:root{--bg-night: #0e1713;--bg-canopy: #183126;--bg-moss: #254637;--surface-strong: rgba(13, 24, 20, .9);--surface-card: rgba(24, 39, 32, .78);--surface-soft: rgba(255, 248, 232, .08);--surface-elevated: rgba(255, 252, 244, .12);--line-soft: rgba(255, 244, 214, .16);--line-strong: rgba(255, 214, 135, .34);--text-main: #f5efdf;--text-soft: #d7cfbc;--text-muted: #a9b6a8;--gold: #f2c46d;--gold-bright: #ffd987;--amber: #e89b2f;--leaf: #74b67c;--leaf-deep: #3d7c52;--danger: #d46b54;--danger-deep: #8e4136;--info: #83bbd9;--shadow-deep: 0 24px 80px rgba(0, 0, 0, .36);--shadow-card: 0 20px 45px rgba(0, 0, 0, .24);--radius-xl: 28px;--radius-lg: 22px;--radius-md: 16px;--radius-sm: 12px;--content-width: 1520px}*{box-sizing:border-box;margin:0;padding:0}html{color-scheme:dark}body{min-height:100vh;font-family:Trebuchet MS,Lucida Sans Unicode,Lucida Grande,sans-serif;line-height:1.5;color:var(--text-main);background:radial-gradient(circle at top,rgba(242,196,109,.08),transparent 34%),radial-gradient(circle at 20% 20%,rgba(116,182,124,.14),transparent 28%),linear-gradient(160deg,var(--bg-night) 0%,var(--bg-canopy) 48%,var(--bg-moss) 100%);position:relative;overflow-x:hidden}body:before,body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1}body:before{background:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:radial-gradient(circle at center,black 45%,transparent 100%);mask-image:radial-gradient(circle at center,black 45%,transparent 100%);opacity:.25}body:after{background:radial-gradient(circle at center,transparent 0%,rgba(0,0,0,.38) 100%)}button,[role=button]{-webkit-tap-highlight-color:transparent}button{font:inherit}a{color:inherit}.app-header{width:min(calc(100% - 1.5rem),var(--content-width));margin:1rem auto 0;padding:.5rem 1.25rem;display:grid;grid-template-columns:1fr;justify-items:center;align-items:center;gap:1rem;border:1px solid var(--line-soft);border-radius:var(--radius-xl);background:linear-gradient(135deg,#fff8e814,#fff8e808),#08100c80;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-card)}.header-copy{text-align:center}.eyebrow,.section-badge{display:inline-flex;align-items:center;gap:.4rem;width:fit-content;text-transform:uppercase;letter-spacing:.22em;font-size:.68rem;color:var(--gold-bright)}.eyebrow{margin:0 auto .4rem}.section-badge{padding:.42rem .75rem;border-radius:999px;border:1px solid rgba(255,217,135,.2);background:#ffd98714;margin-bottom:.85rem}.header-copy h1{font-family:Georgia,Times New Roman,serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:700;letter-spacing:.02em;color:var(--gold-bright);text-shadow:0 8px 24px rgba(0,0,0,.32)}.header-copy>p:last-child{margin-top:.45rem;color:var(--text-soft);font-size:clamp(.96rem,2vw,1.15rem)}.header-ornament{font-size:1.3rem;color:#ffd987c7}.app-shell{width:min(calc(100% - 1.5rem),var(--content-width));margin:1rem auto 0}#game-status{width:100%;margin:0 auto 1rem}.status{display:flex;align-items:center;justify-content:center;gap:.75rem;min-height:3.75rem;padding:.9rem 1.1rem;border-radius:18px;border:1px solid var(--line-soft);background:linear-gradient(135deg,#ffffff14,#ffffff08);box-shadow:var(--shadow-card);text-align:center;font-weight:700;letter-spacing:.02em;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.status-dot{width:.8rem;height:.8rem;border-radius:999px;background:currentColor;box-shadow:0 0 #ffffff59;animation:pulse 2s infinite;flex-shrink:0}.status.info{color:#d7ecfb;border-color:#83bbd959;background:linear-gradient(135deg,#548daf42,#19364466)}.status.success,.status.jaguar{color:#f6e2af;border-color:#f2c46d59;background:linear-gradient(135deg,#e89b2f40,#49351066)}.status.warning,.status.dogs{color:#d8f3da;border-color:#74b67c57;background:linear-gradient(135deg,#3d7c5261,#14371f6b)}.status.error,.status.game-over{color:#ffd4c7;border-color:#d46b5461;background:linear-gradient(135deg,#8d413675,#3f130e85)}.game-container{display:grid;grid-template-columns:minmax(17rem,21rem) minmax(0,1fr);gap:1.25rem;align-items:start}.game-sidebar{position:sticky;top:1rem}.sidebar-content{display:grid;gap:1rem}.welcome-section{display:grid;gap:.9rem}.welcome-section,.game-info-panel,.rules-card,.replay-section,.matchmaking-status{position:relative;border:1px solid var(--line-soft);border-radius:var(--radius-lg);background:linear-gradient(180deg,#fffcf414,#fffcf408),var(--surface-card);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-card)}.welcome-section,.game-info-panel{padding:1.25rem}.welcome-section>.game-info-panel{padding:.95rem .95rem .2375rem;background:linear-gradient(180deg,#ffd98717,#ffd98708),#0a120e47}.welcome-section>.game-info-panel .section-badge{margin-bottom:.55rem}.welcome-section>.game-info-panel h3{margin-bottom:.6rem;font-size:1rem}.welcome-section>.game-info-panel .game-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem}.welcome-section>.game-info-panel .stat-item{padding:.7rem .55rem;border-radius:14px}.welcome-section>.game-info-panel .stat-value{font-size:clamp(.96rem,.95vw,1.2rem);line-height:1.15}.welcome-section>.game-info-panel .stat-label{font-size:.64rem;letter-spacing:.1em}.welcome-section:after,.game-info-panel:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;border:1px solid rgba(255,255,255,.04);pointer-events:none}.welcome-section h2,.game-info-panel h3,.replay-section h3,.rules-card h3,.rules-modal h2,.modal-panel h2,.modal-panel h3,.victory-modal h2,.victory-modal h3{font-family:Georgia,Times New Roman,serif}.welcome-section h2{font-size:clamp(1.65rem,2vw,2rem);color:var(--gold-bright);margin-bottom:.55rem}.welcome-section>p{color:var(--text-soft);margin-bottom:1rem;max-width:32ch}.rules-card,.replay-section,.matchmaking-status{padding:1rem}.rules-card{background:linear-gradient(180deg,#ffe1a314,#ffe1a305),#10191580}.rules-card h3,.replay-section h3,.game-info-panel h3{margin-bottom:.75rem;color:var(--text-main);font-size:1.1rem;letter-spacing:.04em}.rules-card ul,.rules-modal .rules-section ul{list-style:none}.rules-card li,.rules-modal .rules-section li{color:var(--text-soft)}.rules-card li+li,.rules-modal .rules-section li+li{margin-top:.45rem}.rules-card strong,.rules-modal strong,.victory-details strong{color:var(--gold-bright)}.btn-text{background:none;border:none;padding:0;color:var(--gold-bright);text-decoration:underline;text-underline-offset:.18em;cursor:pointer}.btn-text:hover,.btn-text:focus-visible{color:#fff4d4}.actions,.game-controls{display:grid;gap:.8rem}.actions{margin-top:1rem}.btn-primary,.btn-secondary,.btn-danger{min-height:3.25rem;width:100%;padding:.9rem 1rem;border-radius:16px;border:1px solid transparent;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease;text-transform:uppercase;letter-spacing:.08em;font-size:.84rem;font-weight:800;box-shadow:0 12px 24px #0003;touch-action:manipulation}.btn-pill{border-radius:999px}.btn-primary{color:#24190a;background:linear-gradient(135deg,var(--gold-bright),var(--amber));border-color:#ffe09d6b}.btn-secondary{color:var(--text-main);background:linear-gradient(135deg,#ffffff1a,#ffffff0a);border-color:var(--line-soft)}.btn-danger,.btn-secondary.btn-danger{color:#ffe2db;background:linear-gradient(135deg,#d46b54e6,#8e4136f2);border-color:#ffd4c733}.btn-primary:hover,.btn-secondary:hover,.btn-danger:hover,.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-danger:focus-visible,.replay-buttons button:hover,.replay-buttons button:focus-visible,.position-group:focus-visible{transform:translateY(-2px)}.btn-primary:hover,.btn-primary:focus-visible{box-shadow:0 14px 28px #e89b2f52}.btn-secondary:hover,.btn-secondary:focus-visible,.replay-buttons button:hover,.replay-buttons button:focus-visible{background:linear-gradient(135deg,#ffffff29,#ffffff14);border-color:var(--line-strong)}.btn-danger:hover,.btn-danger:focus-visible{box-shadow:0 14px 26px #8e41364d}.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-danger:focus-visible,.replay-buttons button:focus-visible,.btn-text:focus-visible,.position-group:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px}.game-info-panel h3{margin-bottom:.9rem}.game-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(8.5rem,1fr));gap:.85rem}.stat-item{padding:.95rem .8rem;border-radius:18px;border:1px solid rgba(255,255,255,.05);background:linear-gradient(180deg,#ffffff0d,#ffffff05),#080e0b42;text-align:center}.stat-value{color:var(--gold-bright);font-size:clamp(1.15rem,1.2vw,1.45rem);font-weight:800;word-break:break-word}.stat-label{margin-top:.2rem;color:var(--text-muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.12em}.replay-controls{margin-top:.085rem}.replay-buttons{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.45rem}.replay-buttons button{min-height:3rem;padding:.75rem .5rem;border-radius:14px;border:1px solid var(--line-soft);background:linear-gradient(135deg,#ffffff17,#ffffff0a);color:var(--text-main);cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease;font-weight:700}.replay-buttons button:disabled{opacity:.48;cursor:not-allowed;transform:none}.replay-progress{margin-top:.7rem;text-align:center;color:var(--text-soft);font-size:.92rem}.matchmaking-status{overflow:hidden}.status-message{display:flex;align-items:center;gap:.6rem;font-weight:700;color:var(--text-main)}.status-message:before{content:"";width:.75rem;height:.75rem;border-radius:999px;background:var(--gold-bright);box-shadow:0 0 #ffd9874d;animation:pulse 2s infinite}.status-details{margin-top:.45rem;color:var(--text-soft);font-size:.94rem}.game-main{display:grid;gap:1rem;align-items:start;justify-items:center}.game-main-layout{width:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(16.75rem,19rem);gap:1rem;align-items:start}.board-column,.game-side-column{width:100%;display:grid;gap:1rem;align-items:start}.game-side-column{display:flex;flex-direction:column;align-items:stretch;gap:1rem}.game-side-column .matchmaking-queue-panel{flex:0 1 auto;overflow-y:auto;max-height:18rem}.board-wrapper{width:100%;padding:clamp(.4rem,1.2vw,.8rem) 0 0;display:grid;gap:.95rem;justify-items:center;align-items:start;overflow:visible}#game-board{width:100%;display:flex;justify-content:center}.board-svg{width:min(100%,42rem);height:auto;border-radius:22px;border:1px solid rgba(78,53,18,.28);background:radial-gradient(circle at top,#fffaeff5,#ecdcbffa);box-shadow:inset 0 0 0 1px #ffffff73,inset 0 12px 28px #ffffff47,0 18px 34px #00000038}.connection-line{stroke:#7a5637;stroke-width:2.8;opacity:.7}.position-label{display:none}.touch-target{pointer-events:all}.position-group{transition:opacity .16s ease,transform .16s ease;outline:none}.position-group.has-piece:hover image,.position-group.has-piece:focus-visible image,.position-group.is-selected image{filter:drop-shadow(0 10px 14px rgba(0,0,0,.22))}.position-group.is-valid-move circle:nth-of-type(2){filter:drop-shadow(0 0 10px rgba(61,124,82,.4))}.position-group:focus-visible .touch-target,.position-group.is-selected .touch-target{stroke:#ffd987b3;stroke-width:2}.piece-jaguar,.piece-dog{transition:transform .16s ease,filter .16s ease}.position-group.has-piece:hover .piece-jaguar,.position-group.has-piece:hover .piece-dog{transform:translateY(-2px)}.game-controls{grid-template-columns:repeat(auto-fit,minmax(11rem,1fr))}.game-controls button{min-height:3.5rem}.board-attribution{width:min(100%,42rem);margin:0 auto;text-align:center;color:var(--text-muted);font-size:.84rem}.auth-panel{padding:1rem;background:linear-gradient(180deg,#73c48d14,#73c48d05),#10191580}.auth-panel.is-authenticated{background:linear-gradient(180deg,#74b67c21,#74b67c0a),#0e19128a}.auth-helper-text{color:var(--text-soft)}.auth-summary,.auth-actions{display:grid;gap:.75rem}.auth-actions{margin-top:1rem}.auth-label{color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em}.auth-email{margin-top:.3rem;color:var(--gold-bright);font-size:1rem;font-weight:800;overflow-wrap:anywhere}.matchmaking-queue-panel{padding:1rem;background:linear-gradient(180deg,#87b4ff14,#87b4ff05),#10151e80}.matchmaking-status-inline{padding:.5rem .7rem;margin-bottom:.5rem;border-radius:var(--radius-sm, 6px);background:#daa5201a;border:1px solid rgba(218,165,32,.2)}.matchmaking-status-inline .status-message{font-size:.84rem;font-weight:600;color:var(--gold-bright, #f0c040)}.matchmaking-status-inline .status-details{font-size:.75rem;color:var(--text-muted);margin-top:.2rem}.queue-empty-message{color:var(--text-muted);font-size:.85rem;font-style:italic;text-align:center;padding:.5rem 0}.queue-player-list{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}.queue-player-item{display:flex;align-items:center;gap:.5rem;padding:.45rem .7rem;border-radius:var(--radius-sm, 6px);background:#ffffff0a;border:1px solid rgba(255,255,255,.06);font-size:.84rem;color:var(--text-soft)}.queue-player-item.is-current-user{background:#daa5201a;border-color:#daa52040;color:var(--gold-bright, #f0c040)}.queue-player-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace;font-size:.8rem}.queue-you-badge{font-size:.72rem;font-weight:700;color:var(--gold-bright, #f0c040);white-space:nowrap}.app-footer{width:min(calc(100% - 1.5rem),var(--content-width));margin:1.1rem auto 1.25rem;padding:1rem 1.1rem 1.4rem;text-align:center;color:var(--text-muted);font-size:.84rem}.app-footer a{color:var(--gold);text-decoration:none}.app-footer a:hover,.app-footer a:focus-visible{color:var(--gold-bright)}.attribution{margin-top:.45rem;line-height:1.8}.rules-modal-backdrop,.modal-backdrop,.victory-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1rem;background:#030806b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;animation:fadeIn .24s ease}.rules-modal,.modal-panel,.victory-modal{width:min(100%,40rem);max-height:min(86vh,46rem);overflow-y:auto;padding:1.4rem;border-radius:24px;border:1px solid var(--line-strong);background:linear-gradient(180deg,#fffaef14,#fffaef08),var(--surface-strong);box-shadow:var(--shadow-deep);color:var(--text-main);animation:modalSlideIn .24s ease}.rules-modal h2,.victory-modal h2,.modal-panel h3{color:var(--gold-bright)}.rules-modal h2,.victory-modal h2{margin-bottom:1rem;text-align:center;font-size:clamp(1.7rem,4vw,2.15rem)}.rules-modal .rules-section+.rules-section{margin-top:1.15rem}.rules-modal .rules-section h3{margin-bottom:.6rem;color:var(--leaf);font-size:1.15rem}.rules-modal .rules-section li{position:relative;padding-left:1.1rem}.rules-modal .rules-section li:before{content:"•";position:absolute;left:0;color:var(--gold-bright)}.rules-modal .close-btn{margin-top:1.25rem}.modal-panel,.victory-modal{text-align:center}.modal-panel>p,.victory-modal h3,.victory-details,.rules-modal .rules-section{color:var(--text-soft)}.signup-modal-panel{width:min(100%,32rem)}.signup-helper-text{margin-bottom:1rem}.signup-form{display:grid;gap:.95rem}.form-field{display:grid;gap:.45rem}.form-field span{font-weight:700;color:var(--text-main)}.form-field input{width:100%;min-height:3rem;padding:.8rem .95rem;border-radius:14px;border:1px solid var(--line-soft);background:#fffcf414;color:var(--text-main);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.form-field input::placeholder{color:var(--text-muted)}.form-field input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #f2c46d29;background:#fffcf41f}.form-field input:disabled{opacity:.72;cursor:not-allowed}.form-error{margin:0;color:#ffd4c7;font-weight:700}.signup-actions{display:grid;gap:.75rem;margin-top:.25rem}.difficulty-selection{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;margin:.9rem 0 1.2rem}.difficulty-btn{min-height:3rem}.difficulty-btn.selected{background:linear-gradient(135deg,var(--gold-bright),var(--amber));color:#24190a;border-color:#ffe09d6b}.side-selection{display:grid;gap:.7rem;margin-top:.9rem}.victory-modal h3{margin-bottom:1rem;font-size:1.15rem}.victory-details{display:grid;gap:.45rem;margin-bottom:1.25rem}.victory-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}@media (min-width: 1280px){.app-header{margin-top:.65rem;padding:.375rem 1rem}.header-copy h1{font-size:clamp(1.85rem,2.6vw,2.85rem)}.app-shell{margin-top:.7rem}#game-status{margin-bottom:.75rem}.status{min-height:3rem;padding:.7rem .95rem;font-size:.95rem}.game-container{grid-template-columns:minmax(18.25rem,20rem) minmax(0,1fr);gap:.9rem;align-items:start}.game-sidebar,.sidebar-content,.welcome-section{height:auto}.sidebar-content{gap:.45rem}.welcome-section,.game-info-panel{padding:.72rem}.rules-card,.replay-section,.matchmaking-status{padding:.65rem}.rules-card,.replay-section{padding-bottom:.16rem}.rules-card .btn-text{display:inline-block;margin-top:.35rem;margin-bottom:0}.replay-section>.btn-pill{margin-bottom:0}.rules-card h3,.replay-section h3,.game-info-panel h3{margin-bottom:.42rem;font-size:.94rem}.rules-card li,.status-details,.replay-progress{font-size:.8rem}.actions{margin-top:.45rem;gap:.45rem}.btn-primary,.btn-secondary,.btn-danger{min-height:2.4rem;padding:.58rem .8rem;font-size:.72rem}.game-main{height:100%;min-height:0}.game-main-layout{grid-template-columns:minmax(0,1fr) minmax(17.25rem,19.5rem);gap:1.05rem}.board-wrapper{height:auto;min-height:auto;padding:.2rem 0 0;display:grid;grid-template-rows:auto auto;align-items:start;justify-items:center;gap:.65rem}#game-board{height:auto;align-items:center}.board-svg{width:min(100%,34.25rem);max-height:none}.game-controls{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;width:min(100%,42rem);margin:0 auto;gap:.65rem}.game-controls button{min-height:2.75rem;flex:0 1 10.5rem;max-width:12rem}.board-attribution{font-size:.76rem}.app-footer{margin:.6rem auto .85rem;padding:.6rem 1rem .8rem;font-size:.76rem}.attribution{margin-top:.25rem;line-height:1.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%{box-shadow:0 0 #ffffff47}70%{box-shadow:0 0 0 .6rem #fff0}to{box-shadow:0 0 #fff0}}@media (max-width: 1100px){.game-container{grid-template-columns:1fr}.game-sidebar{position:static;order:2}.game-main{order:1}.game-main-layout{grid-template-columns:1fr}.game-side-column{width:min(100%,30rem);justify-self:center}.sidebar-content{grid-template-columns:1.2fr .8fr;align-items:start}}@media (max-width: 760px){.app-header{grid-template-columns:1fr;justify-items:center;text-align:center;padding:.5rem 1rem}.header-ornament:last-child{display:none}.app-shell,.app-footer,.app-header{width:min(calc(100% - 1rem),var(--content-width))}.sidebar-content{grid-template-columns:1fr}.board-wrapper{padding:.7rem}.board-svg{width:min(100%,30rem)}.game-controls{grid-template-columns:repeat(2,minmax(0,1fr))}.difficulty-selection,.victory-actions{grid-template-columns:1fr}}@media (max-width: 560px){.status{padding-inline:.85rem;font-size:.95rem}.status-dot{display:none}.welcome-section,.game-info-panel,.rules-card,.replay-section,.matchmaking-status,.rules-modal,.modal-panel,.victory-modal{border-radius:20px}.game-controls{grid-template-columns:1fr}.replay-buttons{grid-template-columns:repeat(3,minmax(0,1fr))}.game-stats{grid-template-columns:1fr}.board-wrapper{padding:.55rem}.board-svg{width:100%}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}.drag-piece-flying{filter:drop-shadow(0 6px 12px rgba(0,0,0,.4))}.drag-valid-move{animation:drag-pulse .8s ease-in-out infinite alternate}@keyframes drag-pulse{0%{opacity:.7}to{opacity:1}}#game-board{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.board-svg{touch-action:none}
