*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #111318;--bg-card: #1a1d24;--bg-cell: #2c2418;--bg-cell-alt: #231d14;--bg-input: #0d0f14;--bg-hero: #0d0f14;--bg-board-gap: #0a0a0c;--bg-error: #2a1010;--bg-hover: rgba(255,255,255,.04);--border: #2e3040;--text: #c8cdd8;--text-muted: #6e7383;--amber: #d4943a;--amber-dim: #a06e25;--amber-glow: #e8b060;--red: #b84040;--red-light: #e05555;--teal: #3a7a8a;--teal-light: #4fa8bc;--king-color: #f0d060;--escape-tint: rgba(58, 122, 138, .18);--throne-tint: rgba(212, 148, 58, .22);--selected-tint: rgba(212, 148, 58, .4);--hint-tint: rgba(212, 148, 58, .16);--shadow-dropdown: 0 4px 20px rgba(0,0,0,.4);--shadow-card: 0 2px 8px rgba(0,0,0,.3);--radius: 6px;--gap: 1rem}[data-theme=light]{--bg: #f7f4ee;--bg-card: #ffffff;--bg-cell: #ddd0a8;--bg-cell-alt: #cfc098;--bg-input: #f8f6f0;--bg-hero: #f0ece0;--bg-board-gap: #3a2e1a;--bg-error: #fde8e8;--bg-hover: rgba(0,0,0,.04);--border: #e5e0d5;--text: #1c1913;--text-muted: #7a7060;--amber: #b07015;--amber-dim: #8a5510;--amber-glow: #c88020;--red: #c83030;--red-light: #b02828;--teal: #1e6a7a;--teal-light: #287090;--king-color: #986008;--escape-tint: rgba(30, 106, 122, .12);--throne-tint: rgba(176, 112, 21, .12);--selected-tint: rgba(176, 112, 21, .26);--hint-tint: rgba(176, 112, 21, .14);--shadow-dropdown: 0 4px 20px rgba(0,0,0,.12);--shadow-card: 0 2px 8px rgba(0,0,0,.07)}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.5;transition:background-color .2s ease,color .2s ease}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--amber);text-decoration:none}a:hover{color:var(--amber-glow);text-decoration:underline}h1{font-size:2.4rem;font-weight:700;letter-spacing:-.02em;color:var(--amber-glow)}h2{font-size:1.3rem;font-weight:600;color:var(--text);margin-bottom:.5rem}h3{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:.4rem}.muted{color:var(--text-muted);font-size:.88rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem}button{cursor:pointer;border:none;border-radius:var(--radius);font:inherit;transition:background .15s,color .15s,border-color .15s}button:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--amber);color:#111;padding:.5rem 1.2rem;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--amber-glow)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:.4rem .9rem}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--amber-dim)}.btn-ghost.active{color:var(--amber);border-color:var(--amber)}.btn-small{font-size:.82rem;padding:.25rem .7rem}input[type=text]{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font:inherit;padding:.45rem .75rem;outline:none;transition:border-color .15s}input[type=text]:focus{border-color:var(--amber-dim)}input[type=text]:disabled{opacity:.5}input[type=text][readonly]{color:var(--text-muted)}.form-row{display:flex;gap:.5rem;margin-top:.75rem}.form-row input{flex:1;min-width:0}.checkbox-label{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.86rem;line-height:1.3}.checkbox-label input{width:1rem;height:1rem;accent-color:var(--amber)}.btn-group{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.4rem}.error-banner{display:flex;align-items:center;justify-content:space-between;background:var(--bg-error);border:1px solid var(--red);border-radius:var(--radius);color:var(--red-light);padding:.6rem 1rem;margin-bottom:var(--gap);font-size:.9rem}.error-banner button{background:none;color:var(--red-light);font-size:1rem;line-height:1}.error-inline{background:var(--bg-error);border:1px solid var(--red);border-radius:var(--radius);color:var(--red-light);padding:.5rem .8rem;font-size:.88rem;margin-bottom:.75rem}.link-btn{background:none;border:none;color:var(--red-light);cursor:pointer;font:inherit;padding:0;text-decoration:underline}.link-btn:hover{color:var(--amber-glow)}.move-error{background:var(--bg-error);border:1px solid var(--red);border-radius:var(--radius);color:var(--red-light);padding:.5rem .8rem;font-size:.88rem;margin-bottom:.75rem;text-align:center}input[type=password]{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font:inherit;padding:.45rem .75rem;outline:none;transition:border-color .15s;width:100%}input[type=password]:focus{border-color:var(--amber-dim)}input[type=password]:disabled{opacity:.5}.site-header{border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10;transition:background-color .2s ease,border-color .2s ease}.site-header-inner{max-width:1200px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;width:100%}.site-brand{display:flex;align-items:center;gap:.4rem;font-size:1.1rem;font-weight:700;color:var(--amber);letter-spacing:.02em;text-decoration:none}.site-brand:hover{color:var(--amber-glow);text-decoration:none}.site-brand-icon{width:1.5rem;height:1.5rem;object-fit:contain}.header-right{display:flex;align-items:center;gap:.75rem}.header-vop-link{background:transparent;border:none;color:var(--text-muted);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;padding:.2rem 0;transition:color .15s}.header-vop-link:hover{color:var(--amber)}.lang-switcher{display:flex;gap:.25rem}.lang-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);padding:.2rem .55rem;font-size:.78rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:color .15s,border-color .15s}.lang-btn:hover{color:var(--text);border-color:var(--amber-dim)}.lang-btn.active{color:var(--amber);border-color:var(--amber)}.theme-toggle{background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);padding:.2rem .55rem;font-size:.88rem;line-height:1.4;cursor:pointer;transition:color .15s,border-color .15s}.theme-toggle:hover{color:var(--text);border-color:var(--amber-dim)}.user-panel{position:relative}.user-panel-trigger{display:flex;align-items:center;gap:.45rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.3rem .65rem;font-size:.88rem;cursor:pointer}.user-panel-trigger:hover{border-color:var(--amber-dim)}.user-avatar{display:flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;background:var(--amber-dim);color:#111;border-radius:50%;font-size:.75rem;font-weight:700}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chevron{color:var(--text-muted);font-size:.7rem}.user-dropdown{position:absolute;top:calc(100% + .4rem);right:0;min-width:160px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-dropdown);z-index:100;overflow:hidden}.user-dropdown-name{padding:.6rem 1rem .35rem;font-weight:600;font-size:.88rem;color:var(--amber)}.user-dropdown-badge{padding:0 1rem .45rem;font-size:.75rem;color:var(--text-muted)}.user-dropdown-item{display:block;width:100%;text-align:left;background:transparent;border:none;border-top:1px solid var(--border);color:var(--text-muted);padding:.55rem 1rem;font-size:.88rem;cursor:pointer}.user-dropdown-item:hover{background:var(--bg-hover);color:var(--text)}.page-home{display:flex;flex-direction:column;min-height:100vh}.home-main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem;width:100%}.home-columns{display:flex;gap:2rem;align-items:flex-start}.home-col-games{flex:0 0 30%;min-width:0}.home-col-personal{flex:1;min-width:0;position:sticky;top:1.5rem}.games-empty{margin-top:3rem;text-align:center}.personal-column{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem}.personal-title{font-size:.95rem;font-weight:700;color:var(--amber);margin-bottom:1rem;letter-spacing:.03em;text-transform:uppercase}.personal-loading,.personal-empty{font-size:.88rem}.personal-section{margin-bottom:1.2rem}.personal-section:last-child{margin-bottom:0}.personal-section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.5rem}.personal-game-list{list-style:none;display:flex;flex-direction:column;gap:.3rem}.personal-game-item{display:flex;justify-content:space-between;align-items:center;width:100%;background:transparent;border:1px solid var(--border);border-radius:var(--radius);padding:.45rem .7rem;cursor:pointer;text-align:left;color:var(--text);font-size:.85rem;transition:border-color .12s,background .12s}.personal-game-item:hover{border-color:var(--amber-dim);background:var(--bg-hover)}.personal-game-code{font-family:monospace;font-size:.82rem;letter-spacing:.05em;font-weight:600}.personal-game-status{font-size:.75rem;color:var(--text-muted)}.personal-game-opponent{font-size:.78rem;color:var(--text-muted)}.personal-game-status--active{color:var(--teal-light)}.personal-game-status--waiting{color:var(--amber)}.personal-game-status--finished{color:var(--text-muted)}.personal-doc-h{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.75rem}.personal-doc-p{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin-bottom:.5rem}.difficulty-row{display:flex;align-items:center;gap:.4rem}.difficulty-label{font-size:.75rem;color:var(--text-muted)}@media (max-width: 860px){.home-columns{flex-direction:column}.home-col-games{flex:none;width:100%}.home-col-personal{flex:none;width:100%;position:static}}.games-grid{display:flex;flex-wrap:wrap;gap:1.25rem}.game-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;text-align:left;width:100%;overflow:hidden;padding:0}.game-card:hover{border-color:var(--amber-dim);transform:translateY(-3px);box-shadow:var(--shadow-card)}.game-card-image{background:var(--bg-hero);height:180px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}.game-card-placeholder{font-size:3rem;opacity:.35}.game-card-img{width:100%;height:100%;object-fit:cover;display:block}.game-card-info{padding:.7rem .85rem;display:flex;flex-direction:column;gap:.3rem}.game-card-name{font-weight:600;font-size:.92rem;color:var(--text)}.stars{display:inline-flex;gap:1px}.star{font-size:.8rem}.star-filled{color:var(--amber)}.star-empty{color:var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;overflow-y:auto}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;position:relative}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.2rem .8rem;border-bottom:1px solid var(--border)}.modal-header h2{margin:0}.modal-close{background:transparent;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;line-height:1;padding:.2rem}.modal-close:hover{color:var(--text)}.login-form{padding:1.2rem;display:flex;flex-direction:column;gap:.9rem}.form-label{display:flex;flex-direction:column;gap:.35rem;font-size:.88rem;color:var(--text-muted)}.form-label input{margin-top:.1rem;width:100%}.login-hint{font-size:.8rem}.modal-vop{max-width:680px;max-height:85vh;display:flex;flex-direction:column}.vop-body{padding:1.2rem 1.5rem 1.5rem;overflow-y:auto;line-height:1.65;font-size:.9rem;color:var(--text)}.vop-body h1{font-size:1.05rem;font-weight:700;color:var(--amber);margin:1.4rem 0 .5rem;border-bottom:1px solid var(--border);padding-bottom:.35rem}.vop-body h1:first-child{margin-top:0}.vop-body h2{font-size:.92rem;font-weight:600;color:var(--text);margin:1rem 0 .35rem}.vop-body p{margin:0 0 .65rem;color:var(--text-muted)}.vop-body ul{margin:0 0 .65rem 1.1rem;padding:0;color:var(--text-muted)}.vop-body li{margin-bottom:.2rem}.vop-body hr{border:none;border-top:1px solid var(--border);margin:1.2rem 0}.vop-body blockquote{border-left:3px solid var(--amber-dim);margin:.7rem 0;padding:.35rem .9rem;color:var(--text-muted);font-style:italic}.vop-body a{color:var(--amber);text-decoration:none}.vop-body a:hover{text-decoration:underline}.vop-body del{opacity:.55}.modal-game{max-width:560px;max-height:90vh;overflow-y:auto}.modal-game-hero{background:var(--bg-hero);height:140px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}.modal-game-placeholder{font-size:4rem;opacity:.3}.modal-game-meta{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem .5rem}.modal-game-title{font-size:1.2rem;margin:0}.modal-game-desc{padding:0 1.2rem .9rem;line-height:1.6}.modal-tabs{display:flex;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.modal-tab{flex:1;background:transparent;border:none;color:var(--text-muted);padding:.65rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s}.modal-tab:hover{color:var(--text)}.modal-tab.active{color:var(--amber);border-bottom-color:var(--amber)}.modal-form-area{padding:1rem 1.2rem;border-bottom:1px solid var(--border)}.game-form{display:flex;flex-direction:column;gap:.8rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-label-text{font-size:.85rem;color:var(--text-muted)}.rules-content{font-size:.88rem;line-height:1.7;color:var(--text);display:flex;flex-direction:column;gap:.6rem}.rules-content p{color:var(--text-muted)}.rules-h2{font-size:1rem;color:var(--amber-glow);margin-top:.4rem}.rules-h3{font-size:.9rem;color:var(--text);margin-top:.2rem}.rules-h4{font-size:.85rem;color:var(--text-muted)}.rules-list{padding-left:1.1rem;color:var(--text-muted)}.rules-list li{margin-bottom:.2rem}@media (max-width: 600px){.games-grid{justify-content:center}.game-card{width:100%}.modal-game{max-height:100vh;border-radius:0}.modal-overlay{padding:0;align-items:flex-end}}.page-preview{display:flex;flex-direction:column;min-height:100vh}.preview-main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem;width:100%}.preview-nav{margin-bottom:1.75rem}.preview-hero{background:var(--bg-hero);height:280px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;transition:background-color .2s ease}.preview-hero-placeholder{font-size:5rem;opacity:.25}.preview-hero-img{width:100%;height:100%;object-fit:cover;object-position:left center;display:block;border-radius:var(--radius)}.preview-meta{display:flex;align-items:baseline;gap:1rem;margin-bottom:.6rem}.preview-title{font-size:1.9rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.preview-meta .stars{margin-top:.2rem}.preview-meta .star{font-size:1rem}.preview-desc{margin-bottom:1.75rem;font-size:.95rem;line-height:1.65;color:var(--text-muted)}.preview-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;overflow:hidden;transition:background-color .2s ease,border-color .2s ease}.preview-tabs{display:flex;border-bottom:1px solid var(--border)}.preview-tabs .modal-tab{border-radius:0}.preview-tabs .modal-tab:first-child{border-right:1px solid var(--border)}.preview-form-area{padding:1.25rem 1.4rem;display:flex;flex-direction:column;gap:1rem}.play-columns{display:flex;gap:0;align-items:start}.play-col{flex:1;display:flex;flex-direction:column;gap:.8rem}.play-col+.play-col{border-left:1px solid var(--border);padding-left:1.4rem;margin-left:1.4rem}.play-col-title{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0}@media (max-width: 540px){.play-columns{flex-direction:column}.play-col+.play-col{border-left:none;border-top:1px solid var(--border);padding-left:0;margin-left:0;padding-top:1.2rem;margin-top:.2rem}}.page-preview{background:radial-gradient(circle at 50% 0,rgba(212,148,58,.12),transparent 34rem),linear-gradient(180deg,#090d12 0%,var(--bg) 54%)}.preview-main{max-width:none;padding:0rem 0 3.5rem}.preview-nav,.preview-paths,.preview-feature-strip,.preview-rules-card{width:min(100% - 3rem,1180px);margin-left:auto;margin-right:auto}.preview-nav{margin-bottom:1rem}.preview-hero{position:relative;isolation:isolate;min-height:330px;height:auto;margin:0 0 1.6rem;border:0;border-radius:0;overflow:hidden;background:#070a0e;box-shadow:inset 0 -1px #ffffff14}.preview-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:linear-gradient(90deg,#070a0ef0,#070a0eb3 30%,#070a0e2e 62%,#070a0e85),linear-gradient(0deg,rgba(7,10,14,.18),transparent 42%);pointer-events:none}.preview-hero-copy{position:relative;z-index:2;width:min(100% - 3rem,1180px);min-height:330px;margin:0 auto;padding:2.15rem 0 1.7rem;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.preview-mark{color:var(--amber-dim);font-size:1.45rem;letter-spacing:.18em;margin-bottom:.45rem;width:min(34rem,100%);text-align:center}.preview-kicker,.preview-subtitle,.preview-section-title h2,.preview-feature-strip strong{font-family:Georgia,Times New Roman,serif;letter-spacing:.14em;text-transform:uppercase}.preview-kicker{color:var(--amber);font-size:.82rem;margin-bottom:.15rem;width:min(34rem,100%);text-align:center}.preview-title{width:min(34rem,100%);color:#f5ead9;font-family:Georgia,Times New Roman,serif;font-size:clamp(3.2rem,8vw,5.4rem);line-height:.9;letter-spacing:.04em;text-shadow:0 2px 16px rgba(0,0,0,.75);text-align:center}.preview-subtitle{width:min(34rem,100%);color:var(--amber);font-size:1.28rem;margin-top:.75rem;text-align:center}.preview-desc{width:min(34rem,100%);color:#f5eee2d1;font-size:1.02rem;line-height:1.7;text-align:center;margin:1.1rem 0 0}.preview-hero-actions{width:min(34rem,100%);display:flex;align-items:center;gap:1rem;margin-top:1.2rem}.preview-rules-cta{min-height:2.35rem}.preview-difficulty{display:flex;flex-direction:column;gap:.15rem;align-items:flex-start}.preview-difficulty>span{color:#f5eee2b8;font-size:.72rem;letter-spacing:.08em;line-height:1;text-transform:uppercase}.preview-hero-img{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:center;border-radius:0}.preview-hero-placeholder{position:absolute;right:18%;top:50%;transform:translateY(-50%);color:#ffffff29;font-size:8rem}.preview-section-title{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.3rem;margin:.4rem 0 1.2rem}.preview-section-title span{height:1px;background:linear-gradient(90deg,transparent,var(--amber-dim),transparent)}.preview-section-title h2{color:var(--amber);font-size:1.05rem;margin:0}.preview-paths .error-inline{margin-bottom:1rem}.preview-paths .play-columns{align-items:stretch;gap:2rem}.preview-action-card--dimmed{opacity:.3;pointer-events:none}.preview-action-card{width:100%;min-width:0;min-height:400px;padding:1.55rem 1.7rem;background:linear-gradient(145deg,#ffffff0b,#ffffff04);border:1px solid color-mix(in srgb,var(--border) 70%,var(--amber-dim));border-radius:var(--radius);box-shadow:0 18px 38px #00000038}.preview-paths .play-col+.play-col{border-left:1px solid color-mix(in srgb,var(--border) 70%,var(--amber-dim));padding-left:1.7rem;margin-left:0}.play-card-head{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1rem}.play-card-icon{flex:0 0 auto;display:grid;place-items:center;width:3rem;height:3rem;border:1px solid var(--amber-dim);border-radius:50%;color:var(--amber);font-size:1.45rem}.play-card-head p{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin-top:.2rem}.preview-action-card .play-col-title{color:var(--text);font-family:Georgia,Times New Roman,serif;font-size:1.08rem;letter-spacing:.08em}.preview-action-card .form-label,.preview-action-card .form-label-text{text-transform:uppercase;letter-spacing:.06em;font-size:.76rem}.preview-action-card input[type=text]{min-height:2.65rem;background:#070a0e8c}.preview-action-card .btn-group{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.preview-action-card .btn-small{min-height:2.55rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.4rem .65rem}.preview-action-card .btn-small span{color:var(--amber);font-size:1.05rem}.preview-submit{display:flex;justify-content:space-between;align-items:center;min-height:2.9rem;margin-top:.1rem}.preview-submit span:last-child{font-size:1.55rem;line-height:1}.preview-invited-by{font-size:.88rem;color:var(--teal-light);margin:0 0 .5rem}.preview-hint{display:flex;gap:.7rem;align-items:center;color:var(--amber-glow);background:#d4943a1a;border:1px solid rgba(212,148,58,.25);border-radius:var(--radius);padding:.8rem .95rem;font-size:.88rem}.preview-feature-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.3rem;margin-top:1.6rem;padding:1.05rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.preview-feature-strip div{display:grid;grid-template-columns:auto 1fr;column-gap:.75rem;row-gap:.15rem;align-items:start;min-width:0}.preview-feature-strip div+div{border-left:1px solid var(--border);padding-left:1.3rem}.preview-feature-strip span{grid-row:span 2;color:var(--amber);font-size:2.1rem;line-height:1.2}.preview-feature-strip strong{color:var(--amber);font-size:.88rem}.preview-feature-strip p{color:var(--text-muted);font-size:.88rem}.preview-join-col{scroll-margin-top:5rem}.preview-rules-card{scroll-margin-top:5rem;margin-top:2rem;padding:1.4rem 1.6rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.preview-rules-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem}.preview-rules-head h2{color:var(--text);margin:0}@media (max-width: 900px){.preview-hero-img{width:100%;opacity:.55}.preview-desc{text-align:left}.preview-paths .play-columns{flex-direction:column;align-items:stretch}.preview-paths .play-col+.play-col{border-left:0;border-top:1px solid color-mix(in srgb,var(--border) 70%,var(--amber-dim));padding-left:1.7rem;padding-top:1.55rem;margin-top:0}.preview-feature-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.preview-feature-strip div:nth-child(odd){border-left:0;padding-left:0}}@media (max-width: 600px){.preview-nav,.preview-hero-copy,.preview-paths,.preview-feature-strip,.preview-rules-card{width:min(100% - 2rem,1180px)}.preview-hero,.preview-hero-copy{min-height:380px}.preview-hero-actions{align-items:flex-start;flex-direction:column}.preview-action-card,.preview-paths .play-col+.play-col{padding:1.2rem}.preview-action-card .btn-group,.preview-feature-strip{grid-template-columns:1fr}.preview-feature-strip div+div{border-left:0;padding-left:0;border-top:1px solid var(--border);padding-top:.9rem}.preview-rules-head{flex-direction:column}}.page-game{display:flex;flex-direction:column;min-height:100vh;padding:0 1rem 2rem}.page-game .game-main{max-width:1200px;margin:10px auto;width:100%}.game-nav{display:flex;align-items:center;gap:1.5rem;padding:.75rem 0;border-bottom:1px solid var(--border);margin-bottom:1rem}.back-link{color:var(--amber-dim);font-size:.9rem}.back-link:hover{color:var(--amber)}.waiting-notice{font-size:.88rem;color:var(--text-muted);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.game-layout{display:flex;gap:1.5rem;align-items:flex-start;flex-wrap:wrap}.board-area{flex:0 0 auto}.game-sidebar{flex:1 1 220px;display:flex;flex-direction:column;gap:var(--gap);min-width:300px;max-width:400px}.page-loading,.page-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:var(--text-muted)}.status-panel{font-size:.88rem}.status-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem 0;border-bottom:1px solid var(--border)}.status-row:last-of-type{border-bottom:none}.label{color:var(--text-muted);font-size:.82rem}.game-code{font-family:monospace;font-size:1rem;color:var(--amber);letter-spacing:.05em}.status-badge{font-size:.78rem;padding:.15rem .5rem;border-radius:20px;font-weight:600}.status-waiting{background:#1e2030;color:var(--text-muted)}.status-active{background:#142a14;color:#5ec85e}.status-finished{background:#201530;color:#a070d0}.status-abandoned{background:#1e1616;color:var(--text-muted)}[data-theme=light] .status-waiting{background:#eaeaf5;color:#5050a0}[data-theme=light] .status-active{background:#e0f0e0;color:#1a7020}[data-theme=light] .status-finished{background:#ede0f8;color:#6030a0}[data-theme=light] .status-abandoned{background:#ececec;color:#707070}.side-badge{font-size:.78rem;padding:.15rem .5rem;border-radius:20px;font-weight:600}.side-attackers{background:#2a1010;color:var(--red-light)}.side-defenders{background:#10202a;color:var(--teal-light)}[data-theme=light] .side-attackers{background:#fde8e8;color:var(--red-light)}[data-theme=light] .side-defenders{background:#e0eef8;color:var(--teal-light)}.your-turn{color:var(--amber);font-weight:600}.winner-row{padding:.5rem 0}.winner-row strong{color:var(--amber-glow);font-size:1rem}.status-actions{display:flex;gap:.5rem;padding-top:.6rem;flex-wrap:wrap}.move-history{max-height:340px;overflow-y:auto}.move-list{list-style:none;display:flex;flex-direction:column;gap:.2rem}.move-item{font-family:monospace;font-size:.82rem;padding:.2rem .4rem;border-radius:3px;color:var(--text-muted)}.move-item.side-attackers{border-left:2px solid var(--red)}.move-item.side-defenders{border-left:2px solid var(--teal)}.captures{color:var(--amber-dim)}.move-item.move-clickable{cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none}.move-item.move-clickable:hover{background:var(--bg-hover)}.move-item.move-clickable:focus{outline:2px solid var(--amber-dim);outline-offset:-2px}.move-item.move-selected{background:#d4943a1f;color:var(--text)}.move-item.move-selected.side-attackers{border-left:3px solid var(--red)}.move-item.move-selected.side-defenders{border-left:3px solid var(--teal)}.cell.replay-from{z-index:2;box-shadow:inset 0 0 0 3px #f0bd68b3,inset 0 0 16px #f0bd6838;cursor:default}.cell.replay-to{z-index:2;box-shadow:inset 0 0 0 3px #48c478cc,inset 0 0 16px #48c47847;cursor:default}.cell.replay-captured{cursor:default}.piece.replay-ghost{opacity:.45;filter:drop-shadow(0 0 5px rgba(240,189,104,.95)) drop-shadow(0 0 2px rgba(255,220,140,1))}.piece.replay-to-piece{filter:drop-shadow(0 1px 0 rgba(255,232,185,.26)) drop-shadow(0 0 1px rgba(255,226,170,.32)) drop-shadow(0 5px 4px rgba(14,7,3,.58)) drop-shadow(0 0 7px rgba(72,196,120,.85))}.piece.replay-captured-piece{opacity:.6;filter:drop-shadow(0 1px 0 rgba(255,232,185,.14)) drop-shadow(0 5px 4px rgba(14,7,3,.38))}.replay-cross{position:absolute;top:14%;right:14%;bottom:14%;left:14%;z-index:3;pointer-events:none}.replay-cross:before,.replay-cross:after{content:"";position:absolute;top:50%;left:8%;right:8%;height:3px;border-radius:2px;background:var(--red-light);box-shadow:0 0 6px #b84040d9,0 0 2px #dc5050e6}.replay-cross:before{transform:translateY(-50%) rotate(45deg)}.replay-cross:after{transform:translateY(-50%) rotate(-45deg)}.board-wrap{--cell-size: 54px;--board-padding: 10px;--board-border: 7px;--board-label-height: 1.25rem;display:flex;gap:.35rem;align-items:flex-start;-webkit-user-select:none;user-select:none;padding:.6rem .75rem .75rem .45rem;background:linear-gradient(#76746f8a,#76746f8a),radial-gradient(circle at 50% 42%,rgba(222,216,202,.08),transparent 58%),repeating-linear-gradient(8deg,#5a4f42 0,#5a4f42 9px,#66594a 10px,#66594a 17px,#4a4036 18px,#4a4036 28px);border:1px solid #27221d;border-radius:8px;box-shadow:0 18px 34px #00000057,inset 0 0 0 1px #e8dcbe24,inset 0 0 28px #1e1a1594}.board-labels-col{display:grid;grid-template-rows:repeat(9,var(--cell-size));padding-top:calc(var(--board-label-height) + var(--board-border) + var(--board-padding));padding-bottom:calc(var(--board-border) + var(--board-padding))}.board-labels-row{display:grid;grid-template-columns:repeat(9,var(--cell-size));width:max-content;height:var(--board-label-height);margin-left:calc(var(--board-border) + var(--board-padding))}.board-label{display:flex;align-items:center;justify-content:center;width:var(--cell-size);height:var(--cell-size);font-size:.7rem;font-weight:700;color:#f4d6a3;text-shadow:0 1px 1px #1b0d05}.board-labels-row .board-label{height:var(--board-label-height)}.board-labels-col .board-label{width:1.15rem}.board{position:relative;display:grid;grid-template-columns:repeat(var(--board-size, 9),var(--cell-size));gap:0;padding:var(--board-padding);background:linear-gradient(#65625c61,#65625c61),linear-gradient(90deg,#1b1917b8,#433e3733 12%,#433e3733 88%,#1a1816bd),repeating-linear-gradient(0deg,#514c45 0,#514c45 14px,#5b554d 15px,#5b554d 28px,#49443e 29px,#49443e 42px);border:var(--board-border) solid #2f2a24;border-radius:7px;box-shadow:inset 0 0 0 2px #cab78f47,inset 0 0 30px #12100e8f}.cell{width:var(--cell-size);height:var(--cell-size);display:flex;align-items:center;justify-content:center;border-right:1px solid rgba(32,29,25,.68);border-bottom:1px solid rgba(32,29,25,.68);position:relative;cursor:default;overflow:hidden;transition:filter .12s,box-shadow .12s}.cell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(102deg,rgba(255,255,255,.035),transparent 38%,rgba(38,35,31,.12) 100%),repeating-linear-gradient(6deg,#8a8376 0,#8a8376 18px,#827b70 19px,#827b70 35px,#91897b 36px,#91897b 54px)}.cell:nth-child(9n){border-right:0}.cell:nth-last-child(-n+9){border-bottom:0}.cell:nth-child(2n):before{background:linear-gradient(78deg,rgba(45,41,36,.1),transparent 44%,rgba(255,255,255,.035)),repeating-linear-gradient(-4deg,#7f786d 0,#7f786d 18px,#8b8478 19px,#8b8478 36px,#777167 37px,#777167 54px)}.cell.escape:before{background:linear-gradient(#332f2938,#332f2938),linear-gradient(102deg,rgba(255,255,255,.025),transparent 38%,rgba(38,35,31,.1) 100%),repeating-linear-gradient(6deg,#696258 0,#696258 18px,#625c52 19px,#625c52 35px,#70695f 36px,#70695f 54px)}.cell.throne:before{background:radial-gradient(circle at 50% 50%,rgba(174,160,126,.34) 0 18%,rgba(63,56,47,.72) 19% 22%,transparent 23%),radial-gradient(circle,transparent 0 36%,rgba(70,62,52,.58) 37% 41%,transparent 42%),linear-gradient(102deg,rgba(255,255,255,.03),transparent 38%,rgba(38,35,31,.12) 100%),repeating-linear-gradient(6deg,#766d5f 0,#766d5f 18px,#6c6458 19px,#6c6458 35px,#7d7466 36px,#7d7466 54px)}.cell.selected{filter:saturate(1.18) brightness(1.08);box-shadow:inset 0 0 0 3px #f0bd68,inset 0 0 18px #f0bd6873;z-index:2}.cell.hint{filter:brightness(1.08);cursor:pointer}.cell.hint:after{content:"";width:14px;height:14px;border-radius:50%;background:#2412079e;border:2px solid rgba(255,220,148,.82);box-shadow:0 0 12px #ffcb6e73;pointer-events:none}.cell:focus{outline:2px solid #f0bd68;outline-offset:-3px;z-index:3}.cell[class*=piece-]:not(.hint):after{content:"";position:absolute;top:14%;right:10%;bottom:8%;left:10%;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(ellipse at center,rgba(18,14,10,.5) 0 34%,rgba(18,14,10,.28) 44%,transparent 72%);box-shadow:0 9px 12px #0f0a0647}.cell.side-defenders:not(.piece-king):not(.hint):after{background:radial-gradient(ellipse at center,rgba(34,25,13,.54) 0 32%,rgba(34,25,13,.28) 44%,transparent 72%);box-shadow:0 9px 12px #18100840}.cell.side-attackers:not(.hint):after{background:radial-gradient(ellipse at center,rgba(235,211,166,.24) 0 28%,rgba(20,14,9,.44) 42%,transparent 72%);box-shadow:0 9px 12px #0f0a0652}.cell.piece-king:not(.hint):after{top:8%;right:5%;bottom:5%;left:5%;background:radial-gradient(ellipse at center,rgba(255,213,112,.24) 0 32%,rgba(24,15,7,.48) 48%,transparent 76%);box-shadow:0 10px 15px #0f0a0657}.piece{position:absolute;left:50%;top:50%;width:45.64%;height:74%;aspect-ratio:37 / 60;--piece-offset-x: -50%;display:block;background-image:var(--piece-sprite);background-repeat:no-repeat;background-size:300% 100%;background-origin:content-box;pointer-events:none;transform:translate(var(--piece-offset-x),-50%);transform-origin:50% 50%;transition:transform .12s,filter .12s;z-index:1;filter:drop-shadow(0 1px 0 rgba(255,232,185,.26)) drop-shadow(0 0 1px rgba(255,226,170,.32)) drop-shadow(0 5px 4px rgba(14,7,3,.58))}.piece-defender{--piece-offset-x: -40%;background-position:left center}.piece-king{background-position:center center}.piece-attacker{--piece-offset-x: -60%;background-position:right center}.cell.piece-king .piece{width:58.59%;height:95%;aspect-ratio:37 / 60;--piece-offset-x: -50%;transform:translate(-50%,-50%);filter:drop-shadow(0 1px 0 rgba(255,238,190,.38)) drop-shadow(0 0 2px rgba(255,226,145,.38)) drop-shadow(0 6px 5px rgba(14,7,3,.62)) drop-shadow(0 0 9px rgba(240,190,93,.28))}.board--interactive .cell.own-piece:not(.hint){cursor:pointer}.board--interactive .cell.own-piece:hover .piece{transform:translate(var(--piece-offset-x),-50%) scale(1.06)}.board--interactive .cell.own-piece.piece-king:hover .piece{transform:translate(-50%,-50%) scale(1.04)}@media (max-width: 680px){.board-wrap{--cell-size: 38px;--board-padding: 7px;--board-border: 5px}.board-wrap{padding:.45rem .55rem .6rem .4rem}.board-label{font-size:.6rem}.board-labels-col .board-label{width:.95rem}.game-layout{flex-direction:column}.game-sidebar{max-width:100%}h1{font-size:1.8rem}.preview-title{font-size:1.5rem}}@media (max-width: 420px){.board-wrap{--cell-size: 31px;--board-padding: 5px;--board-border: 4px}.board-wrap{gap:.25rem;padding:.35rem .45rem .45rem .3rem}}.personal-game-left{display:flex;flex-direction:column;gap:.05rem;min-width:0}.personal-game-name{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.personal-game-status--yours{color:var(--amber);font-size:.75rem}.personal-game-status--theirs{color:var(--text-muted);font-size:.75rem}.personal-overview-btn{width:100%;margin-top:.75rem;text-align:center;justify-content:center}.page-my-games{display:flex;flex-direction:column;min-height:100vh}.my-games-main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem;width:100%}.my-games-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.my-games-title{margin:0}.my-games-tabs{display:flex;gap:.35rem;margin-bottom:1.25rem;flex-wrap:wrap}.my-games-empty{margin-top:1rem}.my-games-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.my-games-table{width:100%;border-collapse:collapse;font-size:.88rem}.my-games-table th{text-align:left;color:var(--text-muted);font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.55rem .85rem;border-bottom:1px solid var(--border);white-space:nowrap}.my-games-table td{padding:.55rem .85rem;border-bottom:1px solid var(--border);white-space:nowrap}.my-games-table tbody tr:last-child td{border-bottom:none}.my-games-row{cursor:pointer;transition:background .12s}.my-games-row:hover{background:var(--bg-hover)}.my-games-name{font-weight:500;color:var(--text)}.my-games-code{font-family:monospace;color:var(--amber);font-size:.84rem;letter-spacing:.05em}.turn-you{color:var(--amber);font-weight:600}.turn-opp{color:var(--text-muted)}.winner-you{color:#5ec85e;font-weight:600}.winner-opp{color:var(--red-light)}.winner-draw{color:var(--text-muted)}.opponent-badge{display:inline-block;padding:.1rem .5rem;border-radius:20px;font-size:.78rem;font-weight:500}.opponent-registered{background:#122a14;color:#5ec85e}.opponent-guest{background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border)}[data-theme=light] .opponent-registered{background:#e0f5e0;color:#1a7020}[data-theme=light] .opponent-guest{background:#f0ede8;color:var(--text-muted)}
