:root{--bg: 240 244 248;--surface: 255 255 255;--text: 15 23 42;--text-secondary: 100 116 139;--text-muted: 148 163 184;--border: 226 232 240;--accent: 59 130 246;--accent-hover: 37 99 235;--shadow-card: 0 6px 0 rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04);--shadow-card-hover: 0 8px 0 rgba(0, 0, 0, .06), 0 16px 48px rgba(0, 0, 0, .1);--radius: 20px;--font-display: "Lilita One", cursive;--font-body: "Nunito", system-ui, sans-serif;--font-mono: "JetBrains Mono", Menlo, monospace;--navy: 30 41 59;--navy-deep: 15 23 42;--blue: #3b82f6;--blue-dark: #2563eb;--blue-deeper: #1d4ed8;--blue-light: #dbeafe;--blue-pale: #eff6ff;--yellow: #fbbf24;--yellow-dark: #d97706;--green: #22c55e;--green-dark: #16a34a;--red: #ef4444;--purple: #8b5cf6;--border-thick: 3px;--shadow-chunky: 0 6px 0 rgba(0, 0, 0, .12);--shadow-chunky-blue: 0 6px 0 var(--blue-dark);--shadow-pop: 0 8px 24px rgba(0, 0, 0, .1), 0 4px 0 rgba(0, 0, 0, .08);--shadow-float: 0 16px 48px rgba(0, 0, 0, .12), 0 6px 0 rgba(0, 0, 0, .06)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}html{overflow-x:hidden}body{background:rgb(var(--bg));color:rgb(var(--text));font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%}::-webkit-scrollbar{width:0;height:0;display:none}html{scrollbar-width:none}body{-ms-overflow-style:none}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}.container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem}.full-screen-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.muted{color:rgb(var(--text-secondary))}.muted-strong{color:rgb(var(--text-muted));font-size:.875rem}.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2.5rem;padding:1.5rem;background:rgb(var(--navy));border-radius:var(--radius);box-shadow:0 6px rgb(var(--navy-deep));border:3px solid rgba(255,255,255,.06);position:relative;overflow:hidden;isolation:isolate}@media(max-width:600px){.stats-bar{grid-template-columns:repeat(2,1fr);padding-top:1.75rem}}.stat-card{text-align:center;position:relative;z-index:1}.stat-value{font-family:var(--font-display);font-size:1.75rem;color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.3)}.stat-yellow{color:var(--yellow)}.stat-green{color:var(--green)}.stat-blue{color:var(--blue-light)}.stat-label{font-size:.6875rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#ffffff80;margin-top:.25rem}.stats-strip-art{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;opacity:.92}.stats-strip-art-left{left:-28px;bottom:-34px;width:210px;max-width:24%}.stats-strip-art-right{right:-26px;bottom:-36px;width:220px;max-width:25%}@media(max-width:900px){.stats-strip-art-left{width:170px;left:-32px;bottom:-26px}.stats-strip-art-right{width:180px;right:-28px;bottom:-28px}}@media(max-width:600px){.stats-strip-art-left{width:126px;left:-20px;bottom:auto;top:-8px;opacity:.78}.stats-strip-art-right{width:130px;right:-16px;bottom:auto;top:-6px;opacity:.78}}.portal-nav{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1.5rem;background:rgb(var(--navy));box-shadow:0 4px rgb(var(--navy-deep)),0 8px 24px #00000026;position:sticky;top:0;z-index:100;border-bottom:none;margin-bottom:0}.portal-nav-brand{font-family:var(--font-display);font-size:1.625rem;color:#fff;text-shadow:0 3px 0 rgba(0,0,0,.3);letter-spacing:.02em}.portal-nav-brand-accent{color:var(--yellow)}.portal-nav-user{display:flex;align-items:center;gap:.625rem;font-size:.8125rem;color:#fff;padding:.375rem 1rem .375rem .375rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.15);border-radius:999px}.portal-nav-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--purple));border:2px solid rgba(255,255,255,.3);overflow:hidden;flex-shrink:0}.portal-nav-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.nav-xp-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;background:var(--yellow);border-radius:999px;font-size:.6875rem;font-weight:900;color:rgb(var(--navy-deep));box-shadow:0 2px 0 var(--yellow-dark)}.nav-avatar-ring{display:inline-flex;align-items:center;gap:.625rem;background:none;border:0;padding:0;color:#fff;font:inherit;font-weight:800;cursor:pointer;transition:transform .12s ease-out}.nav-avatar-ring:hover{transform:translateY(-1px)}.nav-avatar-ring:active{transform:translateY(1px)}.nav-avatar-ring-wrap{position:relative;width:44px;height:44px;flex-shrink:0}.nav-avatar-ring-svg{position:absolute;inset:0;filter:drop-shadow(0 0 4px rgba(255,200,0,.25))}.nav-avatar-ring-img{position:absolute;inset:5px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--blue),var(--purple));display:block}.nav-avatar-ring-img img{width:100%;height:100%;object-fit:cover;display:block}.nav-avatar-ring-level{position:absolute;bottom:-2px;right:-4px;min-width:20px;height:20px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;background:var(--yellow);color:rgb(var(--navy-deep));border:2px solid rgb(var(--navy-deep));border-radius:999px;font-family:var(--font-display);font-size:.6875rem;line-height:1;letter-spacing:.02em;box-shadow:0 2px 0 var(--yellow-dark)}.nav-avatar-ring-name{white-space:nowrap}.nav-find-people{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#ffffff14;border:2px solid rgba(255,255,255,.15);border-radius:50%;color:#fff;cursor:pointer;transition:background .12s ease-out,transform .12s ease-out}.nav-find-people:hover{background:#ffffff29;transform:translateY(-1px)}.nav-find-people:active{transform:translateY(1px)}.nav-find-people svg{width:18px;height:18px}.find-people-empty{padding:1.5rem .25rem;text-align:center;color:rgb(var(--text-secondary));font-size:.875rem}.find-people-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.find-people-row{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:rgba(var(--text),.04);border-radius:12px}.find-people-who{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0;background:none;border:0;padding:0;color:inherit;font:inherit;text-align:left;cursor:pointer}.find-people-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--purple));display:inline-flex;align-items:center;justify-content:center}.find-people-avatar img{width:100%;height:100%;object-fit:cover}.find-people-avatar-fallback{color:#fff;font-weight:900;font-size:1rem}.find-people-name-wrap{display:flex;flex-direction:column;min-width:0;flex:1}.find-people-name{font-weight:800;color:rgb(var(--text));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.find-people-handle{font-size:.75rem;color:rgb(var(--text-secondary))}.find-people-name-line{display:inline-flex;align-items:center;gap:.375rem}.find-people-founding{color:var(--yellow);font-size:.75rem;text-shadow:0 0 4px rgba(255,200,0,.5)}.find-people-title,.find-people-bio{display:block;font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.find-people-title{color:#b8860b;font-style:italic}.find-people-zero{padding:1.5rem .75rem 1rem;text-align:center}.find-people-zero-emoji{font-size:2.5rem;margin-bottom:.5rem}.find-people-zero-title{font-family:var(--font-display);font-size:1.25rem;color:rgb(var(--text));letter-spacing:.02em;margin-bottom:.5rem}.find-people-zero-sub{color:rgb(var(--text-secondary));font-size:.875rem;line-height:1.5;max-width:340px;margin:0 auto .75rem}.find-people-zero-privacy{color:rgb(var(--text-secondary));opacity:.7;font-size:.6875rem;letter-spacing:.02em;text-transform:uppercase}.mono{font-family:ui-monospace,Menlo,monospace;color:rgb(var(--text))}.find-people-share{margin-top:1.25rem;padding:.875rem 1rem;background:rgba(var(--text),.04);border:1px solid rgba(var(--text),.08);border-radius:12px}.find-people-share-title{font-family:var(--font-display);font-size:.875rem;color:rgb(var(--text));letter-spacing:.02em;margin-bottom:.25rem}.find-people-share-sub{color:rgb(var(--text-secondary));font-size:.8125rem;line-height:1.4;margin-bottom:.625rem}.find-people-share-row{display:flex;gap:.5rem;align-items:stretch}.find-people-share-url{flex:1;min-width:0;padding:.5rem .75rem;background:rgba(var(--text),.08);border-radius:8px;font-family:ui-monospace,Menlo,monospace;font-size:.75rem;color:rgb(var(--text));overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center}.find-people-share-btn{flex-shrink:0;white-space:nowrap}@media(max-width:640px){.nav-avatar-ring-name{display:none}}.portal-nav-profile{display:inline-flex;align-items:center;gap:.625rem;background:none;border:0;color:#fff;font:inherit;font-weight:800;padding:0;cursor:pointer}.portal-nav-profile:hover{opacity:.9}.games-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:640px){.games-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem}}@media(min-width:1024px){.games-grid{grid-template-columns:repeat(3,1fr)}}.hero-strip{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:5rem}@media(min-width:768px){.hero-strip{grid-template-columns:repeat(3,1fr);gap:2rem}}.hero-card{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-pop);transition:all .15s;display:flex;flex-direction:column;position:relative;cursor:pointer}.hero-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-float);border-color:var(--blue)}.hero-card-link{display:flex;flex-direction:column;height:100%;color:inherit}.hero-card-image-wrap{width:100%;aspect-ratio:4 / 3;background:rgb(var(--bg));display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.hero-card-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.4,0,.2,1)}.hero-card:hover .hero-card-image{transform:scale(1.04)}.hero-card-badge{position:absolute;top:.75rem;left:.75rem;font-family:var(--font-body);font-size:.625rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;padding:.375rem .75rem;border-radius:10px;background:var(--blue);border:2px solid var(--blue-dark);color:#fff;box-shadow:0 3px 0 var(--blue-deeper)}.hero-card-body{padding:1.125rem 1.25rem 1.25rem;flex:1;display:flex;flex-direction:column}.hero-card-title{font-family:var(--font-display);font-size:1.125rem;margin:0 0 .25rem;line-height:1.2;letter-spacing:.01em}.hero-card-tagline{font-size:.8125rem;line-height:1.45;color:rgb(var(--text-secondary));font-weight:600;margin:0 0 .75rem;flex:1}.hero-card-tags{display:flex;flex-wrap:wrap;gap:.375rem}.spotlight-section{margin-bottom:3rem}.spotlight-card{display:grid;grid-template-columns:1fr 1fr;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-pop);cursor:pointer;transition:all .15s;text-align:left;width:100%;font:inherit;color:inherit}.spotlight-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-float)}.spotlight-themed{border:3px solid rgba(255,255,255,.15)}.spotlight-themed:hover{border-color:#ffffff4d}.spotlight-themed .spotlight-title{text-shadow:0 2px 0 rgba(0,0,0,.2)}.spotlight-image-wrap{position:relative;overflow:hidden;aspect-ratio:1 / 1}.spotlight-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.spotlight-card:hover .spotlight-image{transform:scale(1.04)}.spotlight-badge{position:absolute;top:.75rem;left:.75rem;padding:.375rem .75rem;background:var(--yellow);border:2px solid var(--yellow-dark);border-radius:10px;font-family:var(--font-body);font-size:.625rem;font-weight:900;letter-spacing:.08em;color:rgb(var(--navy-deep));box-shadow:0 3px 0 var(--yellow-dark)}.spotlight-body{padding:2rem 2.5rem;display:flex;flex-direction:column;justify-content:center}.spotlight-title{font-family:var(--font-display);font-size:2rem;color:rgb(var(--text));margin-bottom:.5rem;letter-spacing:.02em;text-shadow:0 2px 0 rgba(0,0,0,.06)}.spotlight-tagline{font-size:1rem;color:rgb(var(--text-secondary));line-height:1.55;font-weight:600;margin-bottom:1.5rem}.spotlight-cta{display:inline-flex;align-self:flex-start;padding:1rem 2.25rem;background:var(--blue);border:3px solid var(--blue-dark);border-radius:16px;color:#fff;font-family:var(--font-display);font-size:1.125rem;box-shadow:0 6px 0 var(--blue-deeper);letter-spacing:.03em;transition:transform .16s cubic-bezier(.34,1.56,.64,1),filter .16s ease-out,box-shadow .16s ease-out}.spotlight-card:hover .spotlight-cta{transform:translateY(-2px) scale(1.04);filter:brightness(1.08) saturate(1.05)}.spotlight-cta:hover{transform:translateY(-3px) scale(1.08);filter:brightness(1.15) saturate(1.1)}.spotlight-cta:active{transform:translateY(2px) scale(1.02);filter:brightness(.95);transition-duration:80ms}@media(max-width:768px){.spotlight-card{grid-template-columns:1fr}.spotlight-body{padding:1.25rem 1.5rem}.spotlight-title{font-size:1.5rem}}.game-card-image-wrap{position:relative}.category-section{margin-bottom:3rem}.category-section:last-child{margin-bottom:0}.category-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.category-title{font-family:var(--font-display);font-size:1.5rem;margin:0;letter-spacing:.02em;text-shadow:0 2px 0 rgba(0,0,0,.06);text-transform:uppercase}.category-count{font-size:.8125rem;font-weight:800;color:rgb(var(--text-secondary));text-transform:uppercase;letter-spacing:.04em}.game-card{position:relative;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-chunky);transition:all .15s;display:flex;flex-direction:column;cursor:pointer}.spider-overlay{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:5}.spider-instance{position:absolute;top:0;width:22px;margin-left:-11px}.spider-thread{position:absolute;top:0;left:50%;width:1px;height:var(--spider-drop, 80px);background:#0006;transform-origin:top;transform:scaleY(0);animation:spider-thread var(--spider-duration, 7s) ease-in-out infinite;animation-delay:var(--spider-delay, 0s)}.spider-drop{position:absolute;top:-22px;left:50%;width:22px;height:22px;margin-left:-11px;animation:spider-descend var(--spider-duration, 7s) ease-in-out infinite;animation-delay:var(--spider-delay, 0s)}.spider-svg{width:100%;height:100%;display:block;transform-origin:50% 0%;animation:spider-sway 1.2s ease-in-out infinite}@keyframes spider-descend{0%{transform:translateY(0)}35%{transform:translateY(var(--spider-drop, 80px))}65%{transform:translateY(var(--spider-drop, 80px))}to{transform:translateY(0)}}@keyframes spider-thread{0%{transform:scaleY(0)}35%{transform:scaleY(1)}65%{transform:scaleY(1)}to{transform:scaleY(0)}}@keyframes spider-sway{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.game-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-float);border-color:var(--blue)}.game-card-link{position:relative;display:flex;flex-direction:column;height:100%;color:inherit}.game-card-image-wrap{width:100%;aspect-ratio:16 / 10;background:rgb(var(--bg));display:flex;align-items:center;justify-content:center;overflow:hidden}.game-card-image{width:100%;height:100%;object-fit:cover;display:block}.game-card[data-game-id=pixel-pop] .game-card-image{object-fit:cover;object-position:center top}.game-card--cover{position:relative;overflow:hidden;aspect-ratio:4 / 5}.game-card--cover .game-card-link{display:block;height:100%}.game-card--cover .game-card-image-wrap{position:absolute;inset:0;width:100%;height:100%;aspect-ratio:auto}.game-card--cover .game-card-image,.game-card--cover .game-card-video{width:100%;height:100%;object-fit:cover;object-position:center top}.game-card--cover .game-card-tags{position:absolute;top:10px;left:10px;z-index:3;margin:0;display:flex;gap:6px;flex-wrap:wrap}.game-card--cover .game-card-tag{background:#0f0a1e8c;color:#fff;border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-weight:700}.game-card--cover .game-card-body{position:absolute;left:0;right:0;bottom:0;padding:16px 16px 18px;color:#fff;background:linear-gradient(to top,rgba(15,10,30,.92),rgba(15,10,30,.65) 60%,transparent);transform:translateY(100%);transition:transform .32s cubic-bezier(.34,1.4,.5,1);z-index:2}.game-card--cover:hover .game-card-body{transform:translateY(0)}.game-card--cover .game-card-title{color:#fff;margin-bottom:4px}.game-card--cover .game-card-description{color:#ffffffd9;margin-bottom:0}.game-card--cover .game-card-body .game-card-tags{display:none}@media(hover:none),(pointer:coarse){.game-card--cover .game-card-body{transform:translateY(0);padding:10px 14px 12px}.game-card--cover .game-card-description{display:none}}.game-card-placeholder{color:rgb(var(--text-muted));font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.game-card-body{position:relative;padding:.75rem 1rem .875rem;display:flex;flex-direction:column;gap:.125rem}.game-card-title{font-family:var(--font-display);font-size:1rem;margin:0;line-height:1.15;letter-spacing:.01em}.game-card-description{font-size:.75rem;line-height:1.35;color:rgb(var(--text-secondary));font-weight:600;margin:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.game-card-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#00000059,#0000008c 60%,#000c);opacity:0;transition:opacity .22s ease;pointer-events:none;z-index:3}.game-card-play-overlay-visible{opacity:1}.game-card-play-btn{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2.25rem;background:var(--blue);border:3px solid var(--blue-dark);border-radius:18px;color:#fff;font-family:var(--font-display);font-size:1.375rem;letter-spacing:.03em;box-shadow:0 6px 0 var(--blue-deeper),0 14px 36px #00000073;transform:scale(.92);transition:transform .22s cubic-bezier(.34,1.56,.64,1),background .12s ease-out,border-color .12s ease-out,box-shadow .12s ease-out}.game-card-play-overlay-visible .game-card-play-btn{transform:scale(1)}.game-card-play-overlay-visible{pointer-events:auto}.game-card-play-overlay-visible .game-card-play-btn:hover{transform:scale(1.08) translateY(-2px);background:#60a5fa;border-color:var(--blue);box-shadow:0 8px 0 var(--blue-deeper),0 18px 48px #0000008c}.game-card-play-overlay-visible .game-card-play-btn:active{transform:scale(1.02) translateY(2px);box-shadow:0 2px 0 var(--blue-deeper),0 6px 16px #0006;transition-duration:80ms}.login-card{background:rgb(var(--surface));border-radius:var(--radius);padding:3rem 2.5rem;max-width:26rem;width:100%;box-shadow:var(--shadow-card);text-align:center}.login-title{font-family:var(--font-display);font-size:2.5rem;font-weight:600;margin:0 0 .75rem;letter-spacing:-.01em}.login-subtitle{color:rgb(var(--text-secondary));margin:0 0 2rem;font-size:.9375rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:14px;font-size:.875rem;font-weight:800;transition:all .1s;text-align:center;letter-spacing:.02em}.btn:hover{transform:translateY(2px)}.btn:active{transform:translateY(4px)}.btn-primary{background:var(--blue);border:3px solid var(--blue-dark);color:#fff;box-shadow:0 5px 0 var(--blue-deeper)}.btn-primary:hover{box-shadow:0 3px 0 var(--blue-deeper)}.btn-primary:active{box-shadow:0 1px 0 var(--blue-deeper)}.btn-secondary{background:rgb(var(--surface));color:rgb(var(--text));border:3px solid rgba(0,0,0,.1);box-shadow:0 4px #00000014}.btn-secondary:hover{box-shadow:0 2px #00000014}.btn-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:rgb(var(--text-secondary));margin-bottom:1.5rem;transition:opacity .2s ease}.btn-back:hover{opacity:.6}.btn-signout{font-size:.75rem;font-weight:800;color:#ffffff80;padding:.375rem .75rem;border-radius:8px;background:none;transition:all .15s;text-transform:uppercase;letter-spacing:.06em}.btn-signout:hover{color:#fff;background:#ffffff1a}.game-detail{max-width:1200px;margin:0 auto;padding:2rem}.game-detail-themed{max-width:none;padding:2rem;overflow-x:hidden}@media(max-width:720px),(max-height:500px)and (orientation:landscape){.game-detail-themed{padding:0}.game-detail-themed .game-detail-layout{padding:0;gap:0}.game-frame-wrap{border-radius:0;box-shadow:none}.game-frame-wrap{--frame-max-h: 100vh}.game-detail-themed .game-community,.game-detail-themed .leaderboard,.game-detail-themed .devlog-rail{padding-left:1rem;padding-right:1rem}}.game-detail-themed .game-detail-header,.game-detail-themed .game-detail-layout,.game-detail-themed .game-community{max-width:1200px;margin-left:auto;margin-right:auto}.game-detail-themed .game-detail-title{color:inherit;text-shadow:0 3px 0 rgba(0,0,0,.2)}.game-detail-themed .leaderboard{background:linear-gradient(160deg,color-mix(in srgb,var(--theme-primary, #1e1b4b) 38%,rgba(14,10,28,.88)),color-mix(in srgb,var(--theme-secondary, #1e1b4b) 22%,rgba(14,10,28,.92)));border-color:color-mix(in srgb,var(--theme-primary, #ffffff) 35%,rgba(255,255,255,.18));color:#fff;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.game-detail-themed .leaderboard-title,.game-detail-themed .leaderboard-name,.game-detail-themed .leaderboard-score,.game-detail-themed .leaderboard-rank{color:#fff}.game-detail-themed .leaderboard-tab{color:#ffffff8c}.game-detail-themed .leaderboard-tab-active{background:#ffffff2e;color:#fff}.game-detail-themed .leaderboard-tabs{background:#ffffff14}.game-detail-themed .leaderboard-empty,.game-detail-themed .leaderboard-detail-link{color:#ffffff8c}.game-detail-themed .leaderboard-detail-link:hover{color:#fff}.game-detail-themed .content-section{background:#fffffff2;color:rgb(var(--text))}.game-detail-themed .game-community{padding:0}.game-detail-back{color:inherit;opacity:.7;margin-bottom:1rem}.game-detail-back:hover{opacity:1}.game-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2rem}.game-detail-title{font-family:var(--font-display);font-size:2rem;font-weight:600;margin:0 0 .5rem}.game-detail-tagline{color:rgb(var(--text-secondary));margin:0;font-size:1rem}.game-detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 22rem;gap:1.5rem;align-items:start}@media(max-width:960px){.game-detail-layout{grid-template-columns:1fr}}.game-frame-wrap{--frame-max-h: calc(100vh - 180px) ;--frame-w-from-h: calc(var(--frame-max-h) * var(--aspect-w, 1) / var(--aspect-h, 1));width:min(100%,var(--frame-w-from-h));aspect-ratio:var(--aspect-w, 1) / var(--aspect-h, 1);background:rgb(var(--surface));border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);margin-inline:auto}.game-detail-themed .game-detail-header{display:none}.game-detail-themed .game-detail-back{position:fixed;top:12px;left:12px;margin:0;padding:6px 12px;background:#0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:999px;font-size:.85rem;z-index:20}.game-detail-themed .game-detail-layout{padding-top:0}.game-frame-wrap{--frame-max-h: calc(100vh - 48px) }@media(orientation:landscape)and (max-height:500px){.game-frame-wrap{--frame-max-h: calc(100vh - 16px) }}.game-frame{width:100%;height:100%;border:0;display:block}.leaderboard{background:rgb(var(--surface));border-radius:var(--radius);padding:1.25rem 1.25rem 1rem;box-shadow:var(--shadow-card)}.leaderboard-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.625rem;gap:.5rem}.leaderboard-title{font-family:var(--font-display);font-size:1rem;font-weight:600;margin:0;color:rgb(var(--text));letter-spacing:.02em;text-transform:uppercase}.leaderboard-detail-link{background:none;border:0;color:rgb(var(--text-secondary));font-size:.75rem;cursor:pointer;padding:.125rem .25rem;transition:color .15s ease}.leaderboard-detail-link:hover{color:rgb(var(--text))}.leaderboard-tabs{display:flex;gap:.25rem;padding:.125rem;background:rgba(var(--text),.04);border-radius:8px;margin-bottom:.75rem}.leaderboard-tab{flex:1;padding:.375rem .5rem;background:none;border:0;border-radius:6px;font-size:.75rem;font-weight:600;color:rgb(var(--text-secondary));cursor:pointer;transition:all .15s ease;text-transform:uppercase;letter-spacing:.03em}.leaderboard-tab:hover:not(.leaderboard-tab-active){color:rgb(var(--text))}.leaderboard-tab-active{background:rgb(var(--surface));color:rgb(var(--text));box-shadow:0 1px 2px #00000014}.leaderboard-empty{color:rgb(var(--text-secondary));font-size:.875rem;margin:.5rem 0}.leaderboard-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.leaderboard-row{display:grid;grid-template-columns:1.5rem 1.75rem 1fr auto;align-items:center;gap:.625rem;padding:.375rem 0;font-size:.875rem}.leaderboard-rank{font-variant-numeric:tabular-nums;color:rgb(var(--text-secondary));font-weight:500;text-align:right}.leaderboard-avatar{width:1.75rem;height:1.75rem;border-radius:50%;object-fit:cover;background:rgba(var(--text),.08)}.leaderboard-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:rgb(var(--text-secondary))}.leaderboard-name{color:rgb(var(--text));overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.leaderboard-name-link{background:none;border:0;font:inherit;padding:0;cursor:pointer;text-decoration:none;transition:color .15s ease}.leaderboard-name-link:hover{color:var(--blue);text-decoration:underline}.leaderboard-score{font-variant-numeric:tabular-nums;font-weight:600;color:rgb(var(--text))}.leaderboard-row-me{background:#3b82f614;border-radius:6px;padding-left:.5rem;padding-right:.5rem;margin-left:-.5rem;margin-right:-.5rem}.leaderboard-row-me .leaderboard-rank,.leaderboard-row-me .leaderboard-name,.leaderboard-row-me .leaderboard-score{color:var(--blue);font-weight:600}.leaderboard-my-rank{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed rgba(var(--text),.12)}.leaderboard-my-rank-label{font-size:.6875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgb(var(--text-secondary));margin-bottom:.375rem}.leaderboard-list-pinned{margin:0}.leaderboard-detail-page{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.leaderboard-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin:1rem 0 2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(var(--text),.08)}.leaderboard-detail-eyebrow{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgb(var(--text-secondary));margin-bottom:.25rem}.leaderboard-detail-body{display:flex;flex-direction:column;gap:1.5rem}.leaderboard-detail-body .leaderboard{padding:1.5rem}.recent-runs-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.recent-run-inner{display:grid;grid-template-columns:1fr auto auto;gap:.875rem;align-items:center;width:100%;background:rgb(var(--surface));border:1px solid rgba(var(--text),.06);border-radius:8px;padding:.625rem .875rem;font:inherit;color:inherit;text-align:left;cursor:pointer;transition:border-color .15s ease,background .15s ease}.recent-run-inner:hover{border-color:rgba(var(--text),.15);background:rgba(var(--text),.02)}.recent-run-game{font-weight:600;color:rgb(var(--text));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-run-score{font-variant-numeric:tabular-nums;color:rgb(var(--text));font-size:.9375rem;font-weight:600}.recent-run-time{font-variant-numeric:tabular-nums;font-size:.75rem;color:rgb(var(--text-secondary))}.btn-following{background:rgba(var(--text),.08);color:rgb(var(--text))}.btn-following:hover{background:#dc26261a;color:#dc2626}.follow-stats{display:flex;gap:.5rem;font-size:.8125rem;color:rgb(var(--text-secondary));margin-top:.625rem;align-items:center}.follow-stat strong{color:rgb(var(--text));font-variant-numeric:tabular-nums}.follow-stats-sep{opacity:.4}.presence-now{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:999px;color:#15803d;font-size:.8125rem;font-weight:500;cursor:pointer;margin-top:.75rem;transition:background .15s ease}.presence-now:hover{background:#22c55e26}.presence-now-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e40;animation:presence-pulse 2s ease-in-out infinite}@keyframes presence-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.activity-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.activity-row{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:start}.activity-avatar-wrap{background:none;border:0;padding:0;cursor:pointer}.activity-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:rgba(var(--text),.08);display:block}.activity-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:rgb(var(--text-secondary))}.activity-body{min-width:0;padding-top:.25rem}.activity-text{font-size:.9375rem;color:rgb(var(--text));line-height:1.4}.activity-actor{background:none;border:0;padding:0;font:inherit;color:rgb(var(--text));font-weight:600;cursor:pointer}.activity-actor:hover{text-decoration:underline}.activity-link{background:none;border:0;padding:0;font:inherit;color:var(--blue);cursor:pointer;font-weight:500}.activity-link:hover{text-decoration:underline}.activity-highlight{font-weight:600;color:rgb(var(--text))}.activity-time{font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.125rem;font-variant-numeric:tabular-nums}.following-playing-row{margin:0 0 3rem}.following-playing-head{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.following-playing-title{font-family:var(--font-display);font-size:1.5rem;margin:0;color:rgb(var(--text));letter-spacing:.02em;text-shadow:0 2px 0 rgba(0,0,0,.06)}.live-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;background:var(--green);border:2px solid var(--green-dark);border-radius:999px;font-size:.625rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#fff;box-shadow:0 2px 0 var(--green-dark)}.live-dot{width:6px;height:6px;background:#fff;border-radius:50%;animation:blink-dot 1s step-end infinite}@keyframes blink-dot{0%,to{opacity:1}50%{opacity:0}}.crews-link-btn{margin-left:auto;display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:999px;font-family:var(--font-body);font-size:.6875rem;font-weight:900;letter-spacing:.06em;color:rgb(var(--text));cursor:pointer;box-shadow:0 3px #00000014;transition:all .15s}.crews-link-btn:hover{transform:translateY(1px);border-color:var(--purple);box-shadow:0 2px #00000014}.following-playing-empty{color:rgb(var(--text-secondary));font-weight:600;font-size:.875rem;margin:0}.following-playing-cards{display:flex;gap:.75rem;flex-wrap:wrap}.following-playing-card{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem .625rem .625rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:999px;text-align:left;box-shadow:var(--shadow-chunky);transition:all .15s;font:inherit;color:inherit}.following-playing-card.is-clickable{cursor:pointer}.following-playing-card.is-clickable:hover{transform:translateY(-2px);border-color:var(--green)}.following-playing-avatar-wrap{position:relative;flex-shrink:0}.following-playing-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,var(--blue),var(--purple));border:3px solid rgb(var(--surface));box-shadow:0 2px #0000001a}.following-playing-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:800;color:#fff}.following-playing-online-dot{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;background:var(--green);border:3px solid rgb(var(--surface));border-radius:50%}.following-playing-body{min-width:0}.following-playing-name{font-weight:800;color:rgb(var(--text));font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.following-playing-user-title{font-size:.625rem;color:#b8860b;font-style:italic;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;margin-top:.0625rem}.following-playing-game{font-size:.6875rem;color:rgb(var(--text-secondary));font-weight:700}.following-playing-game-link{background:none;border:0;padding:0;font:inherit;color:var(--blue);cursor:pointer}.following-playing-game-link:hover{text-decoration:underline}.weekly-challenge{background:linear-gradient(135deg,var(--blue),var(--blue-dark),var(--blue-deeper));border:3px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:2.5rem 3rem;margin:2rem 0 2.5rem;box-shadow:var(--shadow-chunky-blue),0 16px 48px #3b82f633;position:relative;overflow:hidden;color:#fff}.weekly-challenge:before{content:"";position:absolute;top:-40px;right:-20px;width:200px;height:200px;background:#ffffff0f;border-radius:50%;pointer-events:none}.weekly-challenge-eyebrow{font-size:.6875rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);text-shadow:0 1px 3px rgba(0,0,0,.2);margin-bottom:.75rem;position:relative}.weekly-challenge-title{font-family:var(--font-display);font-size:3.5rem;margin:0 0 .75rem;color:#fff;line-height:1;text-shadow:0 4px 0 rgba(0,0,0,.2);letter-spacing:.02em;text-transform:uppercase;position:relative}.weekly-challenge-description{color:#fffc;margin:0 0 1.5rem;line-height:1.55;max-width:48ch;font-weight:600;position:relative}.weekly-challenge-actions{display:flex;gap:.875rem;align-items:center;flex-wrap:wrap}.weekly-challenge-game-label{color:#fff9;font-size:.875rem;font-weight:600}.weekly-challenge-game-name{color:#fff;font-weight:800}.weekly-challenge .btn-primary{background:var(--yellow);border:3px solid var(--yellow-dark);color:rgb(var(--navy-deep));font-family:var(--font-display);font-size:1rem;box-shadow:0 5px 0 var(--yellow-dark);letter-spacing:.02em}.weekly-challenge .btn-primary:hover{box-shadow:0 3px 0 var(--yellow-dark)}.weekly-challenge .btn-primary:active{box-shadow:0 1px 0 var(--yellow-dark)}.weekly-challenge-completed{background:linear-gradient(135deg,var(--green),var(--green-dark),#0d7a3e);box-shadow:0 6px 0 var(--green-dark),0 16px 48px #22c55e33;border-color:#fff3}.weekly-challenge-done{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.weekly-challenge-done-badge{display:inline-flex;padding:.75rem 1.75rem;background:#fff3;border:3px solid rgba(255,255,255,.3);border-radius:14px;color:#fff;font-family:var(--font-display);font-size:1rem;letter-spacing:.04em;box-shadow:0 4px #00000026}.weekly-challenge-streak{font-size:1rem;font-weight:800;color:#ffffffe6}.weekly-challenge{transition:background .8s ease,box-shadow .8s ease,border-color .6s ease}.weekly-challenge-completed .weekly-challenge-done-badge{animation:badge-pop .6s cubic-bezier(.34,1.56,.64,1) both}@keyframes badge-pop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.weekly-challenge-completed .weekly-challenge-eyebrow{animation:eyebrow-glow 1s ease both}@keyframes eyebrow-glow{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.challenge-toast{position:fixed;top:5rem;right:1.5rem;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--green);border:3px solid var(--green-dark);border-radius:16px;color:#fff;box-shadow:0 6px 0 var(--green-dark),0 16px 48px #22c55e4d;z-index:500;max-width:380px}.challenge-toast-enter{animation:toast-in .5s cubic-bezier(.34,1.56,.64,1) both}.challenge-toast-exit{animation:toast-out .4s ease-in both}@keyframes toast-in{0%{transform:translate(120%) scale(.8);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes toast-out{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(120%) scale(.8);opacity:0}}.challenge-toast-icon{width:40px;height:40px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.challenge-toast-check{width:22px;height:22px}.challenge-toast-check-path{stroke-dasharray:30;stroke-dashoffset:30;animation:check-draw .5s ease .3s forwards}@keyframes check-draw{to{stroke-dashoffset:0}}.challenge-toast-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.02em;text-shadow:0 2px 0 rgba(0,0,0,.15)}.challenge-toast-subtitle{font-size:.8125rem;font-weight:700;opacity:.85;margin-top:.125rem}.achievement-toast{position:fixed;top:5rem;right:1.5rem;display:flex;align-items:center;gap:.875rem;padding:1rem 1.5rem;background:var(--yellow);border:3px solid var(--yellow-dark);border-radius:16px;color:rgb(var(--navy-deep));box-shadow:0 6px 0 var(--yellow-dark),0 16px 48px #fbbf244d;z-index:500;max-width:340px}.achievement-toast-enter{animation:toast-in .5s cubic-bezier(.34,1.56,.64,1) both}.achievement-toast-exit{animation:toast-out .4s ease-in both}.achievement-toast-icon{font-size:1.75rem;animation:trophy-bounce .6s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes trophy-bounce{0%{transform:scale(0) rotate(-15deg)}60%{transform:scale(1.2) rotate(5deg)}to{transform:scale(1) rotate(0)}}.achievement-toast-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.02em}.achievement-toast-xp{font-size:.875rem;font-weight:900;opacity:.7;margin-top:.0625rem}.xp-toast{position:fixed;top:5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:var(--blue-light);border:3px solid var(--blue);border-radius:14px;color:rgb(var(--navy-deep));box-shadow:0 6px 0 var(--blue-dark),0 12px 32px #3b82f640;z-index:500;max-width:280px}.xp-toast-icon{font-size:1.5rem}.xp-toast-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.02em}.toast-enter{animation:toast-in .4s cubic-bezier(.34,1.56,.64,1) both}.toast-exit{animation:toast-out .3s ease-in both}.levelup-toast{position:fixed;top:5rem;right:1.5rem;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--blue);border:3px solid var(--blue-dark);border-radius:16px;color:#fff;box-shadow:0 6px 0 var(--blue-deeper),0 16px 48px #3b82f64d;z-index:500;max-width:320px}.levelup-toast-enter{animation:toast-in .5s cubic-bezier(.34,1.56,.64,1) both}.levelup-toast-exit{animation:toast-out .4s ease-in both}.levelup-toast-level{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#fff3;border:3px solid rgba(255,255,255,.3);font-family:var(--font-display);font-size:1rem;text-shadow:0 2px 0 rgba(0,0,0,.2);flex-shrink:0;animation:level-pop .6s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes level-pop{0%{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0)}}.levelup-toast-title{font-family:var(--font-display);font-size:1.125rem;letter-spacing:.02em;text-shadow:0 2px 0 rgba(0,0,0,.15)}.levelup-toast-subtitle{font-size:.8125rem;font-weight:700;opacity:.85;margin-top:.125rem}.admin-page{max-width:900px;margin:0 auto;padding:2rem 1.5rem 4rem}.admin-header{margin:1rem 0 2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(var(--text),.08)}.admin-slot-editor{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.admin-slot-editor .profile-section-title{margin:0 0 .5rem}.admin-form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.875rem}@media(max-width:720px){.admin-form-row{grid-template-columns:1fr}}.admin-form-row>.field{margin:0}.sim-status{display:flex;gap:2rem;font-variant-numeric:tabular-nums}.sim-stat-number{font-family:var(--font-display);font-size:1.75rem;color:rgb(var(--text));line-height:1}.sim-stat-label{font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.25rem;text-transform:uppercase;letter-spacing:.05em}.sim-count-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:rgba(var(--text),.08);border-radius:999px;font-size:.75rem;font-weight:700;color:rgb(var(--text-secondary));vertical-align:middle}.sim-profile-list{list-style:none;margin:.75rem 0 0;padding:0;display:flex;flex-direction:column;gap:.375rem;max-height:420px;overflow-y:auto}.sim-profile-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:rgba(var(--text),.03);border-radius:10px}.sim-profile-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:rgba(var(--text),.1);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:800;color:rgb(var(--text))}.sim-profile-avatar img{width:100%;height:100%;object-fit:cover}.sim-profile-name-wrap{display:flex;flex-direction:column;min-width:0;flex:1}.sim-profile-name{font-weight:800;color:rgb(var(--text))}.sim-profile-handle{font-size:.75rem;color:rgb(var(--text-secondary))}.sim-profile-bio{font-size:.75rem;color:rgb(var(--text-secondary));font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.sim-result{margin-top:1rem;padding:.75rem 1rem;background:rgba(var(--text),.05);border-radius:8px;font-family:var(--font-mono, ui-monospace, monospace);font-size:.8125rem;color:rgb(var(--text))}.btn-small{padding:.375rem .75rem;font-size:.75rem}.admin-payload{font-family:var(--font-mono, ui-monospace, monospace);font-size:.8125rem;min-height:12rem}.admin-form-footer{display:flex;justify-content:flex-end}.field-help{margin-top:.5rem;font-size:.75rem;color:rgb(var(--text-secondary))}.field-help summary{cursor:pointer}.field-help-code{display:block;background:rgba(var(--text),.04);padding:.5rem .625rem;border-radius:6px;margin-top:.375rem;font-family:var(--font-mono, ui-monospace, monospace);word-break:break-all}.field-success{background:#22c55e1a;color:#15803d;padding:.625rem .75rem;border-radius:8px;font-size:.875rem}.admin-slot-list{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:.625rem}.admin-slot-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:10px;opacity:.65}.admin-slot-active{opacity:1;border-color:#3b82f659}.admin-slot-title{font-weight:600;color:rgb(var(--text))}.admin-slot-meta{font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.25rem;font-variant-numeric:tabular-nums}.admin-editorial-domain-tabs{display:flex;gap:.5rem;margin-top:1.25rem;border-bottom:2px solid rgb(var(--border))}.admin-editorial-domain-tab{appearance:none;background:transparent;border:none;padding:.6rem 1.1rem;font:inherit;font-family:var(--font-display);font-size:1rem;color:rgb(var(--text-muted));cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .12s,border-color .12s}.admin-editorial-domain-tab:hover{color:rgb(var(--text))}.admin-editorial-domain-tab.is-active{color:rgb(var(--text));border-bottom-color:var(--blue)}.admin-work-picker{display:flex;flex-direction:column;gap:.4rem}.admin-work-picker-current{display:block;padding:.5rem .7rem;background:rgb(var(--bg-muted));border:2px solid rgb(var(--border));border-radius:8px}.admin-work-row{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.admin-work-row-title{font-weight:700}.admin-work-row-author{color:rgb(var(--text-secondary));font-size:.85rem}.admin-work-row-fallback{font-family:var(--font-mono);font-size:.85rem;color:rgb(var(--text-muted))}.admin-work-row-cover{width:32px;height:48px;object-fit:cover;border:1.5px solid rgb(var(--border));border-radius:4px;background:rgb(var(--surface-2));flex:0 0 auto;display:block}.admin-work-row-cover-empty{width:32px;height:48px;border:1.5px dashed rgb(var(--border));border-radius:4px;background:rgb(var(--surface-2));flex:0 0 auto;display:grid;place-items:center;font-size:.65rem;color:rgb(var(--text-muted))}.admin-work-cover-preview{width:100%;max-width:200px;aspect-ratio:2 / 3;object-fit:cover;border:2px solid rgb(var(--border));border-radius:8px;background:rgb(var(--surface-2));display:block}.admin-work-results{list-style:none;margin:0;padding:0;border:2px solid rgb(var(--border));border-radius:8px;max-height:320px;overflow-y:auto;background:#fff}.admin-work-results li+li{border-top:1px solid rgb(var(--border))}.admin-work-result{appearance:none;background:transparent;border:none;padding:.5rem .7rem;width:100%;text-align:left;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font:inherit;cursor:pointer}.admin-work-result:hover{background:rgb(var(--bg-muted))}.admin-work-result.is-selected{background:rgb(var(--bg-muted));border-left:3px solid var(--blue)}.admin-work-result-title{font-weight:700;color:rgb(var(--text))}.admin-work-result-author{color:rgb(var(--text-secondary));font-size:.85rem}.admin-work-result-meta{margin-left:auto;font-family:var(--font-mono);font-size:.75rem;color:rgb(var(--text-muted))}.admin-editorial-layout{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;margin-top:1.5rem}@media(max-width:900px){.admin-editorial-layout{grid-template-columns:1fr}}.admin-editorial-list-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem}.admin-new-btn{padding:.5rem .875rem;font-size:.8125rem}.admin-editorial-editor{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:14px;padding:1.25rem 1.5rem}.admin-editorial-list .admin-slot-item{display:block;cursor:pointer;position:relative;padding:.75rem .875rem 2.5rem}.admin-slot-item-head{display:flex;gap:.5rem;align-items:center;margin-bottom:.375rem}.admin-slot-status{font-size:.625rem;font-weight:800;letter-spacing:.06em;padding:.125rem .5rem;border-radius:4px}.admin-slot-status-live{background:var(--green);color:#fff;animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.7}}.admin-slot-status-upcoming{background:var(--blue-light);color:var(--blue-deeper)}.admin-slot-status-expired{background:#00000014;color:rgb(var(--text-muted))}.admin-slot-type-badge{font-size:.625rem;font-weight:700;color:rgb(var(--text-secondary));background:#0000000d;padding:.125rem .4375rem;border-radius:4px}.admin-editorial-list .admin-slot-live{opacity:1;border-color:#22c55e4d}.admin-editorial-list .admin-slot-upcoming{opacity:1}.admin-editorial-list .admin-slot-expired{opacity:.55}.admin-slot-active-edit{border-color:var(--blue)!important;box-shadow:0 0 0 3px #3b82f626}.admin-slot-delete-btn{position:absolute;bottom:.5rem;right:.5rem;font-size:.6875rem;padding:.25rem .625rem}.admin-slot-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem;margin-top:.5rem}@media(max-width:600px){.admin-slot-type-grid{grid-template-columns:1fr}}.admin-slot-type-card{text-align:left;padding:.625rem .875rem;background:rgb(var(--surface));border:2px solid rgba(0,0,0,.08);border-radius:10px;cursor:pointer;transition:all .12s}.admin-slot-type-card:hover:not(:disabled):not(.is-selected){border-color:#3b82f666}.admin-slot-type-card.is-selected{border-color:var(--blue);background:var(--blue-pale)}.admin-slot-type-card:disabled{cursor:not-allowed;opacity:.7}.admin-slot-type-label{font-weight:700;font-size:.875rem;color:rgb(var(--text))}.admin-slot-type-desc{font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.1875rem;line-height:1.4}.admin-game-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.625rem;margin-top:.5rem}.admin-game-picker-card{display:flex;flex-direction:column;gap:.375rem;padding:.5rem;background:rgb(var(--surface));border:2px solid rgba(0,0,0,.08);border-radius:10px;cursor:pointer;text-align:center;transition:all .12s}.admin-game-picker-card:hover:not(.is-selected){border-color:#3b82f666;transform:translateY(-1px)}.admin-game-picker-card.is-selected{border-color:var(--blue);background:var(--blue-pale);box-shadow:0 0 0 2px #3b82f633}.admin-game-picker-thumb{width:100%;aspect-ratio:9 / 16;object-fit:cover;border-radius:6px;background:#0000000f}.admin-game-picker-title{font-size:.75rem;font-weight:700;color:rgb(var(--text));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-multi-picker-selected{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.375rem}.admin-multi-picker-row{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;background:var(--blue-pale);border:2px solid var(--blue);border-radius:8px}.admin-multi-picker-num{font-weight:800;font-size:.875rem;color:var(--blue-deeper);min-width:1.25rem}.admin-multi-picker-thumb{width:32px;height:32px;object-fit:cover;border-radius:4px;background:#0000000f;flex-shrink:0}.admin-multi-picker-title{flex:1;font-size:.875rem;font-weight:700;color:rgb(var(--text))}.admin-multi-picker-controls{display:flex;gap:.25rem}.btn-tiny{padding:.25rem .5rem;font-size:.75rem;border-radius:5px;background:#fff;border:2px solid rgba(0,0,0,.1);cursor:pointer;font-weight:700}.btn-tiny:hover:not(:disabled){border-color:#0003}.btn-tiny:disabled{opacity:.4;cursor:not-allowed}.btn-tiny-danger{color:var(--red);border-color:#ef44444d}.btn-tiny-danger:hover{background:var(--red);color:#fff;border-color:var(--red)}.game-community{max-width:960px;margin:2rem auto 0;display:flex;flex-direction:column;gap:2rem}.content-section{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);padding:1.5rem}.content-section-title{font-family:var(--font-display);font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem;color:rgb(var(--text))}.content-composer{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1.25rem}.content-composer-footer{display:flex;justify-content:space-between;align-items:center;gap:.875rem}.content-char-count{font-size:.75rem;color:rgb(var(--text-secondary));font-variant-numeric:tabular-nums}.content-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.content-row{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:.375rem .75rem;padding:.875rem 1rem;background:rgba(var(--text),.02);border-radius:10px;border:1px solid transparent}.content-row-dev{background:#f59e0b0f;border-color:#3b82f64d}.content-actor-chip{display:inline-flex;align-items:center;gap:.5rem;background:none;border:0;padding:0;cursor:pointer;grid-column:1 / 2;grid-row:1 / 2}.content-actor-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;background:rgba(var(--text),.08)}.content-actor-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:600;color:rgb(var(--text-secondary))}.content-actor-name{font-weight:600;font-size:.875rem;color:rgb(var(--text))}.content-actor-chip:hover .content-actor-name{text-decoration:underline}.content-actor-badge{display:inline-block;padding:.0625rem .375rem;background:#3b82f626;color:var(--blue);border-radius:999px;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.content-body{grid-column:1 / 3;grid-row:2 / 3;color:rgb(var(--text));line-height:1.5;font-size:.9375rem;white-space:pre-wrap;word-wrap:break-word}.content-meta{grid-column:2 / 3;grid-row:1 / 2;font-size:.75rem;color:rgb(var(--text-secondary));font-variant-numeric:tabular-nums;justify-self:end}.review-summary{display:flex;align-items:center;gap:.625rem;margin-bottom:1rem;padding:.75rem 1rem;background:rgba(var(--text),.03);border-radius:8px}.review-summary-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:999px;font-size:.875rem;font-weight:600;font-variant-numeric:tabular-nums}.review-summary-up{background:#22c55e1f;color:#15803d}.review-summary-down{background:#ef44441a;color:#b91c1c}.review-summary-percent{color:rgb(var(--text-secondary));font-size:.8125rem}.review-thumbs{display:flex;gap:.5rem}.review-thumbs-btn{flex:1;padding:.5rem .75rem;background:rgb(var(--bg));border:1px solid rgba(var(--text),.15);border-radius:8px;font:inherit;font-size:.875rem;font-weight:500;color:rgb(var(--text));cursor:pointer;transition:all .15s ease}.review-thumbs-btn:hover{border-color:rgba(var(--text),.3)}.review-thumbs-btn-active-up{background:#22c55e1f;border-color:#22c55e80;color:#15803d}.review-thumbs-btn-active-down{background:#ef44441a;border-color:#ef444473;color:#b91c1c}.review-inline-thumb{margin-right:.25rem}.devlog-compose-trigger{margin-bottom:1rem}.devlog-composer{background:#f59e0b0a;border:1px solid rgba(245,158,11,.25);border-radius:10px;padding:1rem}.devlog-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.devlog-card{background:rgba(var(--text),.02);border:3px solid rgba(0,0,0,.06);border-radius:10px;padding:1.25rem}.devlog-head{margin-bottom:.875rem}.devlog-title{font-family:var(--font-display);font-size:1.125rem;font-weight:700;margin:0 0 .5rem;color:rgb(var(--text))}.devlog-meta-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.devlog-body{color:rgb(var(--text));line-height:1.6;white-space:pre-wrap;word-wrap:break-word;font-size:.9375rem}.devlog-actions{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:.875rem;border-top:1px solid rgba(var(--text),.08)}.admin-metrics-page{max-width:1200px}.metrics-section{margin-bottom:2.5rem}.metrics-section-title{font-family:var(--font-display);font-size:.9375rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:rgb(var(--text));margin:0 0 1rem}.metrics-section-count{color:rgb(var(--text-secondary));font-weight:400;text-transform:none;letter-spacing:0}.metrics-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.metrics-card{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:12px;padding:1rem 1.125rem}.metrics-card-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:rgb(var(--text-secondary))}.metrics-card-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:rgb(var(--text));font-variant-numeric:tabular-nums;line-height:1.1;margin-top:.375rem}.metrics-card-sub{font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.375rem;font-variant-numeric:tabular-nums}.metrics-playing-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.metrics-playing-row{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center;padding:.625rem .875rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:10px}.metrics-playing-game{color:rgb(var(--text-secondary));font-size:.875rem}.metrics-playing-time{color:rgb(var(--text-secondary));font-size:.75rem;font-variant-numeric:tabular-nums}.metrics-chart{display:grid;grid-template-columns:repeat(14,1fr);gap:.375rem;align-items:end;height:180px;padding:.5rem 0 0}.metrics-chart-col{display:flex;flex-direction:column;align-items:center;gap:.25rem;height:100%}.metrics-chart-bar{width:100%;min-height:2px;border-radius:4px 4px 0 0;overflow:hidden;display:flex;flex-direction:column;background:rgba(var(--text),.05);align-self:stretch;flex:1 1 auto;justify-content:flex-end}.metrics-chart-col:has(.metrics-chart-bar[style*="height: 0%"]) .metrics-chart-bar{background:rgba(var(--text),.03)}.metrics-chart-seg{width:100%}.metrics-chart-seg-score{background:#22c55e}.metrics-chart-seg-achievement{background:#f59e0b}.metrics-chart-seg-comment{background:#3b82f6}.metrics-chart-seg-review{background:#8b5cf6}.metrics-chart-seg-devlog{background:#ec4899}.metrics-chart-seg-follow{background:#0ea5e9}.metrics-chart-seg-other{background:#94a3b8}.metrics-chart-label{font-size:.625rem;color:rgb(var(--text-secondary));font-variant-numeric:tabular-nums}.metrics-chart-total{font-size:.6875rem;font-weight:600;color:rgb(var(--text));font-variant-numeric:tabular-nums;min-height:1em}.metrics-chart-legend{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem;font-size:.75rem;color:rgb(var(--text-secondary))}.metrics-chart-legend-item{display:inline-flex;align-items:center;gap:.375rem}.metrics-chart-dot{display:inline-block;width:10px;height:10px;border-radius:2px}.metrics-table-wrap{overflow-x:auto;border:3px solid rgba(0,0,0,.06);border-radius:10px;background:rgb(var(--surface))}.metrics-table{width:100%;border-collapse:collapse;font-size:.875rem;font-variant-numeric:tabular-nums}.metrics-table th{text-align:left;font-weight:600;text-transform:uppercase;font-size:.6875rem;letter-spacing:.05em;color:rgb(var(--text-secondary));padding:.75rem 1rem;border-bottom:1px solid rgba(var(--text),.08)}.metrics-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(var(--text),.04);color:rgb(var(--text))}.metrics-table tr:last-child td{border-bottom:0}.metrics-table-game-link{background:none;border:0;padding:0;font:inherit;color:rgb(var(--text));font-weight:600;cursor:pointer}.metrics-table-game-link:hover{color:var(--blue);text-decoration:underline}.crew-page{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}.crew-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin:1rem 0 1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(var(--text),.08)}.crew-header-body{min-width:0}.crew-header-meta{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;color:rgb(var(--text-secondary));font-size:.875rem;flex-wrap:wrap}.crew-header-meta-sep{opacity:.4}.crew-header-actions{display:flex;gap:.5rem;flex-shrink:0}.crew-invite{display:flex;align-items:center;gap:.625rem;margin-bottom:2rem;padding:.75rem 1rem;background:#f59e0b0f;border:1px solid rgba(245,158,11,.25);border-radius:10px}.crew-invite-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blue)}.crew-invite-link{flex:1;font-family:var(--font-mono, ui-monospace, monospace);font-size:.8125rem;color:rgb(var(--text));background:rgba(var(--text),.04);padding:.375rem .625rem;border-radius:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.crew-members-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.crew-leaderboard-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.crew-leaderboard-row{display:grid;grid-template-columns:1fr auto auto;gap:.875rem;align-items:center;padding:.75rem 1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:10px}.crew-leaderboard-game{background:none;border:0;padding:0;font:inherit;font-weight:600;color:rgb(var(--text));cursor:pointer;text-align:left;font-size:.9375rem}.crew-leaderboard-game:hover{color:var(--blue)}.crew-leaderboard-score{font-variant-numeric:tabular-nums;font-weight:700;color:rgb(var(--text));font-size:.9375rem}.crew-leaderboard-holder{justify-self:end}.crew-index-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.crew-index-card{width:100%;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:12px;padding:1rem 1.25rem;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color .15s ease}.crew-index-card:hover{border-color:rgba(var(--text),.2)}.crew-index-name{font-family:var(--font-display);font-weight:700;font-size:1.0625rem;color:rgb(var(--text));margin-bottom:.25rem}.crew-index-meta{font-size:.75rem;color:rgb(var(--text-secondary))}.crew-badges{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.625rem}.crew-badge-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.25);border-radius:999px;color:#6d28d9;font-size:.75rem;font-weight:500;cursor:pointer;transition:background .15s ease;font-family:inherit}.crew-badge-pill:hover{background:#8b5cf626}.portal-nav-links{display:flex;gap:.5rem;flex:1;justify-content:center}.portal-nav-link{background:none;border:0;padding:.5rem 1rem;border-radius:10px;color:#ffffff80;font-family:var(--font-body);font-size:.8125rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.portal-nav-link:hover{color:#fff;background:#ffffff1a}.site-footer{border-top:4px solid rgb(var(--navy-deep));margin-top:2rem;padding:2.5rem 1.5rem 3rem;background:rgb(var(--navy));color:#fff9}.site-footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:start}@media(max-width:720px){.site-footer-inner{grid-template-columns:1fr;gap:2rem}}.site-footer-brand-name{font-family:var(--font-display);font-size:1.375rem;color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.3)}.site-footer-brand-meta{margin-top:.375rem;font-size:.8125rem;color:#fff6;font-weight:700}.site-footer-brand-link{color:inherit;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.25);transition:color .15s,border-color .15s}.site-footer-brand-link:hover{color:#fff;border-bottom-color:#fff9}.site-footer-brand-beta{display:inline-block;margin-top:.625rem;padding:.25rem .75rem;background:var(--blue);border:2px solid var(--blue-dark);border-radius:10px;font-size:.625rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#fff;box-shadow:0 2px 0 var(--blue-deeper)}.site-footer-nav{display:grid;grid-template-columns:repeat(2,auto);gap:2rem}.site-footer-col{display:flex;flex-direction:column;gap:.375rem}.site-footer-col-title{font-size:.625rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:#ffffff4d;margin-bottom:.75rem}.site-footer-link{background:none;border:0;padding:.25rem 0;text-align:left;font:inherit;font-size:.875rem;font-weight:700;color:#fff9;cursor:pointer;transition:color .2s}.site-footer-link:hover{color:#fff}.legal-page{max-width:760px;margin:0 auto;padding:2rem 1.5rem 4rem}.legal-header{margin:1rem 0 2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(var(--text),.08)}.legal-title{font-family:var(--font-display);font-size:2.25rem;font-weight:700;margin:0;color:rgb(var(--text));line-height:1.1}.legal-updated{margin-top:.5rem;color:rgb(var(--text-secondary));font-size:.8125rem;font-variant-numeric:tabular-nums}.legal-body{color:rgb(var(--text));line-height:1.7;font-size:.9375rem}.legal-body h2{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:2rem 0 .75rem;color:rgb(var(--text))}.legal-body h3{font-family:var(--font-display);font-size:1rem;font-weight:600;margin:1.5rem 0 .5rem;color:rgb(var(--text))}.legal-body p{margin:0 0 1rem}.legal-body ul{padding-left:1.25rem;margin:0 0 1rem}.legal-body li{margin-bottom:.375rem}.legal-body code{background:rgba(var(--text),.06);padding:.125rem .375rem;border-radius:4px;font-size:.8125rem;font-family:var(--font-mono, ui-monospace, monospace)}.legal-body strong{color:rgb(var(--text));font-weight:600}.legal-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.875rem}.legal-table th,.legal-table td{text-align:left;padding:.625rem .75rem;border-bottom:1px solid rgba(var(--text),.08);vertical-align:top}.legal-table th{font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:rgb(var(--text-secondary))}.cookie-banner{position:fixed;bottom:1rem;left:1rem;right:1rem;max-width:560px;margin:0 auto;background:rgb(var(--surface));border:1px solid rgba(var(--text),.15);border-radius:14px;box-shadow:0 24px 80px #0006;z-index:300}.cookie-banner-body{padding:1.25rem 1.375rem}.cookie-banner-title{font-family:var(--font-display);font-size:1rem;font-weight:700;margin:0 0 .5rem;color:rgb(var(--text))}.cookie-banner-text{color:rgb(var(--text));font-size:.875rem;line-height:1.5;margin:0 0 1rem;opacity:.85}.cookie-banner-link{color:var(--blue);text-decoration:underline}.cookie-banner-categories{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem}.cookie-category{display:grid;grid-template-columns:auto 1fr;gap:.75rem;padding:.625rem .75rem;background:rgba(var(--text),.03);border:3px solid rgba(0,0,0,.06);border-radius:8px;cursor:pointer}.cookie-category-locked{opacity:.7;cursor:default}.cookie-category input[type=checkbox]{margin-top:.1875rem}.cookie-category-label{font-weight:600;font-size:.875rem;color:rgb(var(--text))}.cookie-category-description{font-size:.75rem;color:rgb(var(--text-secondary));margin-top:.125rem;line-height:1.4}.cookie-banner-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}@media(max-width:500px){.cookie-banner-actions .btn{flex:1 0 auto}}.not-found-page,.error-boundary{max-width:640px;margin:0 auto;padding:4rem 1.5rem;display:flex;justify-content:center;min-height:60vh}.not-found-card,.error-boundary-card{text-align:center;max-width:480px}.not-found-code{font-family:var(--font-mono, ui-monospace, monospace);font-size:3.5rem;font-weight:700;color:var(--blue);margin-bottom:1rem}.not-found-title,.error-boundary-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin:0 0 1rem;color:rgb(var(--text))}.not-found-body,.error-boundary-body{color:rgb(var(--text-secondary));line-height:1.6;margin:0 0 1.5rem}.not-found-path{background:rgba(var(--text),.06);padding:.125rem .375rem;border-radius:4px;font-size:.875rem}.error-boundary-detail{background:rgba(var(--text),.04);padding:.75rem 1rem;border-radius:8px;font-family:var(--font-mono, ui-monospace, monospace);font-size:.8125rem;color:rgb(var(--text-secondary));text-align:left;white-space:pre-wrap;word-wrap:break-word;margin:0 0 1.5rem;max-height:12rem;overflow-y:auto}.request-access-card{background:rgb(var(--surface));border-radius:var(--radius);padding:3rem 2.5rem;max-width:28rem;width:100%;box-shadow:var(--shadow-card);text-align:center}.request-access-title{font-family:var(--font-display);font-size:1.75rem;font-weight:600;margin:0 0 1rem}.request-access-body{color:rgb(var(--text-secondary));font-size:.9375rem;line-height:1.6;margin:0 0 1.5rem}.request-access-email{display:inline-block;font-family:var(--font-mono);font-size:.875rem;padding:.375rem .75rem;border-radius:8px;background:rgba(var(--text),.05);color:rgb(var(--text));margin:.5rem 0 1.5rem}.profile-page{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}.profile-header{display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:center;padding:1.5rem 0 2rem;border-bottom:1px solid rgba(var(--text),.08);margin-bottom:2rem}@media(max-width:600px){.profile-header{grid-template-columns:auto 1fr;grid-template-areas:"avatar identity" "edit edit"}.profile-avatar-wrap{grid-area:avatar}.profile-identity{grid-area:identity}.profile-header>.btn{grid-area:edit;justify-self:start}}.profile-avatar-wrap{width:96px;height:96px}.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;background:rgb(var(--surface))}.profile-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:2.25rem;font-weight:600;color:rgb(var(--text-secondary));background:rgba(var(--text),.06)}.profile-display-name{font-family:var(--font-display);font-size:1.75rem;font-weight:600;margin:0;line-height:1.1}.profile-handle-row{display:flex;align-items:center;gap:.625rem;margin-top:.375rem;flex-wrap:wrap}.profile-handle{color:rgb(var(--text-secondary));font-size:.9375rem}.profile-badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.profile-badge-founding{background:var(--yellow);color:rgb(var(--navy-deep));border:2px solid var(--yellow-dark);box-shadow:0 2px 0 var(--yellow-dark);font-weight:900}.profile-actions{display:flex;flex-direction:column;gap:.5rem;align-items:stretch}.profile-signout{font-size:.75rem;opacity:.6}.profile-signout:hover{opacity:1}.profile-title-label{font-family:var(--font-display);font-size:.875rem;color:var(--blue);margin-top:.125rem;letter-spacing:.02em}.profile-bio{color:rgb(var(--text));margin:.75rem 0 0;line-height:1.5;max-width:52ch}.titles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.title-card{display:flex;flex-direction:column;gap:.25rem;padding:.875rem 1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:14px;text-align:left;font:inherit;color:inherit;cursor:pointer;box-shadow:var(--shadow-chunky);transition:all .15s}.title-card:hover:not(:disabled){transform:translateY(-3px);border-color:var(--blue)}.title-locked{opacity:.45;cursor:default}.title-equipped{border-color:var(--blue);background:var(--blue-pale)}.title-card-label{font-family:var(--font-display);font-size:1rem;color:rgb(var(--text));letter-spacing:.01em}.title-card-desc{font-size:.75rem;color:rgb(var(--text-secondary));font-weight:600;line-height:1.35}.title-card-icon{width:40px;height:40px;object-fit:contain;margin:0 auto .25rem;display:block;image-rendering:auto}.title-locked .title-card-icon{filter:grayscale(1) opacity(.4)}.title-card-frame-demo{width:44px;height:44px;border-radius:50%;margin:.25rem auto .5rem;background:linear-gradient(135deg,var(--blue),var(--purple))}.title-card .bg-preview-label{text-shadow:0 1px 2px rgba(255,255,255,.8),0 0 4px rgba(0,0,0,.2);position:relative;z-index:1}.title-card:has(.bg-preview-label){position:relative;overflow:hidden;background-size:cover!important;background-position:center!important}.title-card:has(.bg-preview-label):before{content:"";position:absolute;inset:0;background:#ffffff8c;border-radius:inherit;z-index:0;pointer-events:none}.title-card:has(.bg-preview-label)>*{position:relative;z-index:1}.title-card-equipped-badge{display:inline-block;margin-top:.375rem;padding:.125rem .5rem;background:var(--blue);color:#fff;border-radius:999px;font-size:.5625rem;font-weight:900;letter-spacing:.06em;align-self:flex-start}.title-card-rarity{font-size:.625rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-top:.25rem}.title-rarity-common .title-card-rarity{color:rgb(var(--text-secondary))}.title-rarity-uncommon .title-card-rarity{color:var(--green)}.title-rarity-rare .title-card-rarity{color:var(--blue)}.title-rarity-epic .title-card-rarity{color:var(--purple)}.title-rarity-legendary .title-card-rarity{color:var(--yellow-dark)}.title-rarity-legendary.title-unlocked{border-color:var(--yellow)}.title-rarity-epic.title-unlocked{border-color:var(--purple)}.cosmetic-tabs{display:flex;gap:.25rem;padding:.125rem;background:#0000000a;border-radius:10px;margin-bottom:1rem}.cosmetic-tab{flex:1;padding:.5rem .75rem;background:none;border:0;border-radius:8px;font:inherit;font-size:.8125rem;font-weight:800;color:rgb(var(--text-secondary));cursor:pointer;text-transform:uppercase;letter-spacing:.04em;transition:all .15s}.cosmetic-tab:hover{color:rgb(var(--text))}.cosmetic-tab-active{background:rgb(var(--surface));color:rgb(var(--text));box-shadow:0 2px #0000000f}[class*=avatar-frame-]{position:relative;border-radius:50%}.avatar-frame-default{box-shadow:0 0 0 2px #fff3}.avatar-frame-bronze-ring{box-shadow:0 0 0 3px #cd7f32,0 0 0 5px #cd7f3266}.avatar-frame-silver-ring{box-shadow:0 0 0 3px #e5e7eb,0 0 0 5px #94a3b880,0 0 12px #e5e7eb66}.avatar-frame-gold-ring{box-shadow:0 0 0 3px #fbbf24,0 0 0 5px #d97706,0 0 16px #fbbf2480}.avatar-frame-arrows-frame{box-shadow:0 0 0 3px var(--blue),0 0 0 5px #3b82f666,0 0 14px #3b82f680}.avatar-frame-cats-frame{box-shadow:0 0 0 3px #f472b6,0 0 0 5px #f472b666,0 0 14px #f472b680}.avatar-frame-cards-frame{box-shadow:0 0 0 3px #a78bfa,0 0 0 5px #a78bfa66,0 0 14px #a78bfa80}.avatar-frame-champion-ring{box-shadow:0 0 0 3px var(--purple),0 0 0 6px #8b5cf666,0 0 20px #8b5cf699;animation:champion-pulse 2.4s ease-in-out infinite}@keyframes champion-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}.avatar-frame-founder-frame{box-shadow:0 0 0 3px var(--yellow),0 0 0 5px #fbbf2473,0 0 18px #fbbf2499}.avatar-frame-legendary-glow{box-shadow:0 0 0 3px var(--yellow),0 0 18px #fbbf2499,0 0 36px #fbbf2459;animation:legendary-pulse 2s ease-in-out infinite}@keyframes legendary-pulse{0%,to{box-shadow:0 0 0 3px var(--yellow),0 0 18px #fbbf2499,0 0 36px #fbbf2459}50%{box-shadow:0 0 0 3px var(--yellow),0 0 28px #fbbf24cc,0 0 56px #fbbf2480}}.avatar-frame-fire-ring:before,.avatar-frame-neon-pulse:before,.avatar-frame-rainbow-spin:before{content:"";position:absolute;inset:-5px;border-radius:50%;padding:3px;z-index:-1;pointer-events:none}.avatar-frame-fire-ring{box-shadow:0 0 14px #ef44448c,0 0 28px #f9731659}.avatar-frame-fire-ring:before{background:conic-gradient(from 0deg,#ef4444,#f97316,#facc15,#f97316,#ef4444);-webkit-mask:radial-gradient(circle,transparent calc(50% - 5px),black calc(50% - 3px));mask:radial-gradient(circle,transparent calc(50% - 5px),black calc(50% - 3px));animation:frame-spin 3s linear infinite,fire-flare 1.4s ease-in-out infinite alternate}@keyframes fire-flare{0%{filter:brightness(.95) saturate(1.1)}to{filter:brightness(1.25) saturate(1.4)}}.avatar-frame-neon-pulse{box-shadow:0 0 14px #22d3ee99,0 0 28px #e879f959}.avatar-frame-neon-pulse:before{background:conic-gradient(from 90deg,#22d3ee,#a855f7,#ec4899,#22d3ee);-webkit-mask:radial-gradient(circle,transparent calc(50% - 5px),black calc(50% - 3px));mask:radial-gradient(circle,transparent calc(50% - 5px),black calc(50% - 3px));animation:frame-spin 4s linear infinite}.avatar-frame-rainbow-spin{box-shadow:0 0 18px #a78bfa73}.avatar-frame-rainbow-spin:before{background:conic-gradient(from 0deg,#ef4444,#f59e0b,#eab308,#22c55e,#06b6d4,#3b82f6,#a855f7,#ec4899,#ef4444);-webkit-mask:radial-gradient(circle,transparent calc(50% - 6px),black calc(50% - 3px));mask:radial-gradient(circle,transparent calc(50% - 6px),black calc(50% - 3px));animation:frame-spin 6s linear infinite}@keyframes frame-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}[class*=card-frame-]{position:relative}.card-frame-default{box-shadow:inset 0 0 0 1px rgba(var(--text),.08)}.card-frame-card-slate{box-shadow:inset 0 0 0 2px #64748b80}.card-frame-card-gold-edge{box-shadow:inset 0 0 0 2px #fbbf24,0 0 12px #fbbf2440}.card-frame-card-neon-edge{box-shadow:inset 0 0 0 2px #22d3ee,0 0 14px #22d3ee66,0 0 28px #a855f733}.card-frame-card-flame-edge{box-shadow:inset 0 0 0 2px #f97316,0 0 16px #f9731673,0 0 32px #ef444440;background-image:radial-gradient(ellipse at 50% 120%,rgba(249,115,22,.22),transparent 65%),radial-gradient(ellipse at 20% 0%,rgba(239,68,68,.14),transparent 55%),linear-gradient(180deg,#fbbf240a,#ef444414);animation:card-flame-flicker 2.2s ease-in-out infinite}@keyframes card-flame-flicker{0%,to{filter:brightness(1)}50%{filter:brightness(1.12) saturate(1.25)}}.card-frame-card-arrows{box-shadow:inset 0 0 0 2px var(--blue),0 0 14px #3b82f659}.card-frame-card-pixel-pop{box-shadow:inset 0 0 0 2px #f472b6,0 0 14px #f472b666,0 0 28px #fbbf2433;background-image:radial-gradient(circle at 50% 50%,rgba(244,114,182,.22) 1px,transparent 1.5px),linear-gradient(135deg,#f472b624,#fbbf241a,#3b82f614);background-size:10px 10px,auto}.card-frame-card-champion{box-shadow:inset 0 0 0 2px var(--purple),0 0 16px #8b5cf680,0 0 32px #8b5cf640;background-image:radial-gradient(ellipse at 50% -10%,rgba(139,92,246,.28),transparent 65%),radial-gradient(ellipse at 50% 110%,rgba(236,72,153,.14),transparent 60%),linear-gradient(180deg,#8b5cf60f,#8b5cf605);animation:card-champion-pulse 2.4s ease-in-out infinite}@keyframes card-champion-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.14) saturate(1.1)}}.card-frame-card-founder{box-shadow:inset 0 0 0 2px var(--yellow),0 0 18px #fbbf248c,0 0 36px #fbbf244d;background-image:radial-gradient(ellipse at 30% 25%,rgba(251,191,36,.28),transparent 55%),radial-gradient(ellipse at 75% 80%,rgba(217,119,6,.2),transparent 55%),linear-gradient(135deg,#fbbf241a,#fbbf240a);animation:card-founder-shimmer 5s ease-in-out infinite}@keyframes card-founder-shimmer{0%,to{filter:brightness(1) saturate(1)}50%{filter:brightness(1.08) saturate(1.15)}}.name-style-blue{color:var(--blue)}.name-style-gold{background:linear-gradient(135deg,#fbbf24,#d97706,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-neon{color:#00d4ff;text-shadow:0 0 8px rgba(0,212,255,.5),0 0 16px rgba(0,212,255,.2)}.name-style-holographic{background:linear-gradient(90deg,#f472b6,#a78bfa,#60a5fa,#34d399,#fbbf24,#f472b6);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:holo-shift 4s linear infinite}@keyframes holo-shift{0%{background-position:0% 50%}to{background-position:200% 50%}}.name-style-fire{background:linear-gradient(135deg,#ef4444,#f59e0b,#ef4444);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:fire-flicker 2s ease-in-out infinite}@keyframes fire-flicker{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.profile-not-found{text-align:center;padding:4rem 1rem}.profile-section{margin-bottom:2.5rem}.profile-section-title{font-family:var(--font-display);font-size:1.0625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:rgb(var(--text));margin:0 0 1rem}.profile-section-count{color:rgb(var(--text-secondary));font-weight:400;text-transform:none;letter-spacing:0}.profile-showcase{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:640px){.profile-showcase{grid-template-columns:1fr}}.profile-showcase-card{display:flex;flex-direction:column;gap:.5rem;padding:0;background:rgb(var(--surface));border:0;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-card);transition:transform .2s ease;text-align:left}.profile-showcase-card:hover{transform:translateY(-2px)}.profile-showcase-image{width:100%;aspect-ratio:4 / 3;object-fit:cover;background:rgba(var(--text),.05)}.profile-showcase-title{padding:0 .875rem .875rem;font-weight:600;color:rgb(var(--text));font-size:.9375rem}.profile-games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.875rem}.profile-game-card{display:grid;grid-template-columns:72px 1fr;gap:.75rem;align-items:center;padding:.625rem;background:rgb(var(--surface));border:1px solid rgba(var(--text),.06);border-radius:12px;cursor:pointer;text-align:left;transition:background .15s ease,border-color .15s ease}.profile-game-card:hover{background:rgba(var(--text),.02);border-color:rgba(var(--text),.12)}.profile-game-image{width:72px;height:54px;object-fit:cover;border-radius:6px;background:rgba(var(--text),.08)}.profile-game-body{min-width:0}.profile-game-title{font-weight:600;color:rgb(var(--text));font-size:.9375rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-game-stats{display:flex;gap:.375rem;color:rgb(var(--text-secondary));font-size:.8125rem;margin-top:.125rem;font-variant-numeric:tabular-nums}.profile-game-stats-sep{opacity:.5}.sheet-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:200;touch-action:none;overscroll-behavior:contain}.sheet{background:rgb(var(--surface));border-radius:16px;box-shadow:0 24px 80px #00000059;max-width:520px;width:100%;max-height:calc(100vh - 2rem);display:flex;flex-direction:column}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(var(--text),.08)}.sheet-header h2{margin:0;font-family:var(--font-display);font-size:1.125rem;font-weight:600}.sheet-close{background:none;border:0;font-size:1.5rem;color:rgb(var(--text-secondary));cursor:pointer;padding:.25rem .5rem;line-height:1}.sheet-body{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem;touch-action:pan-y;overscroll-behavior:contain}.sheet-footer{display:flex;justify-content:flex-end;gap:.625rem;padding:1rem 1.25rem;border-top:1px solid rgba(var(--text),.08)}.field{display:flex;flex-direction:column;gap:.375rem}.field-label{display:flex;justify-content:space-between;align-items:baseline;font-size:.8125rem;font-weight:600;color:rgb(var(--text));text-transform:uppercase;letter-spacing:.05em}.field-hint{color:rgb(var(--text-secondary));font-weight:400;text-transform:none;letter-spacing:0;font-size:.75rem}.field-input{background:rgb(var(--bg));border:1px solid rgba(var(--text),.12);border-radius:8px;padding:.625rem .75rem;font-size:.9375rem;color:rgb(var(--text));font-family:inherit;transition:border-color .15s ease}.field-input:focus{outline:none;border-color:rgba(var(--text),.3)}.field-textarea{resize:vertical;min-height:3rem;font-family:inherit}.field-error{background:#ef44441a;color:#dc2626;padding:.625rem .75rem;border-radius:8px;font-size:.875rem}.avatar-edit{display:flex;align-items:center;gap:1rem}.avatar-edit-preview{width:64px;height:64px;border-radius:50%;object-fit:cover;background:rgba(var(--text),.08)}.avatar-edit-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;color:rgb(var(--text-secondary))}.avatar-edit-upload{cursor:pointer;display:inline-block}.showcase-grid{display:flex;flex-wrap:wrap;gap:.5rem}.showcase-option{display:inline-flex;align-items:center;gap:.375rem;background:rgb(var(--bg));border:1px solid rgba(var(--text),.12);border-radius:999px;padding:.375rem .875rem;font-size:.8125rem;color:rgb(var(--text));cursor:pointer;font-family:inherit;transition:all .15s ease}.showcase-option:hover:not(:disabled){border-color:rgba(var(--text),.3)}.showcase-option:disabled{opacity:.4;cursor:not-allowed}.showcase-option-pinned{background:rgba(var(--text),.08);border-color:rgba(var(--text),.35);font-weight:600}.showcase-option-badge{color:rgb(var(--text-secondary));font-size:.75rem}.xp-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;margin-top:1rem;max-width:480px}.xp-level-pill{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;font-weight:700;font-size:.8125rem;letter-spacing:.02em;font-variant-numeric:tabular-nums;box-shadow:0 1px 3px #d977064d}.xp-track{height:8px;background:rgba(var(--text),.08);border-radius:999px;overflow:hidden}.xp-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#d97706);border-radius:999px;transition:width .4s ease}.xp-counts{display:flex;flex-direction:column;align-items:flex-end;font-size:.75rem;font-variant-numeric:tabular-nums;line-height:1.2}.xp-points{color:rgb(var(--text));font-weight:600}.xp-meta{color:rgb(var(--text-secondary))}.achievements-groups{display:flex;flex-direction:column;gap:1.5rem}.achievements-group-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.625rem}.achievements-group-title{font-weight:600;color:rgb(var(--text));font-size:.9375rem}.achievements-group-count{color:rgb(var(--text-secondary));font-size:.8125rem;font-variant-numeric:tabular-nums}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.625rem}.achievement-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:0;padding:0;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:10px;overflow:hidden;min-height:110px;transition:border-color .15s ease,opacity .15s ease}.achievement-locked{opacity:.55}.achievement-locked .achievement-icon,.achievement-locked .achievement-icon-img{filter:grayscale(1)}.achievement-unlocked{border-color:#3b82f659}.achievement-tier-bronze.achievement-unlocked{border-color:#b4785073}.achievement-tier-silver.achievement-unlocked{border-color:#94a3b88c}.achievement-tier-gold.achievement-unlocked{border-color:#3b82f680;box-shadow:0 0 0 1px #3b82f626}.achievement-icon{width:100%;height:100%;min-height:110px;border-radius:0;background:rgba(var(--text),.05);display:flex;align-items:center;justify-content:center;font-size:3.25rem;flex-shrink:0;overflow:hidden}.achievement-icon-img{width:100%;height:100%;object-fit:cover;display:block}.achievement-tier-bronze .achievement-icon{background:linear-gradient(135deg,#b478501f,#b478500a)}.achievement-tier-silver .achievement-icon{background:linear-gradient(135deg,#94a3b82e,#94a3b80d)}.achievement-tier-gold .achievement-icon{background:linear-gradient(135deg,#fbbf2438,#3b82f60f)}.achievement-unlocked.achievement-tier-bronze .achievement-icon{background:linear-gradient(135deg,#b4785047,#b4785014)}.achievement-unlocked.achievement-tier-silver .achievement-icon{background:linear-gradient(135deg,#94a3b859,#94a3b81a)}.achievement-unlocked.achievement-tier-gold .achievement-icon{background:linear-gradient(135deg,#fbbf246b,#3b82f624)}.achievement-body{min-width:0;padding:.875rem 1rem;display:flex;flex-direction:column;justify-content:center;gap:.25rem}.achievement-title{font-weight:600;color:rgb(var(--text));font-size:.9375rem;line-height:1.2}.achievement-description{color:rgb(var(--text-secondary));font-size:.8125rem;margin-top:.125rem;line-height:1.35}.achievement-meta{display:flex;gap:.375rem;margin-top:.375rem;font-size:.75rem;color:rgb(var(--text-secondary));align-items:center;flex-wrap:wrap}.achievement-points{font-weight:600;color:rgb(var(--text));font-variant-numeric:tabular-nums}.achievement-unlocked .achievement-points{color:var(--blue)}.achievement-meta-sep{opacity:.4}.achievement-rarity{font-variant-numeric:tabular-nums}.skeleton-card{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.04);border-radius:var(--radius);overflow:hidden}.skeleton-image{width:100%;aspect-ratio:4 / 3;background:#0000000a}.skeleton-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.skeleton-line{height:.875rem;border-radius:6px;background:#0000000d}.skeleton-line-title{width:60%;height:1.125rem}.skeleton-line-desc{width:90%}.skeleton-line-short{width:40%}.skeleton-shimmer{position:relative;overflow:hidden}.skeleton-shimmer:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem}.loading-spinner{width:40px;height:40px;border:4px solid rgba(0,0,0,.08);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-label{font-weight:700;color:rgb(var(--text-secondary));font-size:.875rem;margin:0}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:rgb(var(--bg))}.login-hero{text-align:center;margin-bottom:2.5rem}.login-brand{font-family:var(--font-display);font-size:3.5rem;color:rgb(var(--text));text-shadow:0 4px 0 rgba(0,0,0,.08);letter-spacing:.02em}.login-brand-accent{color:var(--yellow)}.login-tagline{font-size:1.125rem;font-weight:700;color:rgb(var(--text-secondary));margin:.75rem 0 0}.login-card{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);padding:2.5rem;max-width:400px;width:100%;box-shadow:var(--shadow-pop);text-align:center}.login-card-title{font-family:var(--font-display);font-size:1.375rem;color:rgb(var(--text));margin:0 0 .375rem;letter-spacing:.02em}.login-card-subtitle{font-size:.9375rem;color:rgb(var(--text-secondary));font-weight:600;margin:0 0 1.75rem}.login-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;border-radius:14px;font-size:.9375rem;font-weight:800;cursor:pointer;transition:all .1s;margin-bottom:.75rem;border:3px solid}.login-btn:hover{transform:translateY(2px)}.login-btn-github{background:rgb(var(--navy));border-color:rgb(var(--navy-deep));color:#fff;box-shadow:0 5px rgb(var(--navy-deep))}.login-btn-github:hover{box-shadow:0 3px rgb(var(--navy-deep))}.login-btn-google{background:rgb(var(--surface));border-color:#0000001a;color:rgb(var(--text));box-shadow:0 4px #00000014}.login-btn-google:hover{box-shadow:0 2px #00000014}.login-footer-text{font-size:.75rem;color:rgb(var(--text-secondary));margin:1rem 0 0;font-weight:600}.login-footer-text a{color:var(--blue);text-decoration:underline}@media(max-width:640px){.login-brand{font-size:2.5rem}.login-card{padding:1.75rem}}.report-trigger{background:none;border:0;padding:.25rem;font-size:.875rem;color:rgb(var(--text-secondary));opacity:.4;cursor:pointer;transition:opacity .2s}.report-trigger:hover{opacity:1;color:var(--red)}.report-sent{font-size:.6875rem;color:var(--green);font-weight:700}.report-form{display:flex;flex-direction:column;gap:.375rem;padding:.75rem;background:#00000008;border-radius:10px;margin-top:.375rem}.report-select{font-size:.8125rem;padding:.375rem .5rem}.report-actions{display:flex;gap:.375rem;justify-content:flex-end}@media(max-width:900px){.portal-nav-links{display:none}.portal-nav{gap:.5rem}}@media(max-width:640px){.portal-nav{padding:.625rem 1rem;gap:.5rem}.portal-nav-brand{font-size:1.25rem}.portal-nav-links{display:none}.portal-nav-user{padding:.25rem .625rem .25rem .25rem;gap:.375rem;font-size:.75rem}.portal-nav-avatar{width:26px;height:26px}.nav-xp-badge{font-size:.5625rem;padding:.125rem .5rem}.container{padding:1.25rem 1rem 3rem}.weekly-challenge{padding:1.5rem 1.25rem;margin:1.25rem 0 1.5rem}.weekly-challenge-title{font-size:2rem}.weekly-challenge-description{font-size:.875rem}.weekly-challenge .btn-primary{font-size:.875rem;padding:.625rem 1.25rem}.stats-bar{padding:1rem;gap:.75rem}.stat-value{font-size:1.375rem}.spotlight-card{grid-template-columns:1fr}.spotlight-body{padding:1.25rem}.spotlight-title{font-size:1.375rem}.games-grid,.hero-strip{grid-template-columns:1fr;gap:.875rem}.category-title{font-size:1.125rem}.following-playing-cards{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.5rem}.following-playing-card{flex-shrink:0}.profile-header{grid-template-columns:auto 1fr;grid-template-areas:"avatar identity" "actions actions"}.profile-avatar-wrap{grid-area:avatar}.profile-identity{grid-area:identity}.profile-header>.btn,.profile-header>.profile-actions{grid-area:actions;justify-self:start}.profile-avatar-wrap,.profile-avatar{width:72px;height:72px}.profile-display-name{font-size:1.375rem}.achievements-grid{grid-template-columns:1fr}.titles-grid{grid-template-columns:1fr 1fr;gap:.5rem}.game-community{margin:1.25rem auto 0;padding:0 1rem}.game-detail-layout{grid-template-columns:1fr}.crew-header{flex-direction:column;gap:1rem}.site-footer-inner{grid-template-columns:1fr;gap:1.5rem}.leaderboard-detail-page{padding:1.25rem 1rem 3rem}.challenge-toast,.achievement-toast,.levelup-toast{right:.75rem;left:.75rem;max-width:none}.sheet{max-width:100%;margin:0 .5rem}.legal-page{padding:1.25rem 1rem 3rem}.legal-title{font-size:1.5rem}.cookie-banner{left:.5rem;right:.5rem;bottom:.5rem}.metrics-chart{grid-template-columns:repeat(7,1fr);height:120px}}.age-gate-overlay{position:fixed;inset:0;background:#0f172aa6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.age-gate-card{background:#fff;border-radius:16px;padding:2rem;max-width:480px;width:100%;box-shadow:0 20px 50px #00000040}.age-gate-title{margin:0 0 1rem;font-size:1.5rem}.age-gate-body{margin:0 0 1.5rem;line-height:1.5;color:#334155}.age-gate-checkbox{display:flex;gap:.75rem;align-items:center;padding:1rem;background:#f1f5f9;border-radius:8px;cursor:pointer;margin-bottom:1rem}.age-gate-checkbox input{width:18px;height:18px;cursor:pointer}.age-gate-actions{display:flex;justify-content:flex-end;margin-bottom:1rem}.age-gate-footer{font-size:.85rem;color:#64748b;text-align:center;margin:0}.terms-update-banner{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:1rem 1.25rem;border-radius:12px;display:flex;align-items:center;gap:1rem;max-width:640px;width:calc(100% - 2rem);z-index:999;box-shadow:0 10px 30px #00000040}.terms-update-banner a{color:#93c5fd;text-decoration:underline}.terms-update-body{flex:1;font-size:.9rem;line-height:1.4}.learn-header{margin-bottom:2rem}.learn-header-title{font-family:var(--font-display);font-size:2.25rem;color:rgb(var(--text));margin:0 0 .25rem;line-height:1.1}.learn-header-lead{color:rgb(var(--text-secondary));font-size:1rem;max-width:48rem;line-height:1.5;margin:0}.learn-section-title{font-family:var(--font-display);font-size:1.5rem;color:rgb(var(--text));margin:2rem 0 1rem}.learn-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:1rem;margin-bottom:2rem}.learn-tile{background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);padding:1.25rem 1rem;box-shadow:var(--shadow-chunky);text-align:center;transition:all .15s}.learn-tile--clickable{cursor:pointer}.learn-tile--clickable:hover{transform:translateY(-4px);box-shadow:var(--shadow-float);border-color:var(--blue)}.learn-tile-value{font-family:var(--font-display);font-size:2rem;color:rgb(var(--text));line-height:1;margin-bottom:.25rem}.learn-tile-value--yellow{color:var(--yellow-dark)}.learn-tile-value--blue{color:var(--blue)}.learn-tile-value--green{color:var(--green-dark)}.learn-tile-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:rgb(var(--text-muted))}.learn-surface-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(18rem,1fr));gap:1rem;margin-bottom:2rem}.learn-surface-card{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem 1.25rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow-chunky);text-align:left;color:rgb(var(--text));cursor:pointer;transition:all .15s;font:inherit}.learn-surface-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-float);border-color:var(--blue)}.learn-surface-card h3{font-family:var(--font-display);font-size:1.25rem;margin:0;color:rgb(var(--text))}.learn-surface-card p{margin:0;color:rgb(var(--text-secondary));font-size:.95rem;line-height:1.5}.learn-surface-card-cta{margin-top:.25rem;font-weight:800;font-size:.875rem;color:var(--blue);letter-spacing:.02em}.learn-filterbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:1.5rem;padding:.875rem 1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow-chunky)}.learn-search{flex:1 1 12rem;padding:.6rem .85rem;font:inherit;font-size:.95rem;color:rgb(var(--text));background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:12px;outline:none}.learn-search:focus{border-color:var(--blue);background:rgb(var(--surface))}.learn-btngroup{display:flex;gap:.25rem;align-items:center}.learn-btngroup-label{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:rgb(var(--text-muted));margin-right:.4rem}.learn-btngroup-opt{padding:.4rem .75rem;font-size:.85rem;font-weight:700;color:rgb(var(--text-secondary));background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:10px;cursor:pointer;transition:all .1s}.learn-btngroup-opt:hover{border-color:var(--blue)}.learn-btngroup-opt--active{background:var(--blue);border-color:var(--blue-dark);color:#fff;box-shadow:0 3px 0 var(--blue-deeper)}.learn-btngroup-opt--active:hover{box-shadow:0 2px 0 var(--blue-deeper)}.learn-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(17rem,1fr));gap:.75rem;margin-bottom:1.5rem}.learn-grammar-card{display:flex;flex-direction:column;gap:.4rem;padding:1rem 1.1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:14px;box-shadow:var(--shadow-chunky);cursor:pointer;text-align:left;color:rgb(var(--text));font:inherit;transition:all .15s}.learn-grammar-card:hover{transform:translateY(-3px);border-color:var(--blue);box-shadow:var(--shadow-float)}.learn-grammar-card-top{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.learn-grammar-card-label{font-weight:800;font-size:1.05rem;color:rgb(var(--text))}.learn-grammar-card-pattern{color:rgb(var(--text-secondary));font-size:.9rem;line-height:1.4}.learn-chip{display:inline-flex;align-items:center;padding:.2rem .55rem;font-size:.7rem;font-weight:800;letter-spacing:.04em;border-radius:8px;background:rgb(var(--bg));color:rgb(var(--text-secondary));border:2px solid rgb(var(--border))}.learn-chip--yellow{background:#fef3c7;color:var(--yellow-dark);border-color:#fde68a}.learn-chip--blue{background:var(--blue-pale);color:var(--blue-deeper);border-color:var(--blue-light)}.learn-chip--green{background:#dcfce7;color:var(--green-dark);border-color:#bbf7d0}.learn-chip--red{background:#fee2e2;color:#991b1b;border-color:#fecaca}.learn-chip--dim{background:rgb(var(--bg));color:rgb(var(--text-muted));border-color:rgb(var(--border))}.learn-chip-link{cursor:pointer;font:inherit;font-family:var(--font-mono);transition:all .1s}.learn-chip-link:hover{transform:translateY(-1px);filter:brightness(1.05)}.learn-chip-link:active{transform:translateY(1px)}.learn-streak-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;font-family:var(--font-body);font-size:.85rem;font-weight:800;color:#fff;background:var(--yellow-dark);border:2px solid rgba(0,0,0,.15);border-radius:10px;box-shadow:0 3px #0003}.learn-streak-chip-icon{font-weight:900}.learn-pagination{display:flex;justify-content:center;gap:.75rem;align-items:center;margin:1.5rem 0 3rem}.learn-page-num{color:rgb(var(--text-muted));font-size:.875rem;font-weight:700}.learn-empty{padding:2.5rem 1.25rem;text-align:center;color:rgb(var(--text-secondary));background:rgb(var(--surface));border:2px dashed rgb(var(--border));border-radius:var(--radius);margin-bottom:2rem}.learn-error{padding:1.25rem;background:#fef2f2;color:#991b1b;border:2px solid #fecaca;border-radius:14px;margin-bottom:1.5rem}.learn-error strong{display:block;margin-bottom:.25rem;font-weight:800}.learn-flash{padding:.75rem 1rem;background:#dcfce7;color:var(--green-dark);border:2px solid #bbf7d0;border-radius:12px;margin-bottom:1.5rem;font-size:.95rem}.learn-review-card{max-width:42rem;margin:0 auto;padding:2rem 1.5rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;gap:1.5rem}.learn-review-prompt{text-align:center;padding:1rem 0;min-height:4.5rem;font-size:1.25rem;line-height:1.5;color:rgb(var(--text))}.learn-review-prompt-label{display:block;font-size:.8rem;font-weight:700;letter-spacing:.05em;color:rgb(var(--text-muted));text-transform:uppercase;margin-bottom:.5rem}.learn-review-prompt strong{font-family:var(--font-display);font-size:1.9rem;color:rgb(var(--text))}.learn-review-divider{width:100%;height:2px;background:rgb(var(--border));border:none;margin:0}.learn-review-answer{font-size:1rem;line-height:1.6;color:rgb(var(--text))}.learn-review-references{padding-top:1rem;border-top:1px solid rgb(var(--border));font-size:.9rem;color:rgb(var(--text-secondary))}.learn-example-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.learn-example-list li{padding:.6rem .85rem;background:rgb(var(--bg));border-radius:10px;font-size:1rem;color:rgb(var(--text));line-height:1.5}.learn-grade-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.learn-grade-btn{padding:.75rem .5rem;font-family:inherit;font-size:.95rem;font-weight:800;letter-spacing:.02em;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.15rem;transition:all .1s;border:3px solid}.learn-grade-btn:hover{transform:translateY(2px)}.learn-grade-btn:active{transform:translateY(4px)}.learn-grade-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.learn-grade-btn--again{background:#fef2f2;border-color:#fecaca;color:#991b1b;box-shadow:0 4px #fca5a5}.learn-grade-btn--hard{background:#fef3c7;border-color:#fde68a;color:var(--yellow-dark);box-shadow:0 4px #fcd34d}.learn-grade-btn--good{background:#dcfce7;border-color:#bbf7d0;color:var(--green-dark);box-shadow:0 4px #86efac}.learn-grade-btn--easy{background:var(--blue-pale);border-color:var(--blue-light);color:var(--blue-deeper);box-shadow:0 4px #93c5fd}.learn-grade-btn-hint{font-size:.72rem;font-weight:600;opacity:.75}.learn-reveal-wrap{display:flex;flex-direction:column;gap:.75rem;align-items:center}.learn-reveal-skip{background:none;border:none;color:rgb(var(--text-muted));font-size:.85rem;padding:.25rem .75rem;cursor:pointer}.learn-reveal-skip:hover{color:rgb(var(--text-secondary))}.learn-kanji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(4.5rem,1fr));gap:.5rem;margin-bottom:1.5rem}.learn-kanji-cell{aspect-ratio:1 / 1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.1rem;padding:.25rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:12px;box-shadow:var(--shadow-chunky);cursor:pointer;transition:all .12s;font:inherit;color:rgb(var(--text))}.learn-kanji-cell:hover{transform:translateY(-3px);box-shadow:var(--shadow-float);border-color:var(--blue)}.learn-kanji-cell--learning{border-color:#fde68a;background:#fffbeb}.learn-kanji-cell--partial{border-color:var(--blue-light);background:var(--blue-pale)}.learn-kanji-cell--full{border-color:#bbf7d0;background:#f0fdf4}.learn-kanji-cell-char{font-family:var(--font-display);font-size:1.75rem;line-height:1;color:rgb(var(--text))}.learn-kanji-cell-meta{font-size:.65rem;color:rgb(var(--text-muted));font-weight:600}.learn-kanji-hero{width:8rem;height:8rem;display:flex;align-items:center;justify-content:center;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow-chunky);font-family:var(--font-display);font-size:4.5rem;line-height:1;color:rgb(var(--text));flex-shrink:0}.learn-kanji-detail-head{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:start;margin-bottom:2rem}@media(max-width:500px){.learn-kanji-detail-head{grid-template-columns:1fr}}.learn-kanji-meanings{font-family:var(--font-display);font-size:1.4rem;margin:.25rem 0 .75rem;color:rgb(var(--text));line-height:1.2}.learn-reading-row{display:flex;gap:.5rem;align-items:baseline;margin-bottom:.25rem}.learn-reading-label{font-size:.7rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:rgb(var(--text-muted));min-width:4rem}.learn-reading-values{font-size:1rem;color:rgb(var(--text))}.learn-draw-wrap{display:flex;flex-direction:column;gap:.75rem;align-items:center}.learn-draw-canvas{position:relative;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.08);border-radius:14px;box-shadow:var(--shadow-pop);cursor:crosshair;touch-action:none;-webkit-user-select:none;user-select:none}.learn-draw-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.learn-candidate-row{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center}.learn-candidate-chip{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:.45rem .6rem;min-width:3rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:12px;box-shadow:var(--shadow-chunky)}.learn-candidate-chip--target{background:#f0fdf4;border-color:#bbf7d0;box-shadow:0 4px #86efac}.learn-candidate-char{font-family:var(--font-display);font-size:1.55rem;line-height:1;color:rgb(var(--text))}.learn-candidate-rank{font-size:.65rem;font-weight:700;color:rgb(var(--text-muted));margin-top:.15rem}.learn-progress{width:100%;max-width:42rem;margin:0 auto .5rem;height:6px;background:rgb(var(--border));border-radius:999px;overflow:hidden}.learn-progress-fill{height:100%;background:var(--blue);transition:width .2s}.learn-progress-label{text-align:center;font-size:.875rem;color:rgb(var(--text-muted));margin-bottom:1rem;font-weight:700}.learn-summary{max-width:32rem;margin:3rem auto;text-align:center}.learn-summary h1{font-family:var(--font-display);font-size:2.25rem;margin:0 0 .5rem;color:rgb(var(--text))}.learn-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin:1.5rem 0}.learn-summary-chip{padding:.75rem .25rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:12px;box-shadow:var(--shadow-chunky)}.learn-summary-chip-count{font-family:var(--font-display);font-size:1.75rem;line-height:1;color:rgb(var(--text))}.learn-summary-chip-label{font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:rgb(var(--text-muted));margin-top:.25rem}.learn-heatmap{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,12px);gap:3px;padding:1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:14px;box-shadow:var(--shadow-chunky);margin-bottom:2rem;overflow-x:auto}.learn-heatmap-cell{width:12px;height:12px;border-radius:2px;background:rgb(var(--border))}.learn-heatmap-cell--l1{background:var(--blue-light)}.learn-heatmap-cell--l2{background:#93c5fd}.learn-heatmap-cell--l3{background:var(--blue)}.learn-heatmap-cell--l4{background:var(--blue-deeper)}ruby.learn-furigana rt{font-size:.55em;font-weight:600;color:rgb(var(--text-muted))}.learn-review-cta{display:inline-flex;align-items:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:800;background:var(--yellow);color:rgb(var(--text));border:3px solid var(--yellow-dark);border-radius:14px;box-shadow:0 5px 0 var(--yellow-dark);cursor:pointer;margin-bottom:2rem;transition:all .1s}.learn-review-cta:hover{transform:translateY(2px);box-shadow:0 3px 0 var(--yellow-dark)}.learn-review-cta:active{transform:translateY(4px);box-shadow:0 1px 0 var(--yellow-dark)}.portal-nav-wordmark{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer;letter-spacing:inherit;line-height:inherit}.portal-nav-wordmark:hover{opacity:.85}.surface-switcher{position:relative;display:inline-block;margin-left:.35rem}.surface-switcher>summary{list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:8px;background:#ffffff14;color:#ffffffbf;font-size:.75rem;transition:background .1s,color .1s}.surface-switcher>summary::-webkit-details-marker{display:none}.surface-switcher>summary::marker{content:""}.surface-switcher>summary:hover{background:#ffffff29;color:#fff}.surface-switcher[open]>summary{background:#ffffff2e;color:#fff}.surface-switcher-menu{position:absolute;top:calc(100% + .5rem);left:-.25rem;z-index:200;min-width:14rem;padding:.5rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.08);border-radius:14px;box-shadow:var(--shadow-float);display:flex;flex-direction:column;gap:.25rem}.surface-switcher-item{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;padding:.65rem .85rem;background:transparent;border:2px solid transparent;border-radius:10px;color:rgb(var(--text));cursor:pointer;text-align:left;font:inherit;transition:all .1s}.surface-switcher-item:hover:not(:disabled){background:var(--blue-pale);border-color:var(--blue-light)}.surface-switcher-item.is-current{background:rgb(var(--bg));cursor:default}.surface-switcher-item:disabled{cursor:default}.surface-switcher-item-label{font-weight:800;font-size:.95rem}.surface-switcher-item-hint{font-size:.75rem;color:rgb(var(--text-muted));font-weight:500}.surface-switcher-item.is-current .surface-switcher-item-hint{color:var(--blue);font-weight:700}.learn-prose{max-width:44rem;margin:0 auto 3rem;line-height:1.65;color:rgb(var(--text));font-size:1rem}.learn-prose h1,.learn-prose h2,.learn-prose h3,.learn-prose h4{font-family:var(--font-display);color:rgb(var(--text));margin:1.75rem 0 .5rem;line-height:1.2}.learn-prose h2{font-size:1.5rem;margin-top:2.25rem;padding-bottom:.4rem;border-bottom:2px solid rgb(var(--border))}.learn-prose h3{font-size:1.2rem;margin-top:1.75rem}.learn-prose h4{font-size:1.05rem;margin-top:1.25rem}.learn-prose p{margin:.75rem 0}.learn-prose strong{font-weight:800;color:rgb(var(--text))}.learn-prose em{font-style:italic}.learn-prose code{font-family:var(--font-mono);font-size:.92em;background:rgb(var(--bg));padding:.1em .35em;border-radius:5px;border:1px solid rgb(var(--border))}.learn-prose pre{background:rgb(var(--bg));padding:1rem 1.25rem;border-radius:10px;border:2px solid rgb(var(--border));overflow-x:auto;font-size:.9rem;line-height:1.5;margin:1rem 0}.learn-prose pre code{background:transparent;padding:0;border:none;border-radius:0;font-size:inherit}.learn-prose ul,.learn-prose ol{margin:.75rem 0;padding-left:1.75rem}.learn-prose li{margin:.35rem 0}.learn-prose blockquote{margin:1rem 0;padding:.5rem 1rem;border-left:4px solid var(--blue);background:var(--blue-pale);color:rgb(var(--text));border-radius:0 8px 8px 0}.learn-prose blockquote p:first-child{margin-top:0}.learn-prose blockquote p:last-child{margin-bottom:0}.learn-prose a{color:var(--blue-dark);text-decoration:underline;text-underline-offset:.15em}.learn-prose a:hover{color:var(--blue-deeper)}.learn-prose table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.95rem;background:rgb(var(--surface));border:2px solid rgb(var(--border));border-radius:10px;overflow:hidden}.learn-prose thead{background:rgb(var(--bg))}.learn-prose th{text-align:left;font-weight:800;padding:.55rem .85rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em;color:rgb(var(--text-secondary));border-bottom:2px solid rgb(var(--border))}.learn-prose td{padding:.6rem .85rem;border-bottom:1px solid rgb(var(--border));vertical-align:top}.learn-prose tbody tr:last-child td{border-bottom:none}.learn-prose hr{border:none;border-top:2px solid rgb(var(--border));margin:2rem 0}.learn-reference-list{list-style:none;padding:0;margin:.5rem 0 2rem;display:flex;flex-direction:column;gap:.5rem}.learn-reference-list li{padding:.75rem 1rem;background:rgb(var(--surface));border:2px solid rgb(var(--border));border-radius:10px;font-size:.95rem}.learn-reference-list a{color:var(--blue-dark);text-decoration:underline;text-underline-offset:.15em}.learn-achievement-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(13rem,1fr));gap:.75rem;margin-bottom:2rem}.learn-achievement{display:flex;gap:.75rem;align-items:center;padding:.85rem 1rem;background:rgb(var(--surface));border:3px solid rgba(0,0,0,.06);border-radius:14px;box-shadow:var(--shadow-chunky);transition:all .15s}.learn-achievement--locked{opacity:.45}.learn-achievement--unlocked{border-color:var(--yellow)}.learn-achievement-icon{flex-shrink:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:10px;background:#fef3c7;color:var(--yellow-dark);font-family:var(--font-display);font-size:1.5rem;line-height:1}.learn-achievement--locked .learn-achievement-icon{background:rgb(var(--bg));color:rgb(var(--text-muted))}.learn-achievement-body{flex:1;min-width:0}.learn-achievement-title{font-weight:800;font-size:.95rem;color:rgb(var(--text));margin-bottom:.15rem}.learn-achievement-desc{font-size:.8rem;color:rgb(var(--text-secondary));line-height:1.3}.learn-achievement-points{flex-shrink:0;font-family:var(--font-display);font-size:.95rem;color:var(--blue);font-weight:800}.learn-achievement--locked .learn-achievement-points{color:rgb(var(--text-muted))}.dict-search-form{margin-bottom:1.5rem}.dict-search-bar{display:flex;align-items:stretch;gap:.5rem;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.4rem;transition:border-color .12s}.dict-search-bar:focus-within{border-color:var(--blue)}.dict-search-input{flex:1;border:none;outline:none;background:transparent;padding:.6rem .8rem;font:inherit;font-size:1.05rem;font-family:var(--font-body);color:rgb(var(--text))}.dict-search-input::placeholder{color:rgb(var(--text-muted))}.dict-search-modes{display:flex;gap:.25rem}.dict-mode-tab{background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:10px;padding:.4rem .7rem;font:inherit;font-size:.75rem;font-weight:700;color:rgb(var(--text-secondary));cursor:pointer;transition:all .1s}.dict-mode-tab:hover:not(:disabled){border-color:rgb(var(--text-secondary))}.dict-mode-tab.is-active{background:var(--blue-pale);border-color:var(--blue);color:var(--blue-deeper)}.dict-mode-tab.is-disabled,.dict-mode-tab:disabled{opacity:.5;cursor:not-allowed}.dict-results{display:flex;flex-direction:column;gap:1rem}.dict-card{background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:1.1rem 1.25rem;transition:box-shadow .12s,transform .12s}.dict-card:hover{box-shadow:var(--shadow-chunky);transform:translateY(-1px)}.dict-card--vocab{border-color:rgb(var(--border))}.dict-card--kanji{border-color:var(--yellow-dark)}.dict-card--grammar{border-color:var(--blue)}.dict-headword-strip{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.dict-headword-main{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}.dict-headword-glyph{background:none;border:none;padding:0;font:inherit;font-family:var(--font-display);font-size:1.85rem;font-weight:800;color:rgb(var(--text));cursor:pointer;line-height:1.2;text-align:left}.dict-headword-glyph:hover{color:var(--blue)}.dict-headword-glyph--grammar{font-size:1.55rem;font-family:var(--font-body)}.dict-headword-reading{font-size:1.1rem;color:rgb(var(--text-secondary));font-family:var(--font-body)}.dict-audio-btn{background:none;border:2px solid rgb(var(--border));border-radius:8px;width:1.8rem;height:1.8rem;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;color:rgb(var(--text-muted));cursor:pointer;padding:0}.dict-audio-btn:disabled{opacity:.4;cursor:not-allowed}.dict-headword-badges{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}.dict-pos{margin:0 0 .5rem;font-size:.78rem;font-style:italic;color:rgb(var(--text-secondary));letter-spacing:.02em}.dict-sense-list{margin:0 0 .85rem;padding-left:1.4rem;list-style-type:decimal}.dict-sense{margin-bottom:.2rem;line-height:1.5;color:rgb(var(--text));font-size:.95rem}.dict-conjugation-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:10px;padding:.55rem;margin:.5rem 0 .85rem}.dict-conjugation-cell{display:flex;flex-direction:column;gap:.15rem;text-align:center;padding:.2rem .1rem}.dict-conjugation-label{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:rgb(var(--text-muted))}.dict-conjugation-value{font-family:var(--font-body);font-size:.95rem;font-weight:600;color:rgb(var(--text))}@media(max-width:480px){.dict-conjugation-strip{grid-template-columns:repeat(2,1fr)}}.dict-section-title{margin:0 0 .4rem;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.dict-examples{margin:.85rem 0 0}.dict-example-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.dict-example{display:flex;gap:.6rem;padding:.55rem .6rem;background:rgb(var(--bg));border:1px solid rgb(var(--border));border-radius:8px}.dict-example-difficulty{flex-shrink:0;font-size:.75rem;color:rgb(var(--text-muted));line-height:1.4;width:1rem;text-align:center}.dict-example--easy .dict-example-difficulty{color:var(--green)}.dict-example--medium .dict-example-difficulty{color:var(--yellow-dark)}.dict-example--hard .dict-example-difficulty{color:rgb(var(--text-secondary))}.dict-example-body{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.dict-example-jp{font-family:var(--font-body);font-size:.95rem;color:rgb(var(--text));line-height:1.6}.dict-example-en{font-size:.82rem;color:rgb(var(--text-secondary));font-style:italic;line-height:1.4}.dict-kanji-row{margin:.85rem 0 0}.dict-kanji-cards{display:flex;flex-wrap:wrap;gap:.5rem}.dict-kanji-mini-card{display:inline-flex;flex-direction:column;align-items:center;gap:.3rem;padding:.55rem .7rem;background:#fff;border:2px solid rgb(var(--border));border-radius:10px;cursor:pointer;transition:all .12s;font:inherit;min-width:4rem}.dict-kanji-mini-card:hover{border-color:var(--blue);transform:translateY(-1px)}.dict-kanji-mini-glyph{font-family:var(--font-display);font-size:1.6rem;line-height:1;color:rgb(var(--text))}.dict-kanji-mini-meta{display:flex;gap:.2rem;flex-wrap:wrap;justify-content:center}.dict-kanji-mini-meanings{font-size:.7rem;color:rgb(var(--text-muted));text-align:center;font-style:italic}.dict-kanji-header{display:flex;gap:1rem;margin-bottom:.85rem;align-items:stretch}.dict-kanji-glyph-box{flex-shrink:0;width:5rem;height:5rem;display:flex;align-items:center;justify-content:center;background:#fff;border:3px solid var(--yellow-dark);border-radius:12px;font-family:var(--font-display);font-size:3.2rem;line-height:1;color:rgb(var(--text));cursor:pointer;padding:0;transition:transform .12s}.dict-kanji-glyph-box:hover{transform:scale(1.04)}.dict-kanji-header-meta{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.5rem;min-width:0}.dict-kanji-meaning{margin:0;font-size:1.05rem;font-weight:700;color:rgb(var(--text));line-height:1.3}.dict-kanji-facts{display:flex;gap:.35rem;flex-wrap:wrap}.dict-kanji-readings{margin:.5rem 0 .85rem;display:flex;flex-direction:column;gap:.3rem}.dict-kanji-reading-row{display:flex;gap:.6rem;align-items:baseline;font-size:.92rem}.dict-reading-label{flex-shrink:0;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:rgb(var(--text-muted));width:2rem}.dict-reading-list{color:rgb(var(--text));font-family:var(--font-body)}.dict-kanji-words{margin:.85rem 0 0}.dict-kanji-word-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.2rem}.dict-kanji-word-row{display:flex;gap:.5rem;align-items:baseline;flex-wrap:wrap;width:100%;text-align:left;background:none;border:none;border-radius:6px;padding:.3rem .5rem;font:inherit;cursor:pointer;transition:background .1s}.dict-kanji-word-row:hover{background:rgb(var(--bg))}.dict-kanji-word-jp{font-weight:700;color:rgb(var(--text))}.dict-kanji-word-reading{color:rgb(var(--text-secondary));font-size:.88rem}.dict-kanji-word-gloss{color:rgb(var(--text-secondary));font-size:.88rem;font-style:italic}.dict-grammar-meaning{margin:.4rem 0 .5rem;font-size:.95rem;color:rgb(var(--text));line-height:1.5}.dict-grammar-form{margin:.3rem 0 .55rem;display:flex;gap:.5rem;align-items:baseline;flex-wrap:wrap;font-size:.9rem}.dict-grammar-form-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:rgb(var(--text-muted))}.dict-grammar-form-value{font-family:var(--font-mono);color:rgb(var(--text));font-size:.92rem}.dict-grammar-link{background:none;border:none;padding:0;font:inherit;font-size:.88rem;font-weight:700;color:var(--blue);cursor:pointer;margin-top:.25rem}.dict-grammar-link:hover{text-decoration:underline}.dict-results-shell{display:block}.dict-results-main{min-width:0}@media(min-width:880px){.dict-results-shell.has-draw-rail{display:grid;grid-template-columns:320px 1fr;gap:1.25rem;align-items:start}.dict-draw-rail{position:sticky;top:1rem;background:#fff;border:3px solid var(--blue);border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.85rem}}@media(max-width:879px){.dict-draw-rail{position:fixed;left:0;right:0;bottom:0;z-index:60;background:#fff;border-top:3px solid var(--blue);border-radius:16px 16px 0 0;box-shadow:0 -8px 30px #0000002e;padding:.85rem 1rem 1.25rem;max-height:80vh;overflow-y:auto;animation:dict-draw-rail-rise .2s ease-out}}@keyframes dict-draw-rail-rise{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dict-draw-rail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.dict-draw-rail-close{background:none;border:2px solid rgb(var(--border));border-radius:8px;width:1.8rem;height:1.8rem;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;color:rgb(var(--text-secondary));cursor:pointer;padding:0}.dict-draw-rail-close:hover{border-color:rgb(var(--text-secondary));color:rgb(var(--text))}.dict-draw-rail-hint{margin:.6rem 0 0;font-size:.78rem;line-height:1.4}.learn-candidate-chip--clickable{background:#fff;border:2px solid rgb(var(--border));border-radius:10px;padding:.35rem .55rem;cursor:pointer;font:inherit;display:inline-flex;flex-direction:column;align-items:center;gap:.15rem;transition:all .1s;min-width:2.6rem}.learn-candidate-chip--clickable:hover{border-color:var(--blue);background:var(--blue-pale);transform:translateY(-1px)}.learn-candidate-chip--clickable:active{transform:translateY(0)}.dict-card--sentence{border-color:var(--purple)}.dict-sentence-header{margin-bottom:.5rem}.dict-sentence-original{margin:0 0 .85rem;font-size:1.15rem;line-height:1.6;color:rgb(var(--text));padding:.6rem .75rem;background:rgb(var(--bg));border-radius:8px}.dict-token-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.25rem}.dict-token-row{display:grid;grid-template-columns:minmax(2.5rem,auto) minmax(0,1fr) minmax(4.5rem,auto) minmax(0,2fr) auto;gap:.6rem;align-items:baseline;padding:.45rem .6rem;background:#fff;border:1px solid rgb(var(--border));border-radius:8px;font-size:.9rem}.dict-token-row:hover{border-color:var(--purple)}.dict-token-surface{font-weight:700;color:rgb(var(--text));font-size:.98rem}.dict-token-reading{color:rgb(var(--text-secondary));font-size:.82rem;font-family:var(--font-body)}.dict-token-pos{font-style:italic;font-size:.78rem;color:rgb(var(--text-muted));letter-spacing:.02em}.dict-token-gloss{color:rgb(var(--text));font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dict-token-gloss--empty{color:rgb(var(--text-muted))}.dict-token-link{background:none;border:2px solid rgb(var(--border));border-radius:8px;width:1.8rem;height:1.8rem;display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--blue);cursor:pointer;padding:0;font-weight:700;transition:all .1s}.dict-token-link:hover{border-color:var(--blue);background:var(--blue-pale)}.dict-token-link--disabled{border-style:dashed;color:rgb(var(--text-muted));cursor:default;font-weight:400}@media(max-width:640px){.dict-token-row{grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:.3rem .6rem}.dict-token-pos{grid-column:1 / 2;grid-row:2}.dict-token-gloss{grid-column:2 / 3;grid-row:2;white-space:normal}.dict-token-link{grid-column:3;grid-row:1 / 3;align-self:center}}.dict-draw-rail--inline{position:static;margin:1rem 0 1.25rem;max-width:28rem}.learn-candidate-chip--top{background:var(--blue-pale);border-color:var(--blue);color:var(--blue-deeper)}.learn-candidate-chip--top .learn-candidate-rank{font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--blue)}.learn-candidate-chip--clickable.learn-candidate-chip--top:hover{background:var(--blue-pale);filter:brightness(.97)}.word-audio-btn{display:inline-flex;align-items:center;justify-content:center;background:#fff;border:2px solid var(--blue);border-radius:8px;color:var(--blue);cursor:pointer;padding:0;transition:transform .1s,background .12s,color .12s,border-color .12s;box-shadow:0 2px 0 0 var(--blue)}.word-audio-btn--md{width:1.85rem;height:1.85rem}.word-audio-btn--sm{width:1.4rem;height:1.4rem}.word-audio-btn:hover:not(:disabled){background:var(--blue);color:#fff;transform:translateY(-1px);box-shadow:0 3px 0 0 var(--blue-deeper)}.word-audio-btn:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 0 0 var(--blue-deeper)}.word-audio-btn--playing{background:var(--blue);color:#fff}.word-audio-btn--missing,.word-audio-btn--error{border-color:rgb(var(--border));color:rgb(var(--text-muted));box-shadow:0 2px rgb(var(--border));cursor:not-allowed;opacity:.55}.word-audio-icon{display:block}.word-audio-icon--spin{animation:word-audio-spin .8s linear infinite}@keyframes word-audio-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dict-kanji-word-row-wrap{display:flex;align-items:center;gap:.4rem}.dict-kanji-word-row-wrap .dict-kanji-word-row{flex:1;min-width:0}.research-section{margin:1.5rem 0;padding:1rem 1.1rem;background:rgb(var(--bg));border:2px dashed rgb(var(--border));border-radius:12px}.research-section--loading{border-style:dashed;opacity:.85}.research-section-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem;flex-wrap:wrap;margin-bottom:.5rem}.research-source-pill{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted));background:#fff;border:1.5px solid rgb(var(--border));border-radius:6px;padding:.18rem .45rem;cursor:help}.research-citation-list{margin:.4rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.7rem}.research-citation{background:#fff;border:1px solid rgb(var(--border));border-radius:8px;padding:.65rem .75rem}.research-citation-line{margin:0;line-height:1.45;font-size:.9rem;color:rgb(var(--text))}.research-citation-authors{font-weight:700}.research-citation-year{color:rgb(var(--text-secondary))}.research-citation-title{font-style:italic;color:rgb(var(--text))}.research-citation-venue{color:rgb(var(--text-secondary))}.research-citation-snippet{margin:.4rem 0 0;font-size:.83rem;line-height:1.5;color:rgb(var(--text-secondary))}.research-citation-snippet-toggle{appearance:none;background:none;border:none;padding:0;margin:0;font:inherit;font-size:inherit;color:var(--blue);cursor:pointer;text-decoration:none;white-space:nowrap}.research-citation-snippet-toggle:hover,.research-citation-snippet-toggle:focus-visible{text-decoration:underline;outline:none}.research-citation-doi{display:inline-block;margin-top:.4rem;font-family:var(--font-mono);font-size:.78rem;color:var(--blue);text-decoration:none}.research-citation-doi:hover{text-decoration:underline}.research-section-footnote{margin:.7rem 0 0;font-size:.72rem;font-style:italic;line-height:1.45}.research-overview{display:grid;grid-template-columns:repeat(3,1fr) minmax(0,auto);gap:1rem;align-items:center;background:#fff;border:3px solid var(--blue);border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:1rem 1.25rem;margin-bottom:.5rem}@media(max-width:640px){.research-overview{grid-template-columns:1fr 1fr}.research-overview-source{grid-column:1 / -1}}.research-overview-stat{display:flex;flex-direction:column;gap:.25rem}.research-overview-value{font-family:var(--font-display);font-size:1.7rem;line-height:1;color:rgb(var(--text))}.research-overview-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.research-overview-source{display:flex;justify-content:flex-end}.research-cluster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:.85rem;margin-top:.5rem}.research-cluster-card{display:flex;flex-direction:column;gap:.35rem;text-align:left;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.95rem 1rem;cursor:pointer;font:inherit;transition:transform .1s,border-color .12s,box-shadow .12s;min-height:6rem}.research-cluster-card:hover:not(:disabled){border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-chunky)}.research-cluster-card:disabled{opacity:.5;cursor:not-allowed}.research-cluster-label{font-family:var(--font-display);font-size:1.1rem;color:rgb(var(--text));line-height:1.2}.research-cluster-count{font-size:.85rem;font-weight:700;color:var(--blue)}.research-cluster-subdomains{font-size:.72rem;color:rgb(var(--text-muted));font-family:var(--font-mono)}.research-citation-topic-pill{margin-bottom:.4rem}.research-citation-topic-link{background:rgb(var(--bg));border:1.5px solid rgb(var(--border));border-radius:6px;padding:.15rem .45rem;font:inherit;font-family:var(--font-mono);font-size:.7rem;color:rgb(var(--text-secondary));cursor:pointer;transition:all .1s}.research-citation-topic-link:hover{border-color:var(--blue);color:var(--blue)}.research-timeline-link{background:none;border:none;padding:0;font:inherit;font-size:.85rem;font-weight:700;color:var(--blue);cursor:pointer;margin-top:.5rem}.research-timeline-link:hover{text-decoration:underline}.research-search-form{display:flex;align-items:stretch;gap:.5rem;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.4rem;transition:border-color .12s;margin-bottom:1.25rem}.research-search-form:focus-within{border-color:var(--blue)}.research-search-input{flex:1;border:none;outline:none;background:transparent;padding:.6rem .8rem;font:inherit;font-size:1rem;color:rgb(var(--text))}.research-search-input::placeholder{color:rgb(var(--text-muted))}.research-search-kind{background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:10px;padding:0 .7rem;font:inherit;font-size:.85rem;color:rgb(var(--text-secondary));cursor:pointer}.research-search-submit{background:var(--blue);color:#fff;border:2px solid var(--blue);border-radius:10px;padding:.4rem 1rem;font:inherit;font-size:.9rem;font-weight:800;cursor:pointer;box-shadow:0 2px 0 0 var(--blue-deeper);transition:transform .1s}.research-search-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 0 0 var(--blue-deeper)}.research-search-submit:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 0 0 var(--blue-deeper)}.research-search-submit:disabled{opacity:.45;cursor:not-allowed}.research-search-results{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:880px){.research-search-results{grid-template-columns:16rem 1fr}}.research-search-facets{background:rgb(var(--bg));border:2px dashed rgb(var(--border));border-radius:12px;padding:.85rem 1rem;align-self:start}.research-facet-list{margin:.4rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.3rem}.research-facet-row{display:flex;justify-content:space-between;gap:.5rem;align-items:baseline;font-size:.83rem;background:#fff;border:1px solid rgb(var(--border));border-radius:6px;padding:.25rem .5rem}.research-facet-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:rgb(var(--text))}.research-facet-count{flex-shrink:0;font-family:var(--font-mono);font-size:.78rem;font-weight:700;color:var(--blue)}.research-search-meta{margin:0 0 .5rem;font-size:.85rem}.research-facet-row--clickable{font:inherit;cursor:pointer;width:100%;text-align:left;transition:border-color .1s,transform .1s,background .1s}.research-facet-row--clickable:hover{border-color:var(--blue);transform:translateY(-1px);background:#fff}.research-facet-row--clickable:active{transform:translateY(0)}.research-citation-meta-pill{display:inline-block;font-size:.7rem;font-weight:700;font-family:var(--font-mono);color:rgb(var(--text-muted));background:#fff;border:1px solid rgb(var(--border));border-radius:5px;padding:.12rem .4rem;margin-left:.35rem}.research-citation-meta-pill--ja{color:var(--blue-deeper);border-color:var(--blue);background:var(--blue-pale);font-family:var(--font-body)}.research-citation-topic-pill{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;margin-bottom:.4rem}.research-jp-filter{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.55rem .85rem;margin:1rem 0 .6rem;transition:border-color .12s}.research-jp-filter:focus-within{border-color:var(--blue)}.research-jp-filter-label{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.9rem;color:rgb(var(--text));cursor:pointer;-webkit-user-select:none;user-select:none}.research-jp-filter-checkbox{width:1.05rem;height:1.05rem;cursor:pointer;accent-color:var(--blue)}.research-jp-filter-hint{font-size:.82rem;color:rgb(var(--text-muted));flex:1;min-width:14rem}.research-jp-filter-hint strong{color:rgb(var(--text));font-weight:700}.research-filterbar{display:flex;align-items:stretch;gap:.6rem;flex-wrap:wrap;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.4rem;margin:1rem 0 1.25rem;transition:border-color .12s}.research-filterbar:focus-within{border-color:var(--blue)}.research-filterbar-search{flex:1;min-width:12rem;border:none;outline:none;background:transparent;padding:.55rem .75rem;font:inherit;font-size:.95rem;color:rgb(var(--text))}.research-filterbar-search::placeholder{color:rgb(var(--text-muted))}.research-filterbar-sort{display:inline-flex;align-items:center;gap:.35rem;background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:10px;padding:0 .55rem}.research-filterbar-sort-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.research-filterbar-sort-select{background:transparent;border:none;outline:none;font:inherit;font-size:.85rem;color:rgb(var(--text));cursor:pointer;padding:.35rem .2rem}.learn-grammar-card-wrap{position:relative;display:block}.learn-grammar-card-wrap>.learn-grammar-card{width:100%;height:100%;padding-right:2.6rem}.learn-grammar-card-audio{position:absolute;top:.55rem;right:.55rem;z-index:1}.dict-token-actions{display:inline-flex;align-items:center;gap:.35rem;justify-self:end}.reader-filterbar{display:flex;align-items:stretch;gap:.6rem;flex-wrap:wrap;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.4rem;margin:.6rem 0 1rem;transition:border-color .12s}.reader-filterbar:focus-within{border-color:var(--blue)}.reader-difficulty-chips{display:inline-flex;gap:.25rem;align-self:center}.reader-difficulty-chip{background:rgb(var(--bg));border:2px solid rgb(var(--border));border-radius:8px;padding:.4rem .65rem;font:inherit;font-size:.78rem;font-weight:700;color:rgb(var(--text-secondary));cursor:pointer;transition:all .1s}.reader-difficulty-chip:hover{border-color:rgb(var(--text-secondary));color:rgb(var(--text))}.reader-difficulty-chip.is-active{background:var(--blue-pale);border-color:var(--blue);color:var(--blue-deeper)}.reader-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:.85rem}.reader-spotlight{display:block;width:100%;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:.9rem 1.1rem 1rem;margin-top:1rem;text-align:left;cursor:pointer;font:inherit;transition:transform .1s,border-color .12s,box-shadow .12s}.reader-spotlight:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-chunky)}.reader-spotlight-tag{display:inline-block;font-family:var(--font-mono);font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgb(var(--text-muted));background:rgb(var(--bg-muted));border:1.5px solid rgb(var(--border));border-radius:999px;padding:.18rem .55rem;margin-bottom:.55rem}.reader-spotlight-body{display:grid;grid-template-columns:76px 1fr auto;gap:1rem;align-items:center}.reader-spotlight-cover{width:76px;height:92px;border:2.5px solid rgb(var(--border));border-radius:8px;background:linear-gradient(140deg,#fef3c7,#fde68a);display:grid;place-items:center;font-family:var(--font-display);font-size:2.3rem;color:rgb(var(--text))}.reader-spotlight-title{font-family:var(--font-display);font-size:1.4rem;margin:0;line-height:1.1;color:rgb(var(--text))}.reader-spotlight-author{margin:.15rem 0 .35rem;font-size:.85rem;font-weight:600;color:rgb(var(--text-secondary))}.reader-spotlight-blurb{margin:0 0 .5rem;font-size:.85rem;color:rgb(var(--text-secondary));line-height:1.4}.reader-spotlight-meta{display:flex;align-items:center;gap:.45rem;font-size:.72rem;color:rgb(var(--text-muted))}.reader-spotlight-chars,.reader-spotlight-year{font-family:var(--font-mono)}.reader-spotlight-cta{align-self:center;font-family:var(--font-display);font-size:1rem;color:var(--blue);font-weight:700;white-space:nowrap}@media(max-width:720px){.reader-spotlight-body{grid-template-columns:56px 1fr}.reader-spotlight-cover{width:56px;height:70px;font-size:1.7rem}.reader-spotlight-cta{grid-column:1 / -1;text-align:right;margin-top:.3rem}}.reader-spotlight-cover--image{background:rgb(var(--surface-2));object-fit:cover;display:block;padding:0}.reader-featured-section{margin-top:1.5rem}.reader-featured-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.75rem}.reader-featured-label{font-family:var(--font-display);font-size:1.15rem;margin:0;letter-spacing:.04em;text-transform:uppercase;color:rgb(var(--text))}.reader-featured-count{font-size:.75rem;font-weight:700;color:rgb(var(--text-muted));text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono)}.reader-featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem}@media(max-width:480px){.reader-featured-grid{grid-template-columns:1fr}}.reader-collections-rail{display:flex;gap:.7rem;overflow-x:auto;padding:.3rem .15rem .6rem;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.reader-collection-card{flex:0 0 13.5rem;min-height:9.5rem;display:flex;flex-direction:column;gap:.2rem;padding:.85rem .95rem .95rem;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);text-align:left;cursor:pointer;font:inherit;scroll-snap-align:start;position:relative;transition:transform .1s,border-color .12s,box-shadow .12s,background .12s}.reader-collection-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-chunky)}.reader-collection-card.is-active{background:rgb(var(--bg-muted));border-color:var(--blue);box-shadow:var(--shadow-chunky)}.reader-collection-stamp{align-self:flex-start;width:1.85rem;height:1.85rem;border:2px solid rgb(var(--border));border-radius:6px;background:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:1.2rem;color:rgb(var(--text));margin-bottom:.35rem}.reader-collection-card.is-active .reader-collection-stamp{background:var(--blue);border-color:var(--blue);color:#fff}.reader-collection-name{font-family:var(--font-display);font-size:1.05rem;line-height:1.2;color:rgb(var(--text))}.reader-collection-blurb{font-size:.8rem;color:rgb(var(--text-secondary));line-height:1.35;margin-top:.1rem}.reader-collection-kind{margin-top:auto;align-self:flex-start;font-family:var(--font-mono);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgb(var(--text-muted));border:1.5px solid rgb(var(--border));border-radius:999px;padding:.12rem .45rem;background:rgb(var(--bg-muted))}.reader-collection-card--add{border-style:dashed;background:transparent;box-shadow:none;display:grid;place-items:center;text-align:center;color:rgb(var(--text-muted))}.reader-collection-card--add:hover{border-color:var(--blue);color:rgb(var(--text));background:rgb(var(--bg-muted))}.reader-collection-card--add .reader-collection-name{color:inherit}.reader-collection-card--add .reader-collection-blurb{color:inherit;opacity:.7}.reader-collection-card-add-plus{font-family:var(--font-display);font-size:2rem;line-height:1;color:rgb(var(--text-muted))}.reader-open-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem;align-items:flex-start}.reader-save-popover-host{position:relative;display:inline-block}.reader-save-btn{font-family:var(--font-display)}.reader-save-btn.is-saved{border-color:var(--blue);color:var(--blue-deeper)}.reader-save-popover{position:absolute;top:calc(100% + .4rem);right:0;z-index:50;min-width:18rem;max-width:22rem;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky);padding:.7rem .8rem .8rem}.reader-save-popover-head{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-size:.95rem;margin-bottom:.5rem;color:rgb(var(--text))}.reader-save-popover-list{list-style:none;margin:0 0 .6rem;padding:0;max-height:14rem;overflow-y:auto}.reader-save-popover-list li{margin:0;padding:0}.reader-save-popover-row{appearance:none;background:transparent;border:2px solid transparent;border-radius:8px;padding:.4rem .55rem;width:100%;display:flex;align-items:center;gap:.5rem;font:inherit;text-align:left;cursor:pointer}.reader-save-popover-row:hover{background:rgb(var(--bg-muted))}.reader-save-popover-row.is-saved{border-color:var(--blue);background:rgb(var(--bg-muted))}.reader-save-popover-stamp{width:1.6rem;height:1.6rem;border:1.5px solid rgb(var(--border));border-radius:5px;display:grid;place-items:center;font-family:var(--font-display);font-size:.95rem;background:#fff}.reader-save-popover-name{flex:1;font-weight:700;font-size:.9rem}.reader-save-popover-count{font-family:var(--font-mono);font-size:.75rem;color:rgb(var(--text-muted))}.reader-save-popover-row.is-saved .reader-save-popover-count{color:var(--blue-deeper);font-weight:700}.reader-save-popover-new{appearance:none;background:transparent;border:2px dashed rgb(var(--border));border-radius:8px;padding:.4rem .6rem;width:100%;font:inherit;font-family:var(--font-display);color:rgb(var(--text-muted));cursor:pointer}.reader-save-popover-new:hover{border-color:var(--blue);color:var(--blue)}.reader-save-popover-create{display:flex;flex-direction:column;gap:.4rem}.reader-collection-breadcrumb{display:flex;align-items:center;gap:.45rem;font-size:.9rem;color:rgb(var(--text-secondary));margin:.5rem 0 1rem;flex-wrap:wrap}.reader-collection-breadcrumb-sep{color:rgb(var(--text-muted))}.btn-link-quiet{appearance:none;background:transparent;border:none;padding:0;font:inherit;color:inherit;cursor:pointer;text-decoration:underline;text-decoration-color:#00000026;text-underline-offset:3px}.btn-link-quiet:hover{color:var(--blue-deeper)}.reader-collection-hero{display:grid;grid-template-columns:96px 1fr auto;gap:1.2rem;align-items:center;background:rgb(var(--bg-muted));border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:1rem 1.25rem}.reader-collection-hero-cover{width:96px;height:96px;border:3px solid rgb(var(--border));border-radius:12px;background:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:2.6rem;color:rgb(var(--text))}.reader-collection-hero-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted));margin-bottom:.3rem}.reader-collection-hero-title{font-family:var(--font-display);font-size:1.75rem;margin:0 0 .25rem;line-height:1.1;color:rgb(var(--text))}.reader-collection-hero-desc{margin:0;font-size:.95rem;color:rgb(var(--text-secondary));line-height:1.45}.reader-collection-hero-actions{display:flex;flex-direction:column;gap:.4rem;align-items:stretch}@media(max-width:720px){.reader-collection-hero{grid-template-columns:64px 1fr}.reader-collection-hero-cover{width:64px;height:64px;font-size:1.8rem}.reader-collection-hero-actions{grid-column:1 / -1;flex-direction:row}}.reader-vis-pill{display:inline-block;padding:.05rem .4rem;border-radius:4px;border:1.5px solid rgb(var(--border));background:#fff;font-family:var(--font-body);font-size:.62rem;font-weight:700;letter-spacing:.04em}.reader-vis-pill--private{color:rgb(var(--text-muted))}.reader-vis-pill--unlisted{color:var(--blue-deeper);border-color:var(--blue);background:#dbeafe}.reader-vis-pill--public{color:var(--green-dark);border-color:var(--green);background:#dcfce7}.reader-collection-edit-card{margin-top:1rem;background:#fff;border:3px solid rgb(var(--border));border-radius:14px;box-shadow:var(--shadow-chunky-sm);padding:1rem 1.25rem 1.1rem}.reader-collection-delete-btn{margin-left:auto;color:var(--red);border-color:var(--red)}.reader-collection-siblings{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:1.1rem;font-size:.78rem;color:rgb(var(--text-muted))}.reader-collection-siblings-label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.reader-collection-sibling-chip{appearance:none;background:#fff;border:2px solid rgb(var(--border));border-radius:999px;padding:.25rem .7rem;display:inline-flex;align-items:center;gap:.35rem;font:inherit;font-size:.85rem;color:rgb(var(--text));cursor:pointer}.reader-collection-sibling-chip:hover{border-color:var(--blue)}.reader-collection-sibling-chip--add{border-style:dashed;color:rgb(var(--text-muted))}.reader-work-card-wrap{position:relative;display:block;width:100%;height:100%}.reader-work-card-wrap>.reader-work-card{width:100%;height:100%}.reader-work-card-controls{position:absolute;top:.4rem;right:.4rem;display:flex;gap:.2rem;background:#fffffff2;border-radius:6px;padding:.15rem;border:1.5px solid rgb(var(--border));opacity:0;transition:opacity .1s}.reader-work-card-wrap:hover .reader-work-card-controls,.reader-work-card-wrap:focus-within .reader-work-card-controls{opacity:1}.reader-work-card--missing{display:flex;flex-direction:column;gap:.4rem;background:#fff;border:3px dashed rgb(var(--border));border-radius:12px;padding:.85rem 1rem;align-items:flex-start}.profile-tab-strip{display:flex;gap:.4rem;margin:1.25rem 0 0;border-bottom:2px solid rgb(var(--border));flex-wrap:wrap}.profile-tab{appearance:none;background:transparent;border:none;padding:.55rem 1rem;font:inherit;font-family:var(--font-display);font-size:.95rem;color:rgb(var(--text-muted));cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .12s,border-color .12s}.profile-tab:hover{color:rgb(var(--text))}.profile-tab.is-active{color:rgb(var(--text));border-bottom-color:var(--blue)}.profile-section-subtitle{font-family:var(--font-display);font-size:1.1rem;margin:1.5rem 0 .6rem;color:rgb(var(--text))}.profile-learning-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(9rem,1fr));gap:.7rem;margin-bottom:1rem}.profile-learning-tile{background:#fff;border:3px solid rgb(var(--border));border-radius:12px;padding:.7rem .85rem;box-shadow:var(--shadow-chunky-sm)}.profile-learning-tile.is-clickable{cursor:pointer;transition:transform .12s,border-color .12s}.profile-learning-tile.is-clickable:hover{border-color:var(--blue);transform:translateY(-2px)}.profile-learning-tile-value{font-family:var(--font-display);font-size:1.6rem;color:rgb(var(--text));line-height:1}.profile-learning-tile-label{margin-top:.25rem;font-size:.75rem;color:rgb(var(--text-muted))}.profile-learning-actions{margin-top:.5rem;display:flex;gap:.5rem}.profile-learning-ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:.5rem}.profile-learning-ach{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;background:#fff;border:2px solid rgb(var(--border));border-radius:10px;opacity:.55}.profile-learning-ach.is-unlocked{opacity:1;border-color:var(--green);background:#f0fdf4}.profile-learning-ach-icon{font-size:1.4rem;width:2rem;text-align:center}.profile-learning-ach-body{flex:1;min-width:0}.profile-learning-ach-title{font-family:var(--font-display);font-size:.95rem;line-height:1.2;color:rgb(var(--text))}.profile-learning-ach-desc{font-size:.78rem;color:rgb(var(--text-muted));margin-top:.1rem}.profile-learning-ach-points{font-family:var(--font-mono);font-size:.7rem;font-weight:700;color:var(--green-dark);background:#fff;border:1.5px solid var(--green);border-radius:999px;padding:.1rem .45rem}.profile-learning-ach:not(.is-unlocked) .profile-learning-ach-points{color:rgb(var(--text-muted));border-color:rgb(var(--border))}.profile-collections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(13rem,1fr));gap:.7rem;margin-top:.6rem}.profile-collection-card{appearance:none;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.85rem 1rem;text-align:left;cursor:pointer;font:inherit;display:flex;flex-direction:column;gap:.3rem;transition:transform .12s,border-color .12s,box-shadow .12s}.profile-collection-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-chunky)}.profile-collection-stamp{align-self:flex-start;width:1.85rem;height:1.85rem;border:2px solid rgb(var(--border));border-radius:6px;display:grid;place-items:center;font-family:var(--font-display);font-size:1.1rem;background:rgb(var(--bg-muted));margin-bottom:.2rem}.profile-collection-name{font-family:var(--font-display);font-size:1.05rem;line-height:1.2;color:rgb(var(--text))}.profile-collection-meta{font-size:.75rem;color:rgb(var(--text-muted));display:flex;gap:.3rem;align-items:center;flex-wrap:wrap}.reader-work-card{display:flex;flex-direction:column;gap:.3rem;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.85rem 1rem;text-align:left;cursor:pointer;font:inherit;transition:transform .1s,border-color .12s,box-shadow .12s}.reader-work-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-chunky)}.reader-work-card-title{font-family:var(--font-display);font-size:1.05rem;color:rgb(var(--text));line-height:1.25}.reader-work-card-author{font-size:.82rem;color:rgb(var(--text-secondary));font-weight:600}.reader-work-card-meta{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:rgb(var(--text-muted));margin-top:.15rem}.reader-work-card-chars,.reader-work-card-year{font-family:var(--font-mono)}.reader-work-card--with-cover{flex-direction:row;align-items:stretch;gap:.7rem;padding:.7rem .85rem}.reader-work-card-cover{width:56px;height:84px;flex:0 0 auto;object-fit:cover;border:2px solid rgb(var(--border));border-radius:6px;background:rgb(var(--surface-2));display:block}.reader-work-card-text{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.reader-difficulty-pill{display:inline-block;padding:.1rem .4rem;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;border-radius:5px;border:1.5px solid rgb(var(--border));background:#fff;color:rgb(var(--text-muted));font-family:var(--font-body)}.reader-difficulty-pill--easy{border-color:var(--green);background:#dcfce7;color:var(--green-dark)}.reader-difficulty-pill--medium{border-color:var(--yellow-dark);background:#fef3c7;color:var(--yellow-dark)}.reader-difficulty-pill--hard{border-color:var(--red);background:#fee2e2;color:#991b1b}.reader-author-row{display:flex;flex-wrap:wrap;gap:.5rem}.reader-author-chip{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.2rem;background:#fff;border:2px solid rgb(var(--border));border-radius:10px;padding:.5rem .75rem;font:inherit;cursor:pointer;transition:all .1s}.reader-author-chip:hover{border-color:var(--blue);transform:translateY(-1px)}.reader-author-chip-name{font-weight:800;color:rgb(var(--text));font-size:.92rem}.reader-author-chip-count{font-size:.68rem;color:rgb(var(--text-muted));font-family:var(--font-mono)}.reader-work-detail{max-width:36rem;margin:0 auto}.reader-work-detail-header--with-cover{display:grid;grid-template-columns:120px 1fr;gap:1rem;align-items:start}.reader-work-detail-cover{width:120px;height:180px;object-fit:cover;border:3px solid rgb(var(--border));border-radius:10px;box-shadow:var(--shadow-chunky-sm);display:block;background:rgb(var(--surface-2))}.reader-work-detail-headtext{min-width:0}@media(max-width:480px){.reader-work-detail-header--with-cover{grid-template-columns:84px 1fr}.reader-work-detail-cover{width:84px;height:126px}}.reader-work-meta{display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1rem;margin:1rem 0 1.5rem;font-size:.92rem}.reader-work-meta dt{font-weight:800;color:rgb(var(--text-muted));font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}.reader-work-meta dd{margin:0;color:rgb(var(--text))}.reader-open-cta{font-size:1.05rem!important;padding:.85rem 1.5rem!important}.reader-viewer-shell{display:flex;flex-direction:column;height:calc(100dvh - var(--portal-nav-height, 4.5rem));width:100%}.reader-topbar,.reader-bottombar{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.5rem 1rem;background:#fff;border-bottom:2px solid rgb(var(--border));flex-shrink:0;font-size:.85rem}.reader-bottombar{border-bottom:none;border-top:2px solid rgb(var(--border))}.reader-topbar-title{flex:1;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-topbar-actions{display:inline-flex;gap:.4rem}.reader-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;background:#fff;border:2px solid rgb(var(--border));border-radius:8px;font:inherit;font-weight:700;font-size:.95rem;color:rgb(var(--text-secondary));cursor:pointer;transition:all .1s}.reader-icon-btn:hover{border-color:var(--blue);color:var(--blue)}.reader-bottombar-meta{font-family:var(--font-mono);font-size:.75rem;color:rgb(var(--text-muted))}.reader-article{flex:1 1 0;min-height:0;padding:1.5rem 2rem;background:rgb(var(--surface));color:rgb(var(--text));scrollbar-width:thin}.reader-article--horizontal{writing-mode:horizontal-tb;overflow-y:auto;overflow-x:hidden}.reader-article--horizontal .reader-prose{max-width:var(--reader-max-width, 36rem);margin:0 auto}.reader-article--vertical{writing-mode:vertical-rl;text-orientation:mixed;overflow-x:auto;overflow-y:hidden}.reader-prose{break-inside:avoid}.reader-p{margin:0 0 1.1em;text-indent:1em}.reader-h{margin:1.5em 0 1em;font-weight:800;font-family:var(--font-display);break-after:avoid;break-inside:avoid}.reader-h-2{font-size:1.5em}.reader-h-3{font-size:1.25em}.reader-h-4{font-size:1.1em}.reader-blank{margin:0;height:.6em}.reader-no-furi rt{display:none}.reader-force-furi rt{display:revert}.reader-theme-paper{--reader-bg: #f9f7f1;--reader-text: #1c1b17;--reader-chrome-bg: #fffefa}.reader-theme-sepia{--reader-bg: #f1e7d5;--reader-text: #3a2f23;--reader-chrome-bg: #f8f1e3}.reader-theme-dark{--reader-bg: #0f172a;--reader-text: #e2e8f0;--reader-chrome-bg: #1e293b}.reader-theme-high-contrast{--reader-bg: #ffffff;--reader-text: #000000;--reader-chrome-bg: #ffffff}.reader-viewer-shell .reader-article{background:var(--reader-bg, #f9f7f1);color:var(--reader-text, #1c1b17)}.reader-viewer-shell .reader-topbar,.reader-viewer-shell .reader-bottombar{background:var(--reader-chrome-bg, white);color:var(--reader-text, #1c1b17)}.reader-settings-panel{position:relative;background:#fff;border-bottom:2px solid rgb(var(--border));padding:1rem 1.25rem;flex-shrink:0;max-height:60vh;overflow-y:auto}.reader-settings-panel h3{margin:0 0 .75rem;font-size:.95rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.reader-settings-close{position:absolute;top:.6rem;right:.8rem;background:none;border:2px solid rgb(var(--border));border-radius:7px;width:1.8rem;height:1.8rem;cursor:pointer;font:inherit;color:rgb(var(--text-secondary))}.reader-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));gap:.85rem}.reader-settings-grid label{display:flex;flex-direction:column;gap:.2rem;font-size:.85rem}.reader-settings-grid label>span{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.reader-settings-grid select,.reader-settings-grid input[type=range]{font:inherit;padding:.3rem .4rem;border:2px solid rgb(var(--border));border-radius:8px;background:#fff}.reader-bottombar-meta{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.reader-progress-pct{font-family:var(--font-mono);font-weight:800;color:var(--blue)}.reader-progress-track{display:inline-block;position:relative;width:8rem;height:.4rem;background:rgb(var(--border));border-radius:999px;overflow:hidden}.reader-progress-fill{display:block;height:100%;background:var(--blue);border-radius:999px;transition:width .12s}@media(max-width:640px){.reader-progress-track{display:none}}.reader-below-shell{max-width:var(--container-max, 76rem);margin:0 auto;padding:1.25rem 1.25rem 4rem}.discussion-section{margin-top:2rem;padding-top:1.25rem;border-top:2px solid rgb(var(--border))}.discussion-header{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;margin-bottom:1rem}.discussion-tab-strip{display:inline-flex;gap:.4rem;border-bottom:2px solid rgb(var(--border))}.discussion-tab{appearance:none;background:transparent;border:none;padding:.45rem .95rem;font:inherit;font-family:var(--font-display);font-size:.92rem;color:rgb(var(--text-muted));cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .12s,border-color .12s}.discussion-tab:hover{color:rgb(var(--text))}.discussion-tab.is-active{color:rgb(var(--text));border-bottom-color:var(--blue)}.discussion-compose{display:flex;flex-direction:column;gap:.5rem;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.7rem .85rem .85rem;margin-bottom:1rem}.discussion-compose--review{background:rgb(var(--bg-muted))}.discussion-compose-tabs{display:inline-flex;gap:.3rem;align-self:flex-start}.discussion-compose-tab{appearance:none;background:transparent;border:none;font:inherit;font-size:.78rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted));cursor:pointer;padding:.2rem .5rem;border-radius:6px}.discussion-compose-tab.is-active{background:rgb(var(--bg-muted));color:rgb(var(--text))}.discussion-compose-tab:disabled{opacity:.4;cursor:not-allowed}.discussion-compose-textarea{appearance:none;border:2px solid rgb(var(--border));border-radius:8px;padding:.6rem .75rem;font:inherit;font-size:.95rem;line-height:1.5;resize:vertical;min-height:4rem;font-family:var(--font-body);background:#fff}.discussion-compose-textarea:focus{outline:none;border-color:var(--blue)}.discussion-compose-preview{border:2px dashed rgb(var(--border));border-radius:8px;padding:.7rem .85rem;background:#fff9}.discussion-compose-bar{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;font-size:.78rem}.discussion-compose-spoiler{display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;font-size:.85rem;color:rgb(var(--text-secondary))}.discussion-compose-meta{font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted))}.discussion-compose-meta.is-overlimit{color:var(--red);font-weight:700}.discussion-compose-hint{font-family:var(--font-mono);font-size:.7rem;color:rgb(var(--text-muted));flex-basis:100%}.discussion-compose-actions{margin-left:auto;display:inline-flex;gap:.4rem;align-items:center}.discussion-compose-shortcut{display:inline-block;margin-left:.4rem;font-family:var(--font-mono);font-size:.65rem;opacity:.7}.discussion-thumbs-row{display:flex;gap:.6rem;flex-wrap:wrap}.discussion-thumb-btn{appearance:none;background:#fff;border:2px solid rgb(var(--border));border-radius:999px;padding:.35rem .85rem;font:inherit;font-size:.92rem;font-weight:700;cursor:pointer;transition:border-color .12s,background .12s,color .12s}.discussion-thumb-btn:hover{border-color:var(--blue)}.discussion-thumb-btn.is-active{background:var(--green);border-color:var(--green-dark);color:#fff}.discussion-thumb-btn.is-active.is-down{background:var(--red);border-color:var(--red);color:#fff}.discussion-signin-prompt{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem;background:#fff;border:3px dashed rgb(var(--border));border-radius:12px;padding:.85rem 1rem;margin-bottom:1rem}.discussion-signin-prompt p{margin:0;color:rgb(var(--text-secondary))}.discussion-meta-row{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem}.discussion-meta-count{font-family:var(--font-mono);font-size:.78rem;color:rgb(var(--text-muted));text-transform:uppercase;letter-spacing:.05em}.discussion-sort-label{display:inline-flex;align-items:center;gap:.4rem;margin-left:auto;font-size:.85rem;color:rgb(var(--text-secondary))}.discussion-sort-text{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.discussion-sort-select{appearance:none;border:2px solid rgb(var(--border));border-radius:6px;padding:.2rem 1.6rem .2rem .55rem;font:inherit;font-size:.85rem;background:#fff;background-image:linear-gradient(45deg,transparent 50%,rgb(var(--text-muted)) 50%),linear-gradient(135deg,rgb(var(--text-muted)) 50%,transparent 50%);background-position:calc(100% - .7rem) center,calc(100% - .45rem) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.discussion-comment-list,.discussion-comment-children{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.discussion-comment-children{margin-top:.7rem;padding-left:1rem;border-left:2px solid rgb(var(--border))}.discussion-comment-thread{display:block}.discussion-comment{display:grid;grid-template-columns:2.4rem 1fr;gap:.6rem;background:#fff;border:2px solid rgb(var(--border));border-radius:10px;padding:.7rem .85rem .55rem}.discussion-comment.is-mine{border-color:var(--blue);background:#f0f7ff}.discussion-comment-aside{display:flex;flex-direction:column;align-items:center;gap:.2rem}.discussion-vote-btn{appearance:none;background:transparent;border:2px solid rgb(var(--border));border-radius:6px;width:2rem;height:2rem;font:inherit;font-size:1rem;font-weight:700;color:rgb(var(--text-muted));cursor:pointer;transition:all .1s}.discussion-vote-btn:hover:not(:disabled){border-color:var(--blue);color:var(--blue)}.discussion-vote-btn.is-voted{background:var(--blue);border-color:var(--blue);color:#fff}.discussion-vote-btn:disabled{opacity:.45;cursor:not-allowed}.discussion-vote-count{font-family:var(--font-mono);font-size:.78rem;font-weight:700;color:rgb(var(--text-secondary))}.discussion-comment-main{min-width:0}.discussion-comment-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.8rem;color:rgb(var(--text-muted));margin-bottom:.4rem}.discussion-comment-time{font-family:var(--font-mono);font-size:.72rem}.discussion-comment-edited{font-family:var(--font-mono);font-size:.72rem;opacity:.75}.discussion-spoiler-flag{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;background:var(--yellow-dark);color:#fff;padding:.1rem .4rem;border-radius:999px}.discussion-author-chip{appearance:none;background:transparent;border:none;padding:0;font:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;color:inherit}.discussion-author-chip:disabled{cursor:default}.discussion-author-chip:hover .discussion-author-name{text-decoration:underline}.discussion-author-avatar{width:1.4rem;height:1.4rem;border-radius:50%;border:1.5px solid rgb(var(--border));background:rgb(var(--bg-muted));object-fit:cover}.discussion-author-avatar--fallback{display:grid;place-items:center;font-family:var(--font-display);font-size:.8rem;color:rgb(var(--text))}.discussion-author-name{font-weight:700;font-size:.88rem;color:rgb(var(--text))}.discussion-author-handle{font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted))}.discussion-comment-body{font-size:.95rem;line-height:1.55;color:rgb(var(--text))}.discussion-comment-body>p{margin:0 0 .5rem}.discussion-comment-body>p:last-child{margin-bottom:0}.discussion-comment-body blockquote{border-left:3px solid rgb(var(--border));margin:0 0 .5rem;padding:0 .7rem;color:rgb(var(--text-secondary))}.discussion-comment-body code{font-family:var(--font-mono);font-size:.9em;background:rgb(var(--bg-muted));border:1px solid rgb(var(--border));padding:.05rem .3rem;border-radius:4px}.discussion-comment-body ul,.discussion-comment-body ol{margin:0 0 .5rem;padding-left:1.4rem}.discussion-comment-body a{color:var(--blue);text-decoration:underline}.discussion-removed{margin:.2rem 0;font-style:italic;color:rgb(var(--text-muted))}.discussion-spoiler-reveal{appearance:none;background:rgb(var(--bg-muted));border:2px dashed rgb(var(--border));border-radius:8px;padding:.5rem .8rem;font:inherit;font-size:.85rem;color:rgb(var(--text-muted));cursor:pointer;width:100%;text-align:center}.discussion-spoiler-reveal:hover{border-color:var(--blue);color:var(--text)}.discussion-comment-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem}.discussion-action-btn{appearance:none;background:transparent;border:none;padding:0;font:inherit;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted));cursor:pointer}.discussion-action-btn:hover{color:var(--blue)}.discussion-action-btn.is-active{color:var(--green-dark);font-weight:700}.discussion-action-btn--quiet{opacity:.65}.discussion-action-btn--danger,.discussion-action-btn--danger:hover{color:var(--red)}.discussion-review-summary{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;background:rgb(var(--bg-muted));border:2px solid rgb(var(--border));border-radius:10px;padding:.6rem .85rem;margin-bottom:1rem}.discussion-review-pct{font-family:var(--font-display);font-size:1.6rem;color:var(--green-dark);line-height:1}.discussion-review-pct-label{font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted));text-transform:uppercase;letter-spacing:.06em}.discussion-review-bar{flex:1 0 8rem;height:8px;background:rgb(var(--border));border-radius:4px;overflow:hidden;display:block}.discussion-review-bar-fill{display:block;height:100%;background:var(--green)}.discussion-review-mine{background:#fff;border:3px solid var(--blue);border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.85rem 1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.discussion-review-mine-head{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.discussion-review-thumbs{font-size:1.2rem;line-height:1}.discussion-review-mine-actions{display:flex;gap:.5rem}.discussion-review-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.discussion-review-mine-spacer{display:none}.discussion-review-item{background:#fff;border:2px solid rgb(var(--border));border-radius:10px;padding:.7rem .85rem}.discussion-review-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.4rem;font-size:.85rem;color:rgb(var(--text-muted))}.discussion-pinned-banner{background:rgb(var(--bg-muted));border:2px solid var(--blue);border-radius:12px;padding:.6rem .8rem .7rem;margin-bottom:1rem}.discussion-pinned-tag{display:inline-block;font-family:var(--font-mono);font-size:.7rem;font-weight:700;letter-spacing:.06em;color:var(--blue-deeper);text-transform:uppercase}.discussion-comment.is-pinned{border-color:var(--blue);background:#fff}.discover-controls{margin-bottom:1.25rem}.discover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:.85rem}.discover-card{appearance:none;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.95rem 1rem;text-align:left;cursor:pointer;font:inherit;display:flex;flex-direction:column;gap:.3rem;transition:transform .12s,border-color .12s,box-shadow .12s}.discover-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-chunky)}.discover-card-stamp{align-self:flex-start;width:1.85rem;height:1.85rem;border:2px solid rgb(var(--border));border-radius:6px;display:grid;place-items:center;font-family:var(--font-display);font-size:1.1rem;background:rgb(var(--bg-muted))}.discover-card-name{font-family:var(--font-display);font-size:1.1rem;line-height:1.2;color:rgb(var(--text))}.discover-card-desc{font-size:.85rem;color:rgb(var(--text-secondary));line-height:1.4}.discover-card-meta{display:flex;gap:.35rem;font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted));margin-top:.2rem}.discover-card-owner{display:inline-block;font-size:.78rem;color:var(--blue);margin-top:.4rem}.discover-card-owner:hover{text-decoration:underline}.profile-currently-reading{list-style:none;margin:0 0 1.25rem;padding:0;display:flex;flex-direction:column;gap:.5rem}.profile-currently-reading-item{appearance:none;background:#fff;border:2px solid rgb(var(--border));border-radius:10px;padding:.5rem .7rem;font:inherit;text-align:left;width:100%;cursor:pointer;display:flex;flex-direction:column;gap:.3rem}.profile-currently-reading-item:hover{border-color:var(--blue)}.profile-currently-reading-slug{font-family:var(--font-mono);font-size:.82rem;color:rgb(var(--text))}.profile-currently-reading-progress{display:block;height:4px;background:rgb(var(--border));border-radius:2px;overflow:hidden}.profile-currently-reading-fill{display:block;height:100%;background:var(--blue)}.profile-currently-reading-meta{font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted))}@media(max-width:640px){.discussion-comment{grid-template-columns:2rem 1fr;gap:.45rem;padding:.55rem .65rem .45rem}.discussion-vote-btn{width:1.7rem;height:1.7rem;font-size:.9rem}.discussion-comment-children{padding-left:.65rem}.discussion-compose-bar{gap:.4rem}.discussion-compose-hint{display:none}.reader-below-shell{padding:1rem .85rem 3rem}}.notification-bell-wrap{position:relative;display:inline-block}.notification-bell{appearance:none;background:transparent;border:none;width:2.4rem;height:2.4rem;display:grid;place-items:center;cursor:pointer;color:#dcdce6;position:relative;border-radius:8px;transition:background .12s,color .12s}.notification-bell:hover,.notification-bell.is-open{background:#ffffff14;color:#fff}.notification-bell-icon{display:block}.notification-bell-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;background:var(--red);color:#fff;border-radius:999px;font-family:var(--font-mono);font-size:.6rem;font-weight:700;display:grid;place-items:center;line-height:1;border:2px solid rgb(var(--navy))}.notification-dropdown{position:absolute;top:calc(100% + .4rem);right:0;z-index:200;width:22rem;max-height:75vh;overflow-y:auto;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky);color:rgb(var(--text))}.notification-dropdown-head{display:flex;align-items:center;justify-content:space-between;padding:.7rem .85rem .45rem;border-bottom:1.5px solid rgb(var(--border))}.notification-dropdown-title{font-family:var(--font-display);font-size:1rem;color:rgb(var(--text))}.notification-dropdown-mark{appearance:none;background:transparent;border:none;font:inherit;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--blue);cursor:pointer}.notification-dropdown-mark:hover{text-decoration:underline}.notification-dropdown-empty{padding:1.4rem 1rem;text-align:center}.notification-dropdown-foot{border-top:1.5px solid rgb(var(--border));padding:.5rem .85rem;text-align:center}.notification-dropdown-link{appearance:none;background:transparent;border:none;font:inherit;font-size:.8rem;color:var(--blue);cursor:pointer}.notification-dropdown-link:hover{text-decoration:underline}.notification-list{list-style:none;margin:0;padding:0}.notification-list>li>ul{list-style:none;margin:0;padding:0}.notification-group-label{display:block;padding:.5rem .85rem .25rem;font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:rgb(var(--text-muted));background:rgb(var(--bg-muted))}.notification-row{appearance:none;background:transparent;border:none;width:100%;display:grid;grid-template-columns:2rem 1fr auto;gap:.6rem;align-items:center;padding:.55rem .85rem;font:inherit;text-align:left;cursor:pointer;border-bottom:1px solid rgb(var(--border))}.notification-row:hover{background:rgb(var(--bg-muted))}.notification-row.is-unread{background:#3b82f60f}.notification-row-avatar{width:2rem;height:2rem;border-radius:50%;border:1.5px solid rgb(var(--border));background:rgb(var(--bg-muted));object-fit:cover}.notification-row-avatar--fallback{display:grid;place-items:center;font-family:var(--font-display);font-size:.95rem;color:rgb(var(--text))}.notification-row-avatar-stack{display:inline-flex;align-items:center;position:relative}.notification-row-avatar--stacked{position:relative;border:2px solid white}.notification-row--grouped{padding-top:.65rem;padding-bottom:.65rem}.notification-row-body{display:flex;flex-direction:column;gap:.1rem;min-width:0}.notification-row-text{font-size:.85rem;color:rgb(var(--text));line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.notification-row-time{font-family:var(--font-mono);font-size:.68rem;color:rgb(var(--text-muted))}.notification-row-dot{width:8px;height:8px;border-radius:50%;background:var(--blue)}.notification-row--full{border:2px solid rgb(var(--border));border-radius:10px;margin-bottom:.45rem;padding:.7rem .85rem;background:#fff}.notification-row--full.is-unread{border-color:var(--blue)}.notifications-page{padding-bottom:4rem}.notifications-page-actions{display:flex;justify-content:flex-end;margin-bottom:1rem}.notifications-page-list{list-style:none;margin:0;padding:0}.notifications-page-more{display:flex;justify-content:center;margin-top:1.25rem}.notification-toast{position:fixed;top:5rem;right:1.25rem;z-index:300;appearance:none;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky);padding:.6rem .85rem;max-width:22rem;display:grid;grid-template-columns:2.2rem 1fr;gap:.65rem;align-items:center;cursor:pointer;font:inherit;text-align:left}.notification-toast.toast-enter{animation:notification-toast-enter .28s ease-out}.notification-toast.toast-exit{animation:notification-toast-exit .28s ease-in forwards}@keyframes notification-toast-enter{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes notification-toast-exit{0%{transform:translate(0);opacity:1}to{transform:translate(20px);opacity:0}}.notification-toast-avatar{width:2.2rem;height:2.2rem;border-radius:50%;border:1.5px solid rgb(var(--border));background:rgb(var(--bg-muted));object-fit:cover}.notification-toast-avatar--fallback{display:grid;place-items:center;font-family:var(--font-display);font-size:1rem;color:rgb(var(--text))}.notification-toast-body{display:flex;flex-direction:column;min-width:0}.notification-toast-label{font-family:var(--font-mono);font-size:.6rem;font-weight:700;letter-spacing:.08em;color:var(--blue)}.notification-toast-text{font-size:.85rem;color:rgb(var(--text));line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.notification-prefs-list{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-direction:column;gap:.5rem}.notification-prefs-list label{display:flex;align-items:center;gap:.6rem;cursor:pointer;padding:.5rem .7rem;border:2px solid rgb(var(--border));border-radius:8px;background:#fff}.notification-prefs-list label:hover{border-color:var(--blue)}.notification-prefs-list input[type=checkbox]{width:1.1rem;height:1.1rem}.pick-handle-overlay{position:fixed;inset:0;z-index:1000;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:1rem}.pick-handle-card{background:#fff;border:4px solid rgb(var(--border));border-radius:16px;box-shadow:var(--shadow-chunky);max-width:32rem;width:100%;padding:1.5rem 1.5rem 1.25rem}.pick-handle-title{font-family:var(--font-display);font-size:1.6rem;margin:0 0 .5rem;color:rgb(var(--text))}.pick-handle-lead{margin:0 0 1.25rem;font-size:.95rem;color:rgb(var(--text-secondary));line-height:1.5}.pick-handle-form{display:flex;flex-direction:column;gap:.6rem}.pick-handle-label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}.pick-handle-input-row{display:flex;align-items:center;border:3px solid rgb(var(--border));border-radius:10px;padding:.5rem .7rem;background:#fff;gap:.4rem}.pick-handle-input-row:focus-within{border-color:var(--blue)}.pick-handle-prefix{color:rgb(var(--text-muted));font-family:var(--font-mono)}.pick-handle-input{appearance:none;border:none;outline:none;font:inherit;font-size:1.1rem;flex:1;background:transparent;font-family:var(--font-mono)}.pick-handle-hint{margin:0;font-size:.78rem;color:rgb(var(--text-muted))}.pick-handle-actions{display:flex;justify-content:flex-end;margin-top:.5rem}.pick-handle-warning{margin:.4rem 0 0;font-size:.75rem;color:rgb(var(--text-muted));font-style:italic}.writings-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:1.25rem}.writings-filter{display:inline-flex;gap:.4rem;margin-left:auto}.writings-filter-pill{appearance:none;background:#fff;border:2px solid rgb(var(--border));border-radius:999px;padding:.3rem .85rem;font:inherit;font-size:.85rem;color:rgb(var(--text-secondary));cursor:pointer}.writings-filter-pill:hover{border-color:var(--blue)}.writings-filter-pill.is-active{background:rgb(var(--text));border-color:rgb(var(--text));color:#fff}.writings-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.writing-card{display:flex;align-items:center;gap:.6rem;background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);padding:.8rem 1rem;transition:border-color .12s,transform .12s}.writing-card:hover{border-color:var(--blue);transform:translateY(-1px)}.writing-card.is-draft{border-style:dashed}.writing-card-main{appearance:none;background:transparent;border:none;font:inherit;text-align:left;flex:1;cursor:pointer;padding:0;display:flex;align-items:center;gap:.6rem;min-width:0}.writing-card-title{font-family:var(--font-display);font-size:1.15rem;margin:0 0 .25rem;color:rgb(var(--text))}.writing-card-meta{margin:0;font-size:.78rem;color:rgb(var(--text-muted));font-family:var(--font-mono)}.writing-card-status{text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;color:rgb(var(--text-secondary));font-weight:700}.writing-card-link{appearance:none;background:transparent;border:none;font:inherit;font-size:.85rem;color:var(--blue);cursor:pointer;white-space:nowrap}.writing-card-link:hover{text-decoration:underline}.writing-card-cover{width:48px;height:72px;flex:0 0 auto;object-fit:cover;border:2px solid rgb(var(--border));border-radius:5px;background:rgb(var(--surface-2));display:block}.writing-card-text{display:flex;flex-direction:column;min-width:0;flex:1}.writing-editor-shell{display:grid;grid-template-columns:1fr 18rem;grid-template-rows:auto 1fr;grid-template-areas:"topbar  sidebar" "body    sidebar";height:calc(100dvh - var(--portal-nav-height, 4.5rem));width:100%}.writing-editor-topbar{grid-area:topbar;display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;padding:.65rem 1.1rem;border-bottom:2px solid rgb(var(--border));background:#fff}.writing-editor-title{flex:1;min-width:12rem;appearance:none;border:none;font:inherit;font-family:var(--font-display);font-size:1.25rem;background:transparent;outline:none;padding:.2rem 0}.writing-editor-title:focus{border-bottom:2px solid var(--blue)}.writing-editor-status{font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted));text-transform:uppercase;letter-spacing:.06em;min-width:4rem;text-align:right}.writing-editor-status.status-saving{color:var(--blue)}.writing-editor-status.status-saved{color:var(--green-dark)}.writing-editor-status.status-dirty{color:var(--yellow-dark)}.writing-editor-status-pill{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;background:rgb(var(--bg-muted));border:1.5px solid rgb(var(--border));border-radius:999px;padding:.15rem .55rem;color:rgb(var(--text-muted))}.writing-editor-body{grid-area:body;display:flex;overflow:hidden;min-width:0}.writing-editor-pane{flex:1 1 0;min-width:0;display:flex;flex-direction:column;overflow:hidden;border-right:1.5px solid rgb(var(--border))}.writing-editor-pane:last-child{border-right:none}.writing-editor-pane--source{background:rgb(var(--bg-muted))}.writing-editor-pane--preview{background:#fff}.writing-editor-textarea{appearance:none;border:none;resize:none;flex:1;background:transparent;outline:none;font:inherit}.writing-editor-textarea--horizontal{width:100%;padding:1rem 1.25rem;font-family:var(--font-mono);font-size:.95rem;line-height:1.6}.writing-editor-textarea--horizontal.writing-editor-textarea--ja{font-family:Hiragino Mincho ProN,Yu Mincho,Iowan Old Style,serif;font-size:1.05rem;line-height:1.85}.writing-editor-textarea--vertical{writing-mode:vertical-rl;text-orientation:mixed;width:100%;height:100%;padding:1.5rem;font-family:Hiragino Mincho ProN,Yu Mincho,MS Mincho,"Noto Serif CJK JP",serif;font-size:1.1rem;line-height:1.85;letter-spacing:.02em;overflow-x:auto;overflow-y:hidden}.writing-editor-textarea--genko{font-family:Noto Sans Mono CJK JP,Source Han Mono JP,Hiragino Mincho ProN,Yu Mincho,MS Mincho,"Noto Serif CJK JP",monospace;font-size:1.25rem;line-height:1.5;letter-spacing:0;font-kerning:none;font-feature-settings:"fwid" 1,"palt" 0,"vpal" 0,"halt" 0,"vhal" 0;font-variant-east-asian:full-width;background-color:#fff8e7;background-image:repeating-linear-gradient(0deg,transparent 0,transparent calc(1.5em - 1px),rgba(30,41,59,.18) calc(1.5em - 1px),rgba(30,41,59,.18) 1.5em),repeating-linear-gradient(90deg,transparent 0,transparent calc(1.5em - 1px),rgba(30,41,59,.18) calc(1.5em - 1px),rgba(30,41,59,.18) 1.5em);background-size:1.5em 1.5em;background-attachment:local;padding:0}.writing-editor-preview{flex:1;overflow-y:auto;padding:1.25rem}.writing-editor-preview-title{font-family:var(--font-display);font-size:1.4rem;margin:0 0 1rem;color:rgb(var(--text))}.writing-editor-sidebar{grid-area:sidebar;border-left:2px solid rgb(var(--border));background:rgb(var(--bg-muted));padding:1rem;overflow-y:auto}.writing-editor-sidebar-title{font-family:var(--font-display);font-size:.95rem;margin:0 0 .85rem;color:rgb(var(--text));font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono)}.writing-editor-field{margin-bottom:1rem}.writing-editor-field>label{display:block;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted));margin-bottom:.35rem}.writing-editor-field-hint{margin:.4rem 0 0;font-size:.78rem;line-height:1.4;color:rgb(var(--text-muted))}.writing-editor-segmented{display:flex;gap:.25rem;flex-wrap:wrap}.writing-editor-seg{appearance:none;flex:1 1 auto;background:#fff;border:2px solid rgb(var(--border));border-radius:6px;padding:.35rem .6rem;font:inherit;font-size:.8rem;color:rgb(var(--text-secondary));cursor:pointer;white-space:nowrap}.writing-editor-seg.is-active{background:rgb(var(--text));border-color:rgb(var(--text));color:#fff}.writing-editor-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1.5px solid rgb(var(--border))}.writing-editor-delete{margin-top:.4rem;color:var(--red);border-color:var(--red)}.writing-editor-stats{margin-top:1rem;padding-top:.75rem;border-top:1.5px solid rgb(var(--border));display:flex;flex-direction:column;gap:.25rem;font-family:var(--font-mono);font-size:.78rem;color:rgb(var(--text-secondary))}.writing-editor-help{margin-top:1rem;padding-top:.75rem;border-top:1.5px solid rgb(var(--border));font-size:.78rem;color:rgb(var(--text-muted))}.writing-editor-help ul{margin:.3rem 0 0;padding-left:1.1rem}.writing-editor-help code{font-family:var(--font-mono);font-size:.78rem;background:#fff;padding:0 .25rem;border:1px solid rgb(var(--border));border-radius:3px}.writing-reader-page{padding-bottom:4rem}.writing-reader-prose{border:3px solid rgb(var(--border));border-radius:14px;background:#fff;padding:1.5rem;margin-top:1.25rem;box-shadow:var(--shadow-chunky-sm)}.writing-reader-cover{display:flex;justify-content:center;margin:1rem 0 .5rem}.writing-reader-cover-img{width:200px;height:300px;object-fit:cover;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky);background:rgb(var(--surface-2));display:block}@media(max-width:480px){.writing-reader-cover-img{width:140px;height:210px}}.writing-editor-cover-add{appearance:none;background:rgb(var(--surface-2));border:2px dashed rgb(var(--border));border-radius:8px;padding:1rem;cursor:pointer;font:inherit;color:rgb(var(--text-secondary));width:100%;text-align:center}.writing-editor-cover-add:hover{border-color:var(--blue);color:var(--blue)}.writing-editor-cover-preview{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.writing-editor-cover-thumb{width:100%;max-width:140px;aspect-ratio:2 / 3;object-fit:cover;border:2px solid rgb(var(--border));border-radius:6px;background:rgb(var(--surface-2));display:block}.writing-editor-cover-actions{display:flex;gap:.4rem;flex-wrap:wrap}.writing-reader-prose--genko{background-color:#fff8e7;font-family:Noto Sans Mono CJK JP,Source Han Mono JP,Source Han Mono,HiraKakuProN-W3,Osaka-Mono,MS Gothic,Hiragino Mincho ProN,Yu Mincho,MS Mincho,"Noto Serif CJK JP",monospace;font-size:1.25rem;line-height:1.5;letter-spacing:0;font-kerning:none;font-feature-settings:"fwid" 1,"palt" 0,"vpal" 0,"halt" 0,"vhal" 0;font-variant-east-asian:full-width;padding:0}.writing-reader-prose--genko rt{display:none}.writing-reader-prose--genko .reader-p{text-indent:0;margin:0}.writing-reader-prose--genko .reader-p:before{content:"";display:inline-grid;inline-size:1.5em;block-size:1.5em;border:1px solid rgba(30,41,59,.18);line-height:1}.writing-reader-prose--genko .reader-h,.writing-reader-prose--genko .reader-h-2,.writing-reader-prose--genko .reader-h-3,.writing-reader-prose--genko .reader-h-4{font-family:inherit;font-weight:inherit;font-size:1em;margin:0;text-indent:0}.writing-reader-prose--genko .reader-blank{margin:0;height:1.5em}.writing-reader-prose--genko .genko-cell{display:inline-grid;place-items:center;inline-size:1.5em;block-size:1.5em;border:1px solid rgba(30,41,59,.18);line-height:1}.genko-cell{display:inline}.profile-writings-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.profile-writing-item{appearance:none;background:#fff;border:2px solid rgb(var(--border));border-radius:10px;padding:.55rem .75rem;font:inherit;text-align:left;width:100%;cursor:pointer;display:flex;flex-direction:column;gap:.2rem}.profile-writing-item:hover{border-color:var(--blue)}.profile-writing-title{font-family:var(--font-display);font-size:1rem;color:rgb(var(--text))}.profile-writing-meta{font-family:var(--font-mono);font-size:.72rem;color:rgb(var(--text-muted));display:flex;gap:.3rem;align-items:center}.writing-empty{margin:0;font-style:italic}.library-actions{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;margin-bottom:1.25rem}.library-filter{display:inline-flex;gap:.4rem;margin-left:auto}.library-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.library-item-card{background:#fff;border:3px solid rgb(var(--border));border-radius:12px;box-shadow:var(--shadow-chunky-sm);transition:border-color .12s,transform .12s}.library-item-card:hover{border-color:var(--blue);transform:translateY(-1px)}.library-item-main{appearance:none;background:transparent;border:none;font:inherit;text-align:left;width:100%;cursor:pointer;padding:.85rem 1rem;display:grid;grid-template-columns:2.4rem 1fr;gap:.75rem;align-items:center}.library-item-icon{font-size:1.6rem;text-align:center}.library-item-text{display:flex;flex-direction:column;gap:.2rem;min-width:0}.library-item-title{font-family:var(--font-display);font-size:1.1rem;color:rgb(var(--text));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-item-meta{font-family:var(--font-mono);font-size:.78rem;color:rgb(var(--text-muted))}.library-item-format{font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-secondary))}.library-ack{border:3px solid var(--yellow-dark);background:#fef3c7;border-radius:12px;padding:1.1rem 1.25rem;margin-bottom:1.5rem}.library-ack-title{margin:0 0 .6rem;font-family:var(--font-display);font-size:1.2rem;color:rgb(var(--text))}.library-ack p{margin:0 0 .6rem;line-height:1.55;color:rgb(var(--text))}.library-ack p.muted{font-size:.88rem}.library-reader-topbar{display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;margin:.5rem 0 1rem}.library-reader-topbar .btn-back{margin-bottom:0}.library-privacy-badge{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border:2px solid currentColor;border-radius:999px;padding:.2rem .7rem}.library-privacy-badge--file{color:#c2410c;background:#ffedd5}.library-privacy-badge--url{color:#15803d;background:#dcfce7}.library-mode-toggle{display:inline-flex;border:2px solid rgb(var(--border));border-radius:8px;overflow:hidden;background:#fff}.library-mode-btn{appearance:none;background:transparent;border:none;font:inherit;font-size:.8rem;padding:.35rem .7rem;cursor:pointer;color:rgb(var(--text-secondary))}.library-mode-btn.is-active{background:rgb(var(--text));color:#fff}.library-source-link{font-size:.85rem;color:var(--blue);text-decoration:none}.library-source-link:hover{text-decoration:underline}.library-pdf-render{margin-top:1rem;border:3px solid rgb(var(--border));border-radius:14px;padding:1rem;background:#fff;box-shadow:var(--shadow-chunky-sm)}.modal-overlay{position:fixed;inset:0;z-index:800;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:1rem}.modal-card{background:#fff;border:4px solid rgb(var(--border));border-radius:16px;box-shadow:var(--shadow-chunky);max-width:36rem;width:100%;padding:1.1rem 1.25rem;max-height:85vh;overflow-y:auto}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem}.modal-head h2{margin:0;font-family:var(--font-display);font-size:1.3rem;color:rgb(var(--text))}.modal-actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1rem}.library-file-drop{border:3px dashed rgb(var(--border));border-radius:12px;padding:2rem 1rem;text-align:center;cursor:pointer;background:rgb(var(--bg-muted));transition:border-color .12s,background .12s}.library-file-drop:hover,.library-file-drop.is-drag{border-color:var(--blue);background:#fff}.library-file-drop p{margin:.3rem 0}.library-upload-progress{text-align:center;padding:1rem}.library-upload-error{padding:.5rem}.library-upload-preview-head{display:flex;gap:.85rem;align-items:flex-start}.library-upload-preview-icon{font-size:2rem;width:2.5rem;text-align:center}.library-upload-preview-text{flex:1;min-width:0}.library-upload-preview-text h3{margin:0 0 .2rem;font-family:var(--font-display);font-size:1.15rem;color:rgb(var(--text))}.library-upload-preview-author{margin:0 0 .3rem;font-size:.85rem;color:rgb(var(--text-secondary))}.library-upload-preview-stats{margin:0;font-family:var(--font-mono);font-size:.78rem;color:rgb(var(--text-muted))}.library-upload-warnings{list-style:none;margin:.85rem 0 0;padding:.6rem .7rem;background:#fef3c7;border:2px solid var(--yellow-dark);border-radius:10px;font-size:.85rem;color:rgb(var(--text))}.library-upload-warnings li{margin:.2rem 0}.library-upload-preview-preview{margin-top:.85rem;font-size:.85rem;line-height:1.5}.library-upload-preview-body{display:block;margin-top:.4rem;color:rgb(var(--text-secondary));background:rgb(var(--bg-muted));border-radius:8px;padding:.6rem .7rem;border:1.5px solid rgb(var(--border));font-family:var(--font-mono);font-size:.8rem;white-space:pre-wrap}.library-url-input{display:flex;flex-direction:column;gap:.5rem}.field-label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:rgb(var(--text-muted))}@media(max-width:900px){.writing-editor-shell{grid-template-columns:1fr;grid-template-areas:"topbar" "body" "sidebar";height:auto;min-height:calc(100dvh - var(--portal-nav-height, 4.5rem))}.writing-editor-sidebar{border-left:none;border-top:2px solid rgb(var(--border))}.writing-editor-body{flex-direction:column}.writing-editor-pane{border-right:none;border-bottom:1.5px solid rgb(var(--border));min-height:50vh}.writing-editor-pane:last-child{border-bottom:none}}
