@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg: #f4efe6;--bg-elevated: rgba(255, 252, 247, .84);--text: #17202a;--muted: #66707a;--border: rgba(23, 32, 42, .12);--shadow: 0 20px 60px rgba(23, 32, 42, .08);--light-square: #ead8be;--dark-square: #9b7b5b;--accent: #1f7a5f;--accent-soft: rgba(31, 122, 95, .1);--danger: #ba4d43;--success: #247a4c;font-family:IBM Plex Sans,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background:radial-gradient(circle at top,rgba(255,255,255,.72),transparent 38%),linear-gradient(180deg,#f7f2ea,#f1e7d8)}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0}body{overflow:hidden;font-family:IBM Plex Sans,sans-serif;color:var(--text);background:radial-gradient(circle at top,rgba(255,255,255,.72),transparent 38%),linear-gradient(180deg,#f7f2ea,#f1e7d8)}button{font:inherit;border:0;color:inherit;background:none}#app{overflow:hidden}.app-shell{height:100%;display:grid;grid-template-rows:auto minmax(0,1fr);gap:.55rem;padding:.55rem}.topbar{display:flex;align-items:center;justify-content:space-between;gap:.55rem;flex-wrap:wrap}.brand-lockup{display:inline-flex;align-items:center;gap:.55rem;min-width:0}.brand-copy{display:grid;gap:.08rem;min-width:0}.brand-mark{width:2rem;height:2rem;flex:none;display:grid;place-items:center;border-radius:999px;background:linear-gradient(180deg,#1f7a5f29,#1f7a5f14);border:1px solid rgba(31,122,95,.18);box-shadow:0 6px 20px #17202a0d;color:var(--text)}.brand-mark svg{width:1.3rem;height:1.3rem;overflow:visible}.brand-mark use{transform-box:fill-box;transform-origin:center;transform:scale(1.05);fill:currentColor;stroke:currentColor}.mode-switch-inline{margin-inline:auto}.eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700}.brand{font-family:Fraunces,serif;font-size:1.05rem;font-weight:600;letter-spacing:-.03em}.mode-switch{display:inline-flex;gap:.28rem;padding:.2rem;border-radius:999px;border:1px solid var(--border);background:#ffffff80;box-shadow:0 6px 20px #17202a0d}.account-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.42rem .62rem;border-radius:999px;border:1px solid var(--border);background:#ffffff9e;font-size:.82rem;color:var(--muted)}.account-wrap{position:relative;display:inline-flex;align-items:center}.account-avatar{width:1.65rem;height:1.65rem;border-radius:999px;overflow:hidden;display:grid;place-items:center;background:linear-gradient(180deg,#1f7a5f2e,#1f7a5f14);border:1px solid rgba(31,122,95,.18);color:var(--accent);font-size:.74rem;font-weight:700;flex:none}.account-avatar.guest{background:linear-gradient(180deg,#17202a14,#17202a08);color:var(--text)}.account-avatar img{width:100%;height:100%;object-fit:cover}.account-name{max-width:11rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;color:var(--text)}.account-link{color:var(--text);font-weight:700}.profile-back{margin-inline:auto}.app-shell-gated{place-items:center}.auth-shell{width:min(100%,33rem);min-height:100%;display:grid;place-items:center;padding:.5rem}.auth-card{width:100%;display:grid;gap:.9rem;padding:1.2rem;border-radius:28px;border:1px solid var(--border);background:#fffcf7d1;box-shadow:var(--shadow)}.auth-card h1{margin:0;font-family:Fraunces,serif;font-size:clamp(2rem,7vw,3rem);line-height:1;letter-spacing:-.03em}.auth-card p{margin:0;color:var(--muted)}.auth-actions,.auth-form{display:grid;gap:.6rem}.auth-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-input{min-width:0}.auth-input input{width:100%;margin-top:.25rem;border:0;background:transparent;padding:0;color:var(--text);outline:none}.auth-input input::placeholder{color:#67707abf}.auth-error{color:var(--danger);font-size:.85rem}.auth-note{font-size:.82rem}.mode-chip,.ghost-button,.primary-button{border-radius:999px;font-weight:700}.mode-chip{padding:.48rem .72rem;color:var(--muted);transition:background-color .15s ease,color .15s ease,transform .15s ease}.mode-chip.active{background:var(--text);color:#fff}.control-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.4rem}.control-group{display:inline-flex;flex-wrap:wrap;gap:.35rem}.pill{padding:.48rem .72rem;border-radius:999px;background:#ffffff94;border:1px solid rgba(23,32,42,.09);color:var(--muted);font-size:.84rem}.pill.active{background:var(--text);color:#fff;border-color:transparent}.ghost-button,.primary-button{padding:.68rem .95rem;transition:transform .15s ease,background-color .15s ease}.ghost-button{background:#ffffffa6;border:1px solid rgba(23,32,42,.1)}.primary-button{background:var(--accent);color:#fff}.mode-chip:hover,.ghost-button:hover,.primary-button:hover,.square:hover{transform:translateY(-1px)}.trainer-stage{min-height:0;display:grid;place-items:start center;overflow:hidden}.profile-stage{min-height:0;display:grid;gap:.3rem;align-content:start;overflow:hidden;width:min(100%,64rem);margin:0 auto}.profile-sheet{position:relative;display:grid;gap:.6rem;padding:.8rem 1rem .7rem;border:1px solid rgba(23,32,42,.08);border-radius:22px;background:#fffcf7c7;box-shadow:var(--shadow)}.profile-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(23,32,42,.08)}.profile-identity{display:flex;align-items:center;gap:.75rem;min-width:0}.profile-avatar-lg{width:3rem;height:3rem;border-radius:999px;overflow:hidden;display:grid;place-items:center;background:linear-gradient(180deg,#1f7a5f2e,#1f7a5f14);border:1px solid rgba(31,122,95,.18);color:var(--accent);font-size:1rem;font-weight:700;flex:none}.profile-avatar-lg.guest{background:linear-gradient(180deg,#17202a14,#17202a08);color:var(--text)}.profile-avatar-lg img{width:100%;height:100%;object-fit:cover}.profile-copy{min-width:0;display:grid;gap:.05rem}.profile-title{font-family:Fraunces,serif;font-size:clamp(1.4rem,3.6vw,2.2rem);line-height:1.05;letter-spacing:-.03em}.profile-actions{display:inline-flex;gap:.45rem;flex-wrap:wrap;justify-content:flex-end}.profile-meta{display:inline-flex;gap:.4rem;flex-wrap:wrap;color:var(--muted);font-size:.8rem;padding-top:.05rem}.profile-meta span{padding:.34rem .52rem;border-radius:999px;background:#ffffff8c;border:1px solid rgba(23,32,42,.08)}.profile-meta-info{align-self:center}.profile-section{padding-top:.2rem;display:grid;gap:.2rem}.profile-section>.panel-label{color:var(--accent)}.profile-section-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.profile-help-anchor{position:relative}.profile-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;padding-top:.2rem}.profile-hero-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem}.hero-stat{padding:.8rem .85rem;border-radius:16px;background:#ffffffb8;border:1px solid rgba(23,32,42,.08);display:grid;gap:.08rem}.hero-stat span{font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.hero-stat strong{font-size:1.85rem;line-height:1}.profile-list{display:grid;gap:.1rem}.panel-label,.label,.stat-chip span{font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.profile-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.7rem;padding:.42rem .1rem;font-size:.95rem;border-bottom:1px solid rgba(23,32,42,.08)}.profile-row span{min-width:0;color:var(--muted)}.profile-row strong{justify-self:end;color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:1.02rem;font-weight:800}.profile-row:last-child{border-bottom:0}.profile-empty{color:var(--muted);font-size:.84rem}.profile-note{color:var(--muted);font-size:.8rem;line-height:1.35;padding:.1rem 0 .25rem}.info-button{width:1.6rem;height:1.6rem;border-radius:999px;border:1px solid rgba(31,122,95,.22);background:#1f7a5f1f;color:var(--accent);font-weight:800;line-height:1}.profile-help-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem 1rem}.league-table{width:100%;border-collapse:collapse;font-size:.8rem}.league-table th,.league-table td{padding:.38rem .45rem;text-align:left;border-bottom:1px solid rgba(23,32,42,.08)}.league-table th{color:var(--muted);font-size:.67rem;letter-spacing:.12em;text-transform:uppercase}.profile-help-popover{position:absolute;top:calc(100% + .45rem);right:0;width:min(34rem,calc(100vw - 2rem));display:grid;gap:.8rem;padding:.85rem .9rem;border-radius:18px;border:1px solid rgba(23,32,42,.1);background:#fffcf7fa;box-shadow:var(--shadow);z-index:40}.profile-list-inline{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.trainer{width:min(100%,42rem);max-height:100%;display:grid;gap:.42rem;align-content:start}.prompt-row,.hint-row{display:flex;align-items:center;justify-content:space-between;gap:.7rem}.prompt{margin-top:.1rem;font-family:Fraunces,serif;font-size:clamp(1.1rem,2.6vw,1.75rem);font-weight:600;line-height:1.05}.micro-copy{color:var(--muted);font-size:.84rem}.hint-row{font-size:.84rem;color:var(--muted)}.result-line{padding:.5rem .7rem;border-radius:14px;background:#1f7a5f14;border:1px solid rgba(31,122,95,.14);color:var(--text);font-size:.84rem}.board-shell{width:100%;display:grid;place-items:center}.board{width:min(100%,34rem,40vh);aspect-ratio:1;border-radius:18px;overflow:hidden;display:grid;grid-template-columns:repeat(8,1fr);border:1px solid rgba(23,32,42,.18);box-shadow:var(--shadow);background:#fff6}.square{position:relative;aspect-ratio:1;transition:transform .12s ease,background-color .12s ease,box-shadow .12s ease}.square.dark{background:var(--dark-square)}.square:not(.dark){background:var(--light-square)}.square.selected:after,.square.correct:after,.square.wrong:after,.square.missed:after{content:"";position:absolute;top:13%;right:13%;bottom:13%;left:13%;border-radius:14%}.square.selected:after{background:#1f7a5f2e;box-shadow:inset 0 0 0 2px #1f7a5fd9}.square.correct:after{background:#247a4c33;box-shadow:inset 0 0 0 2px #247a4cf2}.square.wrong:after{background:#ba4d4333;box-shadow:inset 0 0 0 2px #ba4d43f2}.square.missed:after{background:#ba4d431f;box-shadow:inset 0 0 0 2px #ba4d438c}.square.piece:before{content:"";position:absolute;top:22%;right:22%;bottom:22%;left:22%;border-radius:999px;background:radial-gradient(circle at 35% 30%,#ffffff2e,#17202a2e 62%);box-shadow:inset 0 0 0 1px #ffffff29}.piece-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;width:100%;height:100%;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(23,32,42,.45))}.piece-icon use{transform-box:fill-box;transform-origin:center;transform:scale(.92)}.piece-marker{position:absolute;top:38%;right:38%;bottom:38%;left:38%;border-radius:999px;pointer-events:none}.piece-marker.friendly{background:#253243;box-shadow:0 0 0 2px #fffc,0 0 0 5px #25324329;border-radius:999px}.piece-marker.enemy{background:#c85b2e;box-shadow:0 0 0 2px #ffffffd1,0 0 0 5px #c85b2e29;border-radius:26%;transform:rotate(45deg)}.stat-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.35rem}.stat-chip{min-width:0;border-radius:14px;padding:.56rem .65rem;background:#ffffff94;border:1px solid rgba(23,32,42,.08)}.stat-chip strong{display:block;margin-top:.12rem;font-size:.82rem;line-height:1.12;overflow:hidden;text-overflow:ellipsis}.select-chip{display:grid;gap:.25rem;min-width:0;flex:1;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.select-chip select{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:14px;border:1px solid rgba(23,32,42,.1);background:#ffffffc2;padding:.62rem .7rem;color:var(--text);font:inherit;text-transform:none}.stat-chip-soft{background:#1f7a5f14}@media(max-width:720px){.topbar{align-items:flex-start;flex-wrap:wrap}.brand-lockup{gap:.45rem}.brand{font-size:.95rem}.brand-mark{width:1.8rem;height:1.8rem}.mode-switch{width:100%;justify-content:space-between}.account-wrap{width:100%;justify-content:flex-end}.mode-chip{flex:1;text-align:center}.control-group{justify-content:center}.control-row{grid-template-columns:1fr}.trainer{gap:.6rem}.prompt-row{gap:.45rem}.prompt{font-size:clamp(1rem,5vw,1.4rem)}.micro-copy,.hint-row{font-size:.78rem}.select-chip select{padding:.56rem .65rem}.stat-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-top{align-items:flex-start;flex-direction:column}.profile-actions{width:100%;justify-content:flex-start}.profile-hero-stats,.profile-columns,.profile-help-grid{grid-template-columns:1fr}.profile-help-popover{right:0;width:min(30rem,calc(100vw - 1.2rem))}.profile-row{font-size:.82rem}.hero-stat strong{font-size:1.5rem}.auth-actions{grid-template-columns:1fr}}.profile-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem}.profile-kpi{padding:.72rem .78rem;border-radius:16px;background:#ffffffb8;border:1px solid rgba(23,32,42,.08);display:grid;gap:.08rem}.profile-kpi span{font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.profile-kpi strong{font-size:1.45rem;line-height:1}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.profile-panel{display:grid;gap:.38rem;padding:.78rem .82rem;border-radius:16px;background:#ffffff9e;border:1px solid rgba(23,32,42,.08)}.profile-panel .panel-label{color:var(--accent)}.profile-panel .profile-list{gap:0}.profile-panel .profile-row{padding:.32rem .05rem;font-size:.9rem}.profile-panel .profile-row strong{font-size:.98rem}.profile-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:1rem;background:#0d12184d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-modal{width:min(42rem,calc(100vw - 2rem));display:grid;gap:.8rem;padding:.9rem 1rem;border-radius:20px;border:1px solid rgba(23,32,42,.1);background:#fffcf7fa;box-shadow:var(--shadow)}.profile-help-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem 1rem}.profile-help-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.profile-help-grid .profile-note{padding-top:.1rem}@media(max-width:720px){.profile-kpis,.profile-grid,.profile-help-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-kpi strong{font-size:1.25rem}}
