*,*: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;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}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{min-height:calc(100vh - var(--nav-height) - 200px);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:rotateY(90deg) scale(.85);opacity:0}to{transform: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:#f5f0e8;border:1px solid #ccc;color:#1a1a1a;box-shadow:var(--shadow-card)}.playing-card--front.suit--red{color:#c0392b}.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:#f5f0e8;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--dealing{animation:card-deal .42s cubic-bezier(.2,.7,.3,1) both;animation-delay:calc(var(--card-i, 0) * 85ms + var(--zone-delay, 0ms));transform-origin:center;backface-visibility:hidden}.playing-card--arriving{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:38px;padding:2px 3px;border-radius:3px}.felt .card-rank-tl,.felt .card-rank-br{font-size:8px}.felt .card-suit-center{font-size:14px}@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-arrow{position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:0;height:0;border-style:solid;border-width:8px 10px 8px 0;border-color:transparent var(--color-accent) transparent transparent;filter:drop-shadow(0 0 6px var(--color-accent-glow));opacity:0}.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--turn .plate-arrow{opacity:1}.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-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(--color-secondary),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 #c07d3559,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,rgba(192,125,53,.55),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;flex-wrap:wrap}.emoji-btn{width:30px;height:30px;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:3px;font-size:16px;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}}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}
