*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100vh;display:flex;flex-direction:column;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}a{color:inherit;text-decoration:none}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}button{cursor:pointer;background:none;border:none}:root{--color-bg: #191c1e;--color-bg-raised: #21272a;--color-bg-elevated: #2a3033;--color-border: #3e484c;--color-border-glow: #5c6a6f;--color-text-primary: #e8dcc8;--color-text-secondary: #9a8c7a;--color-text-dim: #56504a;--color-accent: #f5c518;--color-accent-dim: rgba(245, 197, 24, .12);--color-accent-glow: rgba(245, 197, 24, .28);--color-secondary: #c07d35;--color-secondary-dim: rgba(192, 125, 53, .12);--color-secondary-glow: rgba(192, 125, 53, .28);--color-tertiary: #f5c518;--color-success: #7ec87e;--color-error: #c04a3b;--status-playing: #f5c518;--status-completed: #7ec87e;--status-backlog: #c07d35;--status-dropped: #6a6260;--font-display: "Cinzel", "Playfair Display", serif;--font-body: "Crimson Pro", "Georgia", serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-hero: clamp(3rem, 8vw, 5.5rem);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-24: 6rem;--container-max: 1200px;--container-pad: clamp(1rem, 5vw, 3rem);--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-pill: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.16, 1, .3, 1);--shadow-card: 0 4px 24px rgba(0, 0, 0, .6);--shadow-glow-accent: 0 0 20px var(--color-accent-glow);--shadow-glow-secondary: 0 0 20px var(--color-secondary-glow);--shadow-glow-card: 0 4px 32px rgba(245, 197, 24, .08);--nav-height: 64px;--felt-dark: #1d3a2d;--felt-mid: #224a37;--felt-edge: #15281f;--plate-hi: #3a4146;--plate-mid: #262c30;--plate-lo: #181c1f;--plate-edge: #4b545a;--rivet-hi: #b9a98a;--rivet-mid: #6f6452;--rivet-lo: #2a2519;--felt-accent-color: #c07d35;--felt-accent-glow: rgba(192, 125, 53, .35);--felt-accent-line: rgba(192, 125, 53, .55);--card-front-bg: #f5f0e8;--card-front-border: #ccc;--card-suit-black: #1a1a1a;--card-suit-red: #c0392b}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.2;color:var(--color-text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-block-end:var(--space-4);color:var(--color-text-secondary)}a{color:var(--color-accent);transition:color var(--transition-fast)}a:hover{color:var(--color-secondary)}strong{font-weight:600}em{font-style:italic}small{font-size:var(--text-sm)}code{font-family:var(--font-mono);font-size:var(--text-sm);background:var(--color-bg-elevated);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}blockquote{border-left:3px solid var(--color-accent);padding-left:var(--space-4);margin-block:var(--space-4);color:var(--color-text-secondary);font-style:italic}.text-accent{color:var(--color-accent)}.text-secondary{color:var(--color-text-secondary)}.text-dim{color:var(--color-text-dim)}.text-center{text-align:center}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad)}.section{background-image:radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),linear-gradient(158deg,#2a3135 0%,var(--color-bg-elevated) 45%,#22292d 100%);background-position:15px 15px,calc(100% - 15px) 15px,15px calc(100% - 15px),calc(100% - 15px) calc(100% - 15px),0 0;background-size:11px 11px,11px 11px,11px 11px,11px 11px,100% 100%;background-repeat:no-repeat;border:1px solid var(--color-border);border-top-color:#ffffff14;border-radius:var(--radius-md);box-shadow:inset 0 1px #ffffff12,inset 0 -2px #00000073,0 6px 28px #0000008c;padding-block:var(--space-10);padding-inline:var(--container-pad);margin-block-end:var(--space-16);position:relative;z-index:1}.section-title{font-family:var(--font-display);font-size:var(--text-3xl);margin-block-end:var(--space-8);padding-block-end:var(--space-4);border-bottom:1px solid var(--color-border)}.section-title .accent{color:var(--color-accent)}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6)}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-block-end:var(--space-6)}.filter-bar button,.filter-bar a{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-bg-raised);color:var(--color-text-secondary);font-size:var(--text-sm);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.filter-bar button:hover,.filter-bar a:hover{border-color:var(--color-accent);color:var(--color-accent)}.filter-bar button.active,.filter-bar a.active{background:var(--color-accent-dim);border-color:var(--color-accent);color:var(--color-accent)}.page-header{padding-block:var(--space-12);text-align:center}.page-header h1{font-size:var(--text-4xl);margin-block-end:var(--space-4)}.page-header p{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:600px;margin-inline:auto}.empty-state{text-align:center;padding:var(--space-16);color:var(--color-text-dim)}.empty-state p{font-size:var(--text-lg);color:var(--color-text-dim)}main{flex:1;padding-block-start:calc(var(--nav-height) + var(--space-12));padding-block-end:var(--space-16);position:relative;z-index:1}.section-label{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);display:flex;align-items:center;gap:var(--space-2);margin-block-end:var(--space-3)}.section-label:before{content:"⚙";opacity:.7}@media(max-width:600px){.grid-cards{grid-template-columns:1fr}}.card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);transition:all var(--transition-normal);box-shadow:var(--shadow-card);position:relative}.card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-glow-card),var(--shadow-card);transform:translateY(-3px)}.card-link{display:block;text-decoration:none;color:inherit}.card-image{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:var(--radius-sm);margin-block-end:var(--space-4)}.card-title{font-family:var(--font-display);font-size:var(--text-xl);margin-block-end:var(--space-2)}.card-meta{font-size:var(--text-sm);color:var(--color-text-dim);margin-block-end:var(--space-3)}.card-body{color:var(--color-text-secondary);font-size:var(--text-sm)}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-block-start:var(--space-4);padding-block-start:var(--space-4);border-top:1px solid var(--color-border)}.badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-playing{background:#f5c51826;color:var(--status-playing);border:1px solid rgba(245,197,24,.3)}.badge-completed{background:#7ec87e26;color:var(--status-completed);border:1px solid rgba(126,200,126,.3)}.badge-backlog{background:#c07d3526;color:var(--status-backlog);border:1px solid rgba(192,125,53,.3)}.badge-dropped{background:#6a626026;color:var(--status-dropped);border:1px solid rgba(106,98,96,.3)}.badge-released{background:#7ec87e26;color:var(--status-completed);border:1px solid rgba(126,200,126,.3)}.badge-development{background:#f5c51826;color:var(--status-playing);border:1px solid rgba(245,197,24,.3)}.badge-category{background:var(--color-accent-dim);color:var(--color-accent);border:1px solid rgba(245,197,24,.2)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-6);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;text-decoration:none;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent}.btn-primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent)}.btn-primary:hover{background:transparent;color:var(--color-accent);box-shadow:var(--shadow-glow-accent)}.btn-secondary{background:transparent;color:var(--color-secondary);border-color:var(--color-secondary)}.btn-secondary:hover{background:var(--color-secondary-dim);box-shadow:var(--shadow-glow-secondary)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border)}.btn-ghost:hover{border-color:var(--color-border-glow);color:var(--color-text-primary)}.btn-danger{background:transparent;color:var(--color-error);border-color:var(--color-error)}.btn-danger:hover{background:#c04a3b26}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.rating{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--color-accent);font-weight:600;font-size:var(--text-sm)}.rating-value{font-family:var(--font-mono)}.tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag{padding:var(--space-1) var(--space-2);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--color-text-dim)}.favorite-star{color:var(--color-accent);font-size:var(--text-lg)}.accordion{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-block-end:var(--space-4);overflow:hidden}.accordion-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);background:var(--color-bg-raised);color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-lg);border:none;cursor:pointer;transition:background var(--transition-fast)}.accordion-trigger:hover{background:var(--color-bg-elevated)}.accordion-trigger .chevron{transition:transform var(--transition-fast);color:var(--color-accent)}.accordion-trigger[aria-expanded=true] .chevron{transform:rotate(180deg)}.accordion-content{padding:var(--space-6);background:var(--color-bg);border-top:1px solid var(--color-border)}.form-group{margin-block-end:var(--space-6)}.form-label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);margin-block-end:var(--space-2);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-dim)}.form-textarea{min-height:120px;resize:vertical}.form-checkbox{display:flex;align-items:center;gap:var(--space-2)}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent)}.form-error{color:var(--color-error);font-size:var(--text-sm);margin-block-start:var(--space-1)}.form-actions{display:flex;gap:var(--space-4);margin-block-start:var(--space-8)}.alert{padding:var(--space-4);border-radius:var(--radius-md);margin-block-end:var(--space-6);font-size:var(--text-sm)}.alert-error{background:#c04a3b26;border:1px solid var(--color-error);color:var(--color-error)}.alert-success{background:#7ec87e26;border:1px solid var(--color-success);color:var(--color-success)}.admin-table{width:100%;border-collapse:collapse;margin-block-start:var(--space-6)}.admin-table th{text-align:left;padding:var(--space-3) var(--space-4);font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.admin-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text-secondary)}.admin-table tr:hover td{background:var(--color-bg-elevated)}.admin-table .actions{display:flex;gap:var(--space-2)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-block-end:var(--space-6)}.admin-header h1{font-size:var(--text-2xl)}.stat-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);text-align:center;transition:all var(--transition-normal);text-decoration:none;display:block}.stat-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-glow-card)}.stat-value{font-family:var(--font-mono);font-size:var(--text-4xl);color:var(--color-accent);font-weight:700}.stat-label{font-size:var(--text-sm);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin-block-start:var(--space-2)}.site-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-height);z-index:100;background-image:radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),linear-gradient(180deg,#2e3a3f,#21292d 60%,#1c2528);background-position:15px calc(100% - 10px),calc(100% - 15px) calc(100% - 10px),0 0;background-size:11px 11px,11px 11px,100% 100%;background-repeat:no-repeat;border-bottom:1px solid rgba(192,125,53,.4);box-shadow:inset 0 1px #ffffff0f,0 4px 20px #0009,0 1px #c07d3533}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad)}.nav-brand{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);text-decoration:none;letter-spacing:.1em;text-transform:uppercase}.logo-bracket{color:var(--color-accent);font-weight:400}.nav-links{display:flex;align-items:center;gap:var(--space-6)}.nav-links a{font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:color var(--transition-fast);position:relative}.nav-links a:hover,.nav-links a.active{color:var(--color-accent)}.nav-links a.active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--color-accent);border-radius:var(--radius-pill)}.nav-links .nav-divider{width:1px;height:24px;background:var(--color-border)}.nav-links .btn-sign-out{padding:var(--space-1) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-pill);font-size:var(--text-xs);color:var(--color-text-dim);cursor:pointer;background:none;text-transform:uppercase;letter-spacing:.08em;transition:all var(--transition-fast)}.nav-links .btn-sign-out:hover{border-color:var(--color-error);color:var(--color-error)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-2)}.hamburger span{display:block;width:24px;height:2px;background:var(--color-text-primary);transition:all var(--transition-fast)}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:768px){.hamburger{display:flex}.nav-links{display:none;position:fixed;top:var(--nav-height);left:0;right:0;flex-direction:column;background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);padding:var(--space-6);gap:var(--space-4);box-shadow:0 8px 24px #00000080}.nav-links.open{display:flex}.nav-links .nav-divider{width:100%;height:1px}}.site-footer{position:relative;z-index:1;background-image:radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),radial-gradient(circle,rgba(245,197,24,.65) 0 2px,var(--color-bg-elevated) 2px 4px,rgba(62,72,76,.9) 4px 5.5px,transparent 5.5px),linear-gradient(180deg,#1c2528,#21292d,#2e3a3f);background-position:12px 12px,calc(100% - 12px) 12px,0 0;background-size:11px 11px,11px 11px,100% 100%;background-repeat:no-repeat;border-top:1px solid rgba(192,125,53,.4);box-shadow:inset 0 1px #c07d3526,inset 0 -1px #0006;padding-block:var(--space-4);margin-block-start:var(--space-8)}.footer-inner{max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.footer-brand{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-primary);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}.footer-links{display:flex;gap:var(--space-4);flex-wrap:wrap}.footer-links a{font-size:var(--text-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.08em;transition:color var(--transition-fast)}.footer-links a:hover{color:var(--color-accent)}.footer-copy{font-size:var(--text-xs);color:var(--color-text-dim);white-space:nowrap}@media(max-width:600px){.footer-inner{flex-direction:column;align-items:center;gap:var(--space-2);text-align:center}.footer-links{justify-content:center}}.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - var(--nav-height))}.admin-sidebar{background:var(--color-bg-raised);border-right:1px solid var(--color-border);padding:var(--space-6)}.admin-sidebar-title{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em;margin-block-end:var(--space-6);padding-block-end:var(--space-4);border-bottom:1px solid var(--color-border)}.admin-sidebar nav{display:flex;flex-direction:column;gap:var(--space-2)}.admin-sidebar nav a{display:block;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast)}.admin-sidebar nav a:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.admin-sidebar nav a.active{background:var(--color-accent-dim);color:var(--color-accent);border-left:3px solid var(--color-accent)}.admin-content{padding:var(--space-8);max-width:960px}@media(max-width:768px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{border-right:none;border-bottom:1px solid var(--color-border)}.admin-sidebar nav{flex-direction:row;flex-wrap:wrap}}.section{opacity:0;transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}.section.section--visible{opacity:1;transform:translate(0)}.gm-animate{opacity:0;transform:translate(50px);transition:opacity var(--transition-slow),transform var(--transition-slow)}.gm-animate.gm-visible{opacity:1;transform:none}@keyframes glitch-1{0%,to{clip-path:none;transform:none}20%{clip-path:inset(40% 0 40% 0);transform:translate(-4px)}40%{clip-path:inset(20% 0 60% 0);transform:translate(4px)}60%{clip-path:inset(60% 0 20% 0);transform:translate(-2px)}80%{clip-path:inset(80% 0 5% 0);transform:translate(2px)}}@keyframes glitch-2{0%,to{clip-path:none;transform:none;color:var(--color-secondary)}15%{clip-path:inset(60% 0 30% 0);transform:translate(5px)}35%{clip-path:inset(10% 0 80% 0);transform:translate(-5px)}55%{clip-path:inset(45% 0 45% 0);transform:translate(3px)}75%{clip-path:inset(75% 0 10% 0);transform:translate(-3px)}}.glitch{position:relative}.glitch.is-glitching:before,.glitch.is-glitching:after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;background:var(--color-bg)}.glitch.is-glitching:before{color:var(--color-accent);animation:glitch-1 .4s steps(1) 1}.glitch.is-glitching:after{color:var(--color-secondary);animation:glitch-2 .4s steps(1) 1}@keyframes page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}#reading-progress{position:fixed;top:var(--nav-height);left:0;width:0%;height:2px;background:linear-gradient(90deg,var(--color-accent),var(--color-secondary));z-index:99;transition:width .1s linear}@keyframes card-deal{0%{transform:perspective(600px) rotateY(90deg) scale(.85);opacity:0}to{transform:perspective(600px) rotateY(0) scale(1);opacity:1}}@keyframes card-play-out{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-28px) scale(.88);opacity:0}}@keyframes card-play-in{0%{transform:translateY(18px) scale(.88);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.playing-card{position:relative;width:clamp(2rem,13vw,3.5rem);aspect-ratio:2.5 / 3.5;border-radius:var(--radius-md);display:flex;flex-direction:column;justify-content:space-between;padding:.25rem;box-sizing:border-box;-webkit-user-select:none;user-select:none;flex-shrink:0}.card--deal{animation:card-deal .35s ease-out both;animation-delay:calc(var(--card-i, 0) * 95ms)}.card--playing{animation:card-play-out .25s ease-in forwards;pointer-events:none}.card--arriving{animation:card-play-in .3s ease-out both}.playing-card--sm{width:2.25rem}.playing-card--back{background:var(--color-bg-raised);border:2px solid var(--color-secondary);background-image:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(192,125,53,.12) 4px,rgba(192,125,53,.12) 8px);box-shadow:inset 0 0 0 3px #c07d3514}.playing-card--front{background:var(--card-front-bg);border:1px solid var(--card-front-border);color:var(--card-suit-black);box-shadow:var(--shadow-card)}.playing-card--front.suit--red{color:var(--card-suit-red)}.playing-card--placeholder{background:transparent;border:2px dashed var(--color-border);opacity:.5}.card-rank-tl{font-family:var(--font-mono);font-size:.7rem;font-weight:700;line-height:1;align-self:flex-start}.card-suit-center{font-size:1.4rem;line-height:1;align-self:center;justify-self:center;margin:auto}.card-rank-br{font-family:var(--font-mono);font-size:.7rem;font-weight:700;line-height:1;align-self:flex-end;transform:rotate(180deg)}.playing-card--selectable{cursor:pointer;background:var(--card-front-bg);border:2px solid transparent;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.playing-card--selectable:hover,.playing-card--selectable:focus-visible{transform:translateY(-6px);box-shadow:0 0 14px var(--color-accent-glow),var(--shadow-card);border-color:var(--color-accent);outline:none}.playing-card--inactive{opacity:.6}.playing-card--highlight{border:2px solid var(--color-accent);box-shadow:0 0 8px var(--color-accent-glow)}.playing-card--kicker{opacity:.55}@keyframes card-play-out-v2{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-34px) scale(.86);opacity:0}}@keyframes card-play-in-v2{0%{transform:translateY(22px) scale(.86);opacity:0}60%{transform:translateY(-4px) scale(1.02);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}@keyframes plate-enter{0%{transform:translateY(12px) scale(.96);opacity:0;filter:brightness(.6)}to{transform:translateY(0) scale(1);opacity:1;filter:brightness(1)}}@keyframes plate-pulse{0%,to{box-shadow:inset 0 1px #ffffff14,inset 0 -1px #0000008c,inset 0 0 0 1px #f5c5182e,0 0 8px #f5c5182e,0 6px 14px #00000080}50%{box-shadow:inset 0 1px #ffffff14,inset 0 -1px #0000008c,inset 0 0 0 1px #f5c51859,0 0 22px var(--color-accent-glow),0 6px 14px #00000080}}@keyframes felt-rail-pulse{0%,to{opacity:.32}50%{opacity:.95}}@keyframes gear-turn{to{transform:rotate(360deg)}}.playing-card--flip-in{animation:card-deal .3s cubic-bezier(.2,.7,.3,1) both;animation-delay:calc(var(--reveal-delay, 0ms) + var(--card-i, 0) * 175ms);transform-origin:center;backface-visibility:hidden}.playing-card--slide-in{animation:card-play-in-v2 .36s cubic-bezier(.2,.7,.3,1) both}.playing-card--playing{animation:card-play-out-v2 .26s ease-in forwards;pointer-events:none}.felt .playing-card{width:52px;padding:3px 4px;border-radius:4px}.felt .card-rank-tl,.felt .card-rank-br{font-size:10px}.felt .card-suit-center{font-size:18px}@media(min-width:769px){.felt .playing-card{width:84px;padding:6px 7px;border-radius:6px}.felt .card-rank-tl,.felt .card-rank-br{font-size:14px}.felt .card-suit-center{font-size:32px}}.your-hand .playing-card{width:58px;padding:4px 5px;border-radius:4px}.your-hand .card-rank-tl,.your-hand .card-rank-br{font-size:11px}.your-hand .card-suit-center{font-size:20px}@media(min-width:769px){.your-hand .playing-card{width:108px;padding:8px 9px;border-radius:7px}.your-hand .card-rank-tl,.your-hand .card-rank-br{font-size:18px}.your-hand .card-suit-center{font-size:42px}}.plate{position:relative;display:grid;grid-template-columns:48px 1fr;column-gap:12px;align-items:center;padding:10px 18px 10px 14px;width:100%;min-height:88px;background:linear-gradient(160deg,var(--plate-hi) 0%,var(--plate-mid) 45%,var(--plate-lo) 100%);border:1px solid var(--plate-edge);border-radius:6px;box-shadow:inset 0 1px #ffffff0f,inset 0 -1px #0000008c,inset 0 0 0 1px #00000059,0 6px 14px #00000080;font-family:var(--font-body);animation:plate-enter .44s cubic-bezier(.2,.7,.3,1) both;animation-delay:calc(var(--plate-i, 0) * 70ms)}.plate:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:5px;pointer-events:none;background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(255,255,255,.018) 2px 3px),repeating-linear-gradient(0deg,transparent 0 9px,rgba(0,0,0,.08) 9px 10px);opacity:.9}.rivet{position:absolute;width:9px;height:9px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--rivet-hi) 0 1px,#8a7d62 1px 2.5px,var(--rivet-mid) 2.5px 3.5px,var(--rivet-lo) 3.5px 4.5px,transparent 4.5px);box-shadow:0 0 0 1px #0000008c,inset 0 0 0 .5px #ffffff1a;z-index:2}.rivet--tl{top:5px;left:5px}.rivet--tr{top:5px;right:5px}.rivet--bl{bottom:5px;left:5px}.rivet--br{bottom:5px;right:5px}.plate--turn{border-color:var(--color-accent);box-shadow:inset 0 1px #ffffff14,inset 0 -1px #0000008c,inset 0 0 0 1px #f5c51840,0 0 16px var(--color-accent-glow),0 6px 14px #00000080;animation:plate-enter .44s cubic-bezier(.2,.7,.3,1) both,plate-pulse 2.2s ease-in-out infinite;animation-delay:calc(var(--plate-i, 0) * 70ms),calc(var(--plate-i, 0) * 70ms + .44s)}.plate--you{border-color:var(--color-secondary)}.plate--you.plate--turn{border-color:var(--color-accent)}.plate--away{opacity:.7;border-style:dashed;border-color:var(--color-error)}.plate--left{opacity:.4;border-style:dashed}.plate--open{--plate-hi: #151819;--plate-mid: #0e1011;--plate-lo: #090b0c;--plate-edge: #1e2326;border-style:dashed;opacity:.6}.plate--open .plate-name{color:var(--color-secondary);font-style:italic;letter-spacing:.08em}.plate-avatar{width:44px;height:44px;background:linear-gradient(160deg,#4a5358,#1d2225);border:1px solid #5e6a70;border-radius:3px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;box-shadow:inset 0 1px #ffffff1a,inset 0 0 12px #00000080;overflow:hidden;flex-shrink:0}.plate-avatar img{width:100%;height:100%;object-fit:cover}.plate-avatar-initials{font-family:var(--font-display);font-size:14px;color:var(--color-text-primary);letter-spacing:.04em;text-shadow:0 1px 1px rgba(0,0,0,.6)}.plate-body{grid-column:2;display:flex;flex-direction:column;justify-content:center;min-width:0;z-index:1;gap:3px}.plate-name{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:.04em;color:var(--color-text-primary);text-shadow:0 1px 1px rgba(0,0,0,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.15;min-height:17px}.plate-title{font-family:var(--font-display);font-size:10px;letter-spacing:.08em;color:var(--color-accent);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:12px;line-height:1.2}.plate-title--empty{visibility:hidden}.badge-row{display:flex;gap:4px;min-height:16px;margin-top:1px}.badge-slot{width:16px;height:16px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;line-height:1}.badge-slot--empty{border:1px dashed rgba(232,220,200,.15);background:#00000040}.badge-slot--filled{background:linear-gradient(160deg,#4a3a1e,#2a2010);border:1px solid var(--color-secondary);color:var(--color-accent);box-shadow:inset 0 1px #f5c51833,0 0 4px #c07d3566}.plate-status{position:absolute;top:6px;right:20px;font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:1px 6px;border-radius:2px;border:1px solid currentColor;background:#0006;z-index:3}.plate-status--away{color:var(--color-error)}.plate-status--left{color:var(--color-text-dim)}.felt{position:relative;background:radial-gradient(80% 70% at 50% 40%,var(--felt-mid) 0%,var(--felt-dark) 55%,var(--felt-edge) 100%);border:1px solid #0a1a13;border-radius:16px;box-shadow:inset 0 0 0 6px #2b1b0d,inset 0 0 0 7px var(--felt-accent-color),inset 0 0 0 10px #2b1b0d,inset 0 0 40px #0009,inset 0 0 120px #00000040,0 16px 40px #0000008c;padding:22px 18px 18px}@media(min-width:769px){.felt{padding:32px 36px 28px}}.felt:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;pointer-events:none;background-image:repeating-linear-gradient(45deg,transparent 0 3px,rgba(0,0,0,.04) 3px 4px),repeating-linear-gradient(-45deg,transparent 0 3px,rgba(255,255,255,.012) 3px 4px)}.felt:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:14px;pointer-events:none;background:radial-gradient(circle at 14px 14px,var(--rivet-hi) 0 1px,var(--rivet-mid) 1px 2.5px,transparent 3px),radial-gradient(circle at calc(100% - 14px) 14px,var(--rivet-hi) 0 1px,var(--rivet-mid) 1px 2.5px,transparent 3px),radial-gradient(circle at 14px calc(100% - 14px),var(--rivet-hi) 0 1px,var(--rivet-mid) 1px 2.5px,transparent 3px),radial-gradient(circle at calc(100% - 14px) calc(100% - 14px),var(--rivet-hi) 0 1px,var(--rivet-mid) 1px 2.5px,transparent 3px)}.felt-rail-glow{position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:14px;pointer-events:none;box-shadow:inset 0 0 22px var(--felt-accent-glow),inset 0 0 6px #f5c5181f;animation:felt-rail-pulse 6.5s ease-in-out infinite;z-index:0}.felt-section{position:relative;z-index:1;display:flex;flex-direction:column;gap:6px}.felt-section+.felt-section{margin-top:14px}.felt-label{display:flex;align-items:center;justify-content:center;gap:14px;font-family:var(--font-display);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#e8dcc8bf;text-shadow:0 1px 0 rgba(0,0,0,.5)}.felt-label-text{display:inline-flex;align-items:baseline;gap:8px;white-space:nowrap}.felt-label-line{flex:1 1 0;height:1px;max-width:38%;background:linear-gradient(90deg,transparent,var(--felt-accent-line),transparent)}.felt-label-count{font-family:var(--font-mono);color:var(--color-accent);font-size:10px;letter-spacing:.08em}.hand-rank{font-family:var(--font-mono);font-size:10px;color:var(--color-secondary);letter-spacing:.12em;text-align:center;text-transform:uppercase}.game-board{display:flex;flex-direction:column;gap:12px}.players-rail{display:none}.table-area{display:flex;flex-direction:column;gap:12px}.plates-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}@media(min-width:769px){.game-board{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start}.players-rail{display:flex;flex-direction:column;gap:10px}.plates-grid{display:none}.mobile-only{display:none!important}}.players-rail-head{display:flex;align-items:center;justify-content:space-between;padding:0 2px 4px;font-family:var(--font-display);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.players-rail-count{font-family:var(--font-mono);color:var(--color-accent);font-size:10px}.rail-spacer{flex:1}.game-board .turn-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 14px}.game-board .your-hand{position:relative;background:linear-gradient(180deg,#1f1c17,#15130f);border:1px solid #3a2f20;border-radius:10px;padding:12px 14px 14px;box-shadow:inset 0 1px #c07d352e,0 -8px 24px #00000080}.your-hand-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.your-hand-title{font-family:var(--font-display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--color-accent)}.your-hand-hint{font-family:var(--font-mono);font-size:10px;color:var(--color-text-dim);letter-spacing:.08em}.emoji-bar{display:flex;gap:6px;align-items:center;justify-content:center;flex-wrap:wrap}.emoji-btn{width:36px;height:36px;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:3px;font-size:19px;line-height:1;cursor:pointer;transition:transform .15s ease,border-color .15s ease;display:flex;align-items:center;justify-content:center}.emoji-btn:hover:not(:disabled){border-color:var(--color-secondary);transform:scale(1.15)}.emoji-btn--cooldown,.emoji-btn:disabled{opacity:.4;cursor:default;transform:none}@keyframes emoji-float{0%{opacity:0;transform:translate(-50%) translateY(4px) scale(.4)}15%{opacity:1;transform:translate(-50%) translateY(-8px) scale(1.3)}30%{opacity:1;transform:translate(-50%) translateY(-12px) scale(1)}80%{opacity:1;transform:translate(-50%) translateY(-28px) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-44px) scale(.85)}}.emoji-float{position:absolute;bottom:calc(100% + 2px);left:50%;font-size:26px;line-height:1;pointer-events:none;z-index:30;animation:emoji-float 1.8s ease-out forwards;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}.felt .card-row,.your-hand .card-row{display:flex;flex-wrap:nowrap;gap:6px;align-items:flex-end;justify-content:center;perspective:600px}@media(min-width:769px){.felt .card-row,.your-hand .card-row{gap:8px}}.felt[data-table-theme=mahogany]{--felt-dark: #2a1510;--felt-mid: #3d1f14;--felt-edge: #1c0e0a;--felt-accent-color: #d4af37;--felt-accent-glow: rgba(212, 175, 55, .35);--felt-accent-line: rgba(212, 175, 55, .55);--rivet-hi: #d4af37;--rivet-mid: #8b6914;border-color:#1a0e08}.felt[data-table-theme=mahogany]:before{background-image:repeating-linear-gradient(90deg,transparent 0 7px,rgba(255,255,255,.015) 7px 8px),repeating-linear-gradient(90deg,transparent 0 18px,rgba(0,0,0,.06) 18px 19px)}.felt[data-table-theme=slate]{--felt-dark: #1a2230;--felt-mid: #243040;--felt-edge: #111820;--felt-accent-color: #78909c;--felt-accent-glow: rgba(120, 144, 156, .35);--felt-accent-line: rgba(120, 144, 156, .55);--rivet-hi: #b0bec5;--rivet-mid: #546e7a;border-color:#0c1118}.felt[data-table-theme=slate]:before{background-image:repeating-linear-gradient(-15deg,transparent 0 5px,rgba(255,255,255,.02) 5px 6px)}.felt[data-table-theme=midnight]{--felt-dark: #080c14;--felt-mid: #0e1525;--felt-edge: #04070e;--felt-accent-color: #8892a4;--felt-accent-glow: rgba(136, 146, 164, .3);--felt-accent-line: rgba(136, 146, 164, .45);--rivet-hi: #9fa8bc;--rivet-mid: #3d4558;border-color:#02040a}.felt[data-table-theme=midnight]:before{background-image:radial-gradient(circle,rgba(255,255,255,.045) 1px,transparent 1px);background-size:12px 12px}.felt[data-table-theme=crimson]{--felt-dark: #1e0808;--felt-mid: #2d0f0f;--felt-edge: #140505;--felt-accent-color: #c07d35;--felt-accent-glow: rgba(192, 125, 53, .35);--felt-accent-line: rgba(192, 125, 53, .55);--rivet-hi: #b9a98a;--rivet-mid: #6f6452;border-color:#0e0404}.felt[data-table-theme=crimson]:before{background-image:repeating-linear-gradient(45deg,transparent 0 8px,rgba(255,255,255,.025) 8px 9px),repeating-linear-gradient(-45deg,transparent 0 8px,rgba(255,255,255,.025) 8px 9px)}.felt[data-table-theme=cyberpunk]{--felt-dark: #060b14;--felt-mid: #0a1020;--felt-edge: #040810;--felt-accent-color: #00e5ff;--felt-accent-glow: rgba(0, 229, 255, .28);--felt-accent-line: rgba(0, 229, 255, .5);--rivet-hi: #00e5ff;--rivet-mid: #00607a;border-color:#010608;box-shadow:inset 0 0 0 6px #05080f,inset 0 0 0 7px #00e5ff,inset 0 0 0 10px #05080f,inset 0 0 40px #000000b3,inset 0 0 120px #00000059,0 16px 40px #000000a6}.felt[data-table-theme=cyberpunk]:before{background-image:repeating-linear-gradient(0deg,transparent 0 19px,rgba(0,229,255,.045) 19px 20px),repeating-linear-gradient(90deg,transparent 0 19px,rgba(0,229,255,.045) 19px 20px),repeating-linear-gradient(135deg,transparent 0 40px,rgba(0,229,255,.022) 40px 41px)}[data-card-skin=kintsugi]{--card-front-bg: #ffffff;--card-front-border: #c8a830;--card-suit-black: #1a1a1a;--card-suit-red: #c0392b}[data-card-skin=kintsugi] .playing-card--front,[data-card-skin=kintsugi] .playing-card--selectable{background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 50 70'%3E%3Cpath d='M28 0 L24 14 L10 26 L16 44 L6 62 L12 70' stroke='%23c8a830' stroke-width='1.6' fill='none' opacity='0.72'/%3E%3Cpath d='M24 14 L36 20 L44 38 L50 36' stroke='%23c8a830' stroke-width='1.1' fill='none' opacity='0.55'/%3E%3Cpath d='M16 44 L30 50 L40 64 L46 70' stroke='%23c8a830' stroke-width='0.9' fill='none' opacity='0.48'/%3E%3C/svg%3E");background-size:100% 100%}[data-card-skin=blood]{--card-front-bg: linear-gradient(to bottom, #c0392b, #4a0000);--card-front-border: #8b0000;--card-suit-black: #0a0a0a;--card-suit-red: #ffffff}[data-card-skin=onyx]{--card-front-bg: #0d0d0d;--card-front-border: #e8e8e8;--card-suit-black: #c0c0c0;--card-suit-red: #d4af37}[data-card-skin=cyberpunk]{--card-front-bg: #0a0e1f;--card-front-border: #00e5ff;--card-suit-black: #00e5ff;--card-suit-red: #ff1744}[data-card-skin=cyberpunk] .playing-card--front .card-rank-tl,[data-card-skin=cyberpunk] .playing-card--front .card-suit-center,[data-card-skin=cyberpunk] .playing-card--front .card-rank-br,[data-card-skin=cyberpunk] .playing-card--selectable .card-rank-tl,[data-card-skin=cyberpunk] .playing-card--selectable .card-suit-center,[data-card-skin=cyberpunk] .playing-card--selectable .card-rank-br{text-shadow:0 0 6px currentColor,0 0 14px currentColor}.cosmetic-card-preview{display:inline-flex;gap:4px;align-items:center}.cosmetic-felt-preview{width:100%;height:48px;border-radius:8px;border:1px solid #0a1a13;box-shadow:inset 0 0 0 3px #2b1b0d,inset 0 0 0 3.5px var(--felt-accent-color),inset 0 0 0 5px #2b1b0d}.wm-game-header{position:fixed;top:0;left:0;right:0;height:2.75rem;z-index:50;background:var(--color-bg-raised);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);box-shadow:0 2px 8px #00000040}.wm-game-brand{font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.12em;color:var(--color-accent)}.wm-exit-link{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-family:var(--font-mono);letter-spacing:.05em;background:transparent;border:1px solid var(--color-border);color:var(--color-text-dim);text-decoration:none;transition:var(--transition-fast)}.wm-exit-link:hover{border-color:var(--color-error);color:var(--color-error)}.worduel-match,.worduel-landing{max-width:900px;margin:var(--space-8) auto;padding:0 var(--space-4)}.worduel-match{padding-top:2.75rem}.wm-heading{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-accent);margin:0 0 var(--space-3);text-align:center;letter-spacing:.04em}.wm-sub{color:var(--color-text-secondary);text-align:center;margin:0 0 var(--space-6)}.wm-panel{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-card);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);max-width:480px;margin:0 auto}.btn-duel{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;color:#191c1e;background:var(--color-accent);border:none;border-radius:var(--radius-md);cursor:pointer;transition:filter var(--transition-fast),transform var(--transition-fast);text-decoration:none}.btn-duel:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-duel:disabled{opacity:.4;cursor:not-allowed}.btn-duel.btn-outline{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.btn-duel.btn-outline:hover:not(:disabled){background:var(--color-accent-dim)}.btn-duel.btn-create{font-size:var(--text-base);padding:var(--space-4) var(--space-10)}.btn-duel.btn-join{background:var(--color-secondary)}.btn-duel.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.wl-header{text-align:center;margin-bottom:var(--space-8)}.wl-title{font-family:var(--font-display);font-size:var(--text-5xl);color:var(--color-accent);letter-spacing:.1em;margin:0 0 var(--space-3)}.wl-tagline{font-size:var(--text-lg);color:var(--color-text-secondary);margin:0}.wl-how{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-8);margin-bottom:var(--space-8)}.wl-how h2{font-family:var(--font-display);color:var(--color-text-primary);font-size:var(--text-xl);margin:0 0 var(--space-4)}.wl-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-4)}.wl-steps li{display:flex;gap:var(--space-4);align-items:flex-start;color:var(--color-text-secondary);font-size:var(--text-base)}.step-num{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:1.75rem;height:1.75rem;border-radius:50%;border:1px solid var(--color-secondary);color:var(--color-secondary);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700}.wl-actions{display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}.wl-divider{color:var(--color-text-dim);font-size:var(--text-sm);letter-spacing:.06em;text-transform:uppercase;position:relative;width:100%;text-align:center}.wl-divider:before,.wl-divider:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:var(--color-border)}.wl-divider:before{left:0}.wl-divider:after{right:0}.wl-join-row{display:flex;gap:var(--space-3);align-items:center}.wl-code-input{font-family:var(--font-mono);font-size:var(--text-base);letter-spacing:.15em;text-align:center;text-transform:uppercase;width:10rem;padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);outline:none}.wl-code-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-dim)}.wm-code-display{font-family:var(--font-mono);font-size:var(--text-4xl);letter-spacing:.3em;color:var(--color-accent);padding:var(--space-4) var(--space-8);background:var(--color-bg-elevated);border:1px solid var(--color-accent-dim);border-radius:var(--radius-md)}.wm-copy-row{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.wm-waiting-msg{color:var(--color-text-dim);font-size:var(--text-sm);text-align:center;margin:0}.wm-qr{width:140px;height:140px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--color-border)}.wm-qr svg{width:100%;height:100%;display:block}.wm-pick-form{width:100%;display:flex;flex-direction:column;gap:var(--space-3);align-items:center}.wm-pick-row{display:flex;gap:var(--space-3);align-items:center}.wm-word-input{font-family:var(--font-mono);font-size:var(--text-base);letter-spacing:.15em;text-align:center;text-transform:lowercase;width:11rem;padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);outline:none}.wm-word-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-dim)}.wm-word-locked{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm)}.lock-icon{font-size:var(--text-xl)}.wm-strict-label{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;max-width:24rem;text-align:left}.wm-strict-checkbox{flex-shrink:0;width:1rem;height:1rem;margin-top:.2em;accent-color:var(--color-accent);cursor:pointer}.wm-strict-text{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.wm-strict-text strong{color:var(--color-text-primary)}.wm-error{color:var(--color-error);font-size:var(--text-sm);margin:0;text-align:center}.wm-playing{max-width:none;margin:0;padding:2.75rem 0 184px}.wm-plates-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);padding:var(--space-2) var(--space-3) 0}.wm-plates-row .plate{grid-template-columns:38px 1fr;min-height:62px;padding:8px 14px 8px 10px;column-gap:8px}.wm-plates-row .plate-avatar{width:34px;height:34px}.wm-opponent-mini{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-2) var(--space-4)}.wm-opponent-mini .wm-mini-cell{width:12px;height:12px}.wm-duel-arena{display:flex;flex-direction:column;align-items:center;padding:0 var(--space-3)}.wm-duel-col{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);width:100%}.wm-duel-plate{display:none;width:100%}.wm-vs-divider,.wm-duel-col--opp{display:none}.wm-playing .wm-cell{width:2.875rem;height:2.875rem;font-size:var(--text-lg)}@media(min-width:880px){.wm-plates-row,.wm-opponent-mini{display:none}.wm-duel-plate{display:block}.wm-duel-col--opp{display:flex}.wm-duel-arena{flex-direction:row;align-items:flex-start;justify-content:center;gap:var(--space-4);padding:var(--space-4) var(--space-6) 0}.wm-duel-col{width:320px;flex-shrink:0;gap:var(--space-3)}.wm-vs-divider{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding-top:var(--space-16);flex-shrink:0}.wm-vs-line{width:1px;height:80px;background:linear-gradient(to bottom,transparent,var(--color-secondary),transparent)}.wm-vs-label{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-secondary);letter-spacing:.15em}.wm-playing .wm-cell{width:3.25rem;height:3.25rem;font-size:var(--text-xl)}.wm-playing .wm-keyboard{left:50%;right:auto;transform:translate(-50%);width:min(600px,100vw);border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.wm-grid-section{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);box-shadow:var(--shadow-card)}.wm-grid-label{font-family:var(--font-display);font-size:var(--text-base);color:var(--color-text-secondary);letter-spacing:.06em;margin:0;display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;justify-content:center}.wm-grid{display:flex;flex-direction:column;gap:var(--space-1)}.wm-row{display:flex;gap:var(--space-1)}.wm-cell{width:2.75rem;height:2.75rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);color:var(--color-text-dim);transition:background var(--transition-fast),border-color var(--transition-fast)}.wm-cell-filled{color:var(--color-text-primary)}.cell-green{background:var(--color-accent);border-color:var(--color-accent);color:#191c1e;box-shadow:var(--shadow-glow-accent)}.cell-yellow{background:var(--color-secondary);border-color:var(--color-secondary);color:#191c1e;box-shadow:var(--shadow-glow-secondary)}.cell-grey{background:var(--color-bg);border-color:var(--color-border);color:var(--color-text-dim)}.wm-guess-form-hidden{display:none}.wm-guesses-left{font-size:var(--text-xs);color:var(--color-text-dim);margin:0}.wm-cell-current{border-color:var(--color-accent-dim);border-width:2px}.wm-mini-grid{display:flex;flex-direction:column;gap:3px}.wm-mini-row{display:flex;gap:3px}.wm-mini-cell{width:1rem;height:1rem;border-radius:2px;border:1px solid var(--color-border);background:var(--color-bg-elevated);transition:background var(--transition-fast)}.wm-mini-cell.cell-green{background:var(--color-accent);border-color:var(--color-accent)}.wm-mini-cell.cell-yellow{background:var(--color-secondary);border-color:var(--color-secondary)}.wm-mini-cell.cell-grey{background:var(--color-bg);border-color:var(--color-border)}.wm-done-bar{position:fixed;bottom:0;left:0;right:0;background:var(--color-bg-raised);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4) var(--space-4) var(--space-5);z-index:50;box-shadow:0 -4px 16px #00000059}.wm-done-bar .wm-waiting-msg{margin:0;font-size:var(--text-sm);color:var(--color-text-secondary)}.wm-keyboard{position:fixed;bottom:0;left:0;right:0;background:var(--color-bg-raised);border-top:1px solid var(--color-border);padding:var(--space-2) var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:5px;z-index:50;box-shadow:0 -4px 16px #00000059}.wm-key-row{display:flex;gap:4px;justify-content:center}.wm-key{flex:1;min-width:0;height:3rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:var(--text-sm);font-weight:700;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);padding:0;text-transform:uppercase;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;letter-spacing:0}.wm-key-enter,.wm-key-backspace{flex:1.5;font-size:var(--text-xs);letter-spacing:.03em}.wm-key:hover:not(:disabled){filter:brightness(1.2)}.wm-key:active:not(:disabled){transform:scale(.93);transition:transform 60ms}.wm-key:disabled{opacity:.28;cursor:not-allowed}.wm-key-green{background:var(--color-accent);border-color:var(--color-accent);color:#191c1e}.wm-key-yellow{background:var(--color-secondary);border-color:var(--color-secondary);color:#191c1e}.wm-key-grey{background:var(--color-bg);border-color:var(--color-border);color:var(--color-text-dim)}.wm-key-grey-lenient{opacity:.55;border-style:dashed}.badge-solved{font-family:var(--font-body);font-size:var(--text-xs);font-weight:400;padding:2px var(--space-2);background:var(--color-accent-dim);border:1px solid var(--color-accent);border-radius:var(--radius-pill);color:var(--color-accent)}.badge-failed{font-family:var(--font-body);font-size:var(--text-xs);font-weight:400;padding:2px var(--space-2);background:#c04a3b1f;border:1px solid var(--color-error);border-radius:var(--radius-pill);color:var(--color-error)}.wm-result-header{text-align:center;margin-bottom:var(--space-8)}.wm-victory{color:var(--color-accent)}.wm-defeat{color:var(--color-secondary)}.wm-expired{color:var(--color-text-dim)}.wm-score-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-6);margin:var(--space-4) 0}.wm-score-block{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.score-name{font-size:var(--text-sm);color:var(--color-text-secondary)}.score-val{font-family:var(--font-display);font-size:var(--text-4xl);color:var(--color-text-primary);line-height:1}.wm-score-sep{font-size:var(--text-2xl);color:var(--color-border)}.wm-score-breakdown{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer}.wm-score-breakdown summary{color:var(--color-text-secondary);cursor:pointer}.breakdown-grid{display:grid;grid-template-columns:auto auto;gap:var(--space-2) var(--space-6);margin-top:var(--space-3);text-align:left}.wm-reveal-word{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;letter-spacing:.06em}.wm-reveal-word strong{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:.2em}.wm-sign-in-note{font-size:var(--text-sm);color:var(--color-text-dim);margin:var(--space-3) 0 0}.wm-arena.wm-reveal{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--space-6);margin-bottom:var(--space-6)}.wm-actions-row{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-4)}.worduel-card{border-color:var(--color-accent-dim);background:linear-gradient(135deg,var(--color-bg-raised),var(--color-bg-elevated))}.worduel-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-glow-card)}.worduel-card-header{display:flex;align-items:baseline;gap:var(--space-3);margin-bottom:var(--space-3)}.worduel-card-title{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-accent);letter-spacing:.06em}.worduel-card-desc{color:var(--color-text-secondary);font-size:var(--text-sm);margin:0 0 var(--space-4);line-height:1.6}.worduel-card-cta{font-family:var(--font-display);font-size:var(--text-xs);color:var(--color-accent);letter-spacing:.08em;text-transform:uppercase}@media(max-width:680px){.wm-cell{width:2.25rem;height:2.25rem;font-size:var(--text-base)}}.wm-forfeit-row{display:flex;justify-content:center;padding-block-start:var(--space-2)}.btn-forfeit{background:transparent;border:1px solid color-mix(in srgb,#c0392b 35%,transparent);color:#c0392b;font-family:var(--font-display);font-size:var(--text-xs);padding:var(--space-1) var(--space-4);border-radius:var(--radius-md);cursor:pointer;letter-spacing:.04em;transition:border-color .12s,color .12s}.btn-forfeit:hover{border-color:#c0392b;color:#e74c3c}.wm-forfeit-banner{text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary);background:color-mix(in srgb,#c0392b 10%,transparent);border:1px solid color-mix(in srgb,#c0392b 30%,transparent);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);margin-block:var(--space-3)}.wm-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-4)}.wm-modal{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);max-width:420px;width:100%;display:flex;flex-direction:column;gap:var(--space-4)}.wm-modal-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-accent);margin:0}.wm-modal-body{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.5}.wm-modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.btn-duel-danger{background:#c0392b;border-color:#922b21;color:#fff}.btn-duel-danger:hover:not(:disabled){background:#e74c3c}.btn-duel-ghost{background:transparent;border-color:var(--color-border);color:var(--color-text-secondary)}.btn-duel-ghost:hover{border-color:var(--color-border-glow);color:var(--color-text)}.wm-theme-root{display:contents}[data-worduel-theme=cyberpunk]{--color-bg: #060b14;--color-bg-raised: #0a1020;--color-bg-elevated: #0e1830;--color-border: rgba(0, 229, 255, .18);--color-border-glow: rgba(0, 229, 255, .42);--color-accent: #00e5ff;--color-accent-dim: rgba(0, 229, 255, .12);--color-accent-glow: rgba(0, 229, 255, .35);--color-secondary: #ff1744;--color-secondary-dim: rgba(255, 23, 68, .12);--color-secondary-glow: rgba(255, 23, 68, .35);--color-text-primary: #c8f0ff;--color-text-secondary: #5a9ab0;--color-text-dim: #1e4a5a}[data-worduel-theme=cyberpunk] .wm-game-header{background-image:repeating-linear-gradient(0deg,transparent 0 19px,rgba(0,229,255,.04) 19px 20px),repeating-linear-gradient(90deg,transparent 0 19px,rgba(0,229,255,.04) 19px 20px)}[data-worduel-theme=cyberpunk] .wm-playing,[data-worduel-theme=cyberpunk] .wm-waiting,[data-worduel-theme=cyberpunk] .wm-picking,[data-worduel-theme=cyberpunk] .wm-complete{background-image:repeating-linear-gradient(0deg,transparent 0 19px,rgba(0,229,255,.03) 19px 20px),repeating-linear-gradient(90deg,transparent 0 19px,rgba(0,229,255,.03) 19px 20px)}[data-worduel-theme=cyberpunk] .cell-green,[data-worduel-theme=cyberpunk] .cell-yellow{color:#060b14;text-shadow:0 0 8px currentColor}[data-worduel-theme=cyberpunk] .wm-key-green,[data-worduel-theme=cyberpunk] .wm-key-yellow{text-shadow:0 0 6px currentColor,0 0 14px currentColor}[data-worduel-theme=midnight]{--color-bg: #0a0818;--color-bg-raised: #100c22;--color-bg-elevated: #160f2e;--color-border: rgba(120, 80, 220, .22);--color-border-glow: rgba(120, 80, 220, .48);--color-accent: #9b7fe8;--color-accent-dim: rgba(155, 127, 232, .12);--color-accent-glow: rgba(155, 127, 232, .35);--color-secondary: #e87fe8;--color-secondary-dim: rgba(232, 127, 232, .12);--color-secondary-glow: rgba(232, 127, 232, .35);--color-text-primary: #d8d0f0;--color-text-secondary: #7060a0;--color-text-dim: #2a1e50}[data-worduel-theme=midnight] .wm-playing,[data-worduel-theme=midnight] .wm-waiting,[data-worduel-theme=midnight] .wm-picking,[data-worduel-theme=midnight] .wm-complete{background-image:radial-gradient(ellipse at 50% 0%,rgba(120,80,220,.08) 0%,transparent 70%)}[data-worduel-theme=midnight] .cell-green,[data-worduel-theme=midnight] .cell-yellow{color:#0a0818}[data-worduel-theme=crimson]{--color-bg: #1a0808;--color-bg-raised: #240c0c;--color-bg-elevated: #2d1010;--color-border: rgba(192, 50, 30, .25);--color-border-glow: rgba(192, 50, 30, .5);--color-accent: #d4af37;--color-accent-dim: rgba(212, 175, 55, .12);--color-accent-glow: rgba(212, 175, 55, .35);--color-secondary: #c07d35;--color-secondary-dim: rgba(192, 125, 53, .12);--color-secondary-glow: rgba(192, 125, 53, .35);--color-text-primary: #e8d8c0;--color-text-secondary: #8a6050;--color-text-dim: #3a1c14}[data-worduel-theme=crimson] .wm-playing,[data-worduel-theme=crimson] .wm-waiting,[data-worduel-theme=crimson] .wm-picking,[data-worduel-theme=crimson] .wm-complete{background-image:repeating-linear-gradient(45deg,transparent 0 8px,rgba(255,255,255,.015) 8px 9px),repeating-linear-gradient(-45deg,transparent 0 8px,rgba(255,255,255,.015) 8px 9px)}[data-worduel-theme=crimson] .cell-green,[data-worduel-theme=crimson] .cell-yellow{color:#1a0808}[data-worduel-theme=verdant]{--color-bg: #071410;--color-bg-raised: #0c1e18;--color-bg-elevated: #102820;--color-border: rgba(40, 140, 80, .22);--color-border-glow: rgba(40, 140, 80, .48);--color-accent: #4caf50;--color-accent-dim: rgba(76, 175, 80, .12);--color-accent-glow: rgba(76, 175, 80, .35);--color-secondary: #d4a017;--color-secondary-dim: rgba(212, 160, 23, .12);--color-secondary-glow: rgba(212, 160, 23, .35);--color-text-primary: #c8e8d0;--color-text-secondary: #507060;--color-text-dim: #1a3828}[data-worduel-theme=verdant] .wm-playing,[data-worduel-theme=verdant] .wm-waiting,[data-worduel-theme=verdant] .wm-picking,[data-worduel-theme=verdant] .wm-complete{background-image:radial-gradient(ellipse at 50% 100%,rgba(40,140,80,.06) 0%,transparent 65%)}[data-worduel-theme=verdant] .cell-green,[data-worduel-theme=verdant] .cell-yellow{color:#071410}canvas.svelte-1w9yhl0{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;pointer-events:none}canvas.svelte-tv9ch6{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}main.game-mode{padding-block-start:0;padding-block-end:0;min-height:100dvh}
