:root{--color-bg: #F8FAFC;--color-bg-surface: #ECFDF5;--color-bg-card: #FFFFFF;--color-ink: #0F172A;--color-ink-muted: #475569;--color-ink-subtle: #94A3B8;--color-primary: #166534;--color-primary-hover:#14532D;--color-primary-text: #FFFFFF;--color-primary-light:#DCFCE7;--color-accent: #EA580C;--color-accent-hover: #C2410C;--color-accent-text: #FFFFFF;--color-success: #16A34A;--color-success-bg: #F0FDF4;--color-error: #DC2626;--color-error-bg: #FEF2F2;--color-warning: #CA8A04;--color-border: #BBF7D0;--color-border-strong:#86EFAC;--game-accent: var(--color-primary);--shadow-sm: 0 1px 3px rgba(22, 101, 52, .06), 0 1px 2px rgba(22, 101, 52, .04);--shadow-md: 0 4px 16px rgba(22, 101, 52, .1), 0 2px 6px rgba(22, 101, 52, .06);--shadow-lg: 0 8px 32px rgba(22, 101, 52, .12), 0 4px 12px rgba(22, 101, 52, .08);--font-display: "Syne Variable", "Syne", system-ui, sans-serif;--font-body: "Plus Jakarta Sans Variable", "Plus Jakarta Sans", system-ui, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--text-7xl: 4.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-2xl: 40px;--radius-full: 9999px;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.23, 1, .32, 1);--duration-fast: .15s;--duration-base: .22s;--duration-slow: .35s;--container-max: 1200px;--content-max: 65ch;--section-pad-y: var(--space-20);--header-h: 64px}[data-theme=dark]{--color-bg: #0D1B2A;--color-bg-surface: #132032;--color-bg-card: #1A2D42;--color-ink: #E2E8F0;--color-ink-muted: #94A3B8;--color-ink-subtle: #64748B;--color-primary: #F59E0B;--color-primary-hover:#D97706;--color-primary-text: #0D1B2A;--color-primary-light:#1C2A1A;--color-accent: #38BDF8;--color-accent-hover: #0EA5E9;--color-accent-text: #0D1B2A;--color-success: #22C55E;--color-success-bg: #0D2F16;--color-error: #F87171;--color-error-bg: #2D1515;--color-warning: #FBBF24;--color-border: #1E3A5F;--color-border-strong:#2563EB;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .45)}@media(prefers-color-scheme:dark){:root:not([data-theme]){--color-bg: #0D1B2A;--color-bg-surface: #132032;--color-bg-card: #1A2D42;--color-ink: #E2E8F0;--color-ink-muted: #94A3B8;--color-ink-subtle: #64748B;--color-primary: #F59E0B;--color-primary-hover:#D97706;--color-primary-text: #0D1B2A;--color-primary-light:#1C2A1A;--color-accent: #38BDF8;--color-accent-hover: #0EA5E9;--color-accent-text: #0D1B2A;--color-success: #22C55E;--color-success-bg: #0D2F16;--color-error: #F87171;--color-error-bg: #2D1515;--color-warning: #FBBF24;--color-border: #1E3A5F;--color-border-strong:#2563EB;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .45)}}.field{display:flex;flex-direction:column;gap:6px;min-width:200px}.field__label{font-size:var(--text-sm);font-weight:600;color:var(--color-ink-muted)}.field__hint{font-size:var(--text-xs);color:var(--color-ink-subtle)}.input,.select,.textarea{width:100%;padding:10px 12px;font-family:var(--font-body);font-size:var(--text-base);color:var(--color-ink);background:var(--color-bg-card);border:1px solid var(--color-border-strong);border-radius:var(--radius-md)}.textarea{resize:vertical;min-height:96px;line-height:1.5}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input[aria-invalid=true]{border-color:var(--color-error)}.form-stack{display:flex;flex-direction:column;gap:var(--space-4)}.form-row{display:flex;flex-wrap:wrap;gap:var(--space-4)}@font-face{font-family:Syne Variable;font-style:normal;font-display:swap;font-weight:400 800;src:url(/assets/syne-greek-wght-normal-5tOOQDeJ.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Syne Variable;font-style:normal;font-display:swap;font-weight:400 800;src:url(/assets/syne-latin-ext-wght-normal-JjI8ZrW1.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne Variable;font-style:normal;font-display:swap;font-weight:400 800;src:url(/assets/syne-latin-wght-normal-BVsvWWA4.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(data:font/woff2;base64,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) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-vietnamese-wght-normal-qRpaaN48.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-latin-ext-wght-normal-DmpS2jIq.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-latin-wght-normal-eXO_dkmS.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.65;color:var(--color-ink);background-color:var(--color-bg);transition:background-color var(--duration-base) var(--ease-in-out),color var(--duration-base) var(--ease-in-out);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-.02em;color:var(--color-ink);text-wrap:balance}h1{font-size:clamp(var(--text-4xl),6vw,var(--text-6xl));letter-spacing:-.03em}h2{font-size:clamp(var(--text-2xl),4vw,var(--text-4xl))}h3{font-size:clamp(var(--text-xl),2.5vw,var(--text-2xl))}h4{font-size:var(--text-lg)}p{max-width:var(--content-max);color:var(--color-ink-muted)}a{color:var(--color-primary);text-decoration:none;transition:color var(--duration-fast) var(--ease-in-out)}a:hover{color:var(--color-primary-hover)}button{font-family:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}img,svg{display:block;max-width:100%}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--space-6)}@media(min-width:768px){.container{padding-inline:var(--space-8)}}@media(min-width:1200px){.container{padding-inline:var(--space-12)}}.container--wide{max-width:1400px}.container--narrow{max-width:760px}.section{padding-block:var(--section-pad-y)}.section--surface{background-color:var(--color-bg-surface)}.eyebrow{display:inline-block;font-family:var(--font-body);font-size:var(--text-sm);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--game-accent)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-100%;left:var(--space-4);z-index:9999;padding:var(--space-2) var(--space-4);background:var(--color-primary);color:var(--color-primary-text);border-radius:var(--radius-md);font-weight:600}.skip-link:focus{top:var(--space-4)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1 0 auto}.panel{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:4px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;background:var(--color-bg-surface);color:var(--color-ink-muted);border:1px solid var(--color-border)}.notice{padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);background:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-ink-muted);font-size:var(--text-sm)}.notice--error{background:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.notice--success{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.skeleton{background:linear-gradient(90deg,var(--color-bg-surface) 25%,var(--color-bg-card) 37%,var(--color-bg-surface) 63%);background-size:400% 100%;animation:skeleton-shimmer 1.4s ease infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.fade-in{animation:fade-in var(--duration-base) var(--ease-out-expo)}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.maplibregl-map{width:100%;height:100%}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-ink-muted);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast) var(--ease-in-out),border-color var(--duration-fast) var(--ease-in-out),transform var(--duration-base) var(--ease-spring)}.theme-toggle:hover{color:var(--color-ink);border-color:var(--color-border-strong)}.theme-toggle:active{transform:rotate(35deg)}.theme-toggle .icon{width:19px;height:19px}.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--color-bg) 86%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border)}.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);height:var(--header-h)}.brand{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-ink);font-weight:700}.brand:hover{color:var(--color-ink)}.brand__mark{flex-shrink:0}.brand__name{font-family:var(--font-display);font-size:var(--text-xl);letter-spacing:-.02em}.main-nav{display:flex;align-items:center;gap:var(--space-1);margin-left:auto}.main-nav__link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);color:var(--color-ink-muted)}.main-nav__link:hover{color:var(--color-ink);background:var(--color-bg-surface)}.main-nav__link--active{color:var(--color-primary);background:var(--color-primary-light)}.main-nav__link .icon{width:17px;height:17px}.site-header__actions{display:flex;align-items:center;gap:var(--space-2)}.nav-burger{display:none;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-ink);border-radius:var(--radius-md);cursor:pointer}.nav-burger .icon{width:20px;height:20px}@media(max-width:720px){.nav-burger{display:inline-flex}.main-nav{position:absolute;top:var(--header-h);left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;padding:var(--space-3);background:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);transform:translateY(-8px);opacity:0;pointer-events:none;transition:opacity var(--duration-fast) var(--ease-in-out),transform var(--duration-fast) var(--ease-in-out)}.main-nav--open{transform:none;opacity:1;pointer-events:auto}.main-nav__link{padding:12px 14px;font-size:var(--text-base)}}.site-footer{margin-top:var(--space-16);border-top:1px solid var(--color-border);background:var(--color-bg-surface)}.site-footer__inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);padding-block:var(--space-6)}.site-footer__copy{font-size:var(--text-sm);color:var(--color-ink-muted);margin:0;max-width:none}.site-footer__links{display:flex;flex-wrap:wrap;gap:var(--space-4)}.site-footer__links a{font-size:var(--text-sm);color:var(--color-ink-muted)}.site-footer__links a:hover{color:var(--color-primary)}.spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);color:var(--color-ink-muted)}.spinner-wrap--full{min-height:60vh}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--game-accent);border-radius:var(--radius-full);animation:spinner-rotate .8s linear infinite}.spinner-label{font-size:var(--text-sm)}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.game-card{display:flex;flex-direction:column;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);color:var(--color-ink);transition:transform var(--duration-base) var(--ease-spring),box-shadow var(--duration-base) var(--ease-in-out),border-color var(--duration-base) var(--ease-in-out)}.game-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--game-accent);color:var(--color-ink)}.game-card__media{position:relative;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 120% at 80% 0%,color-mix(in srgb,var(--game-accent) 22%,var(--color-bg-card)) 0%,var(--color-bg-surface) 70%);overflow:hidden}.game-card__media img{width:100%;height:100%;object-fit:cover}.game-card__icon{display:inline-flex;align-items:center;justify-content:center}.game-card__icon svg{width:56px;height:56px;color:var(--game-accent);stroke-width:1.6}.game-card__cat{position:absolute;top:var(--space-3);left:var(--space-3);background:color-mix(in srgb,var(--color-bg-card) 80%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.game-card__body{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);flex:1}.game-card__title{font-size:var(--text-xl)}.game-card__desc{font-size:var(--text-sm);color:var(--color-ink-muted);max-width:none;flex:1}.game-card__foot{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.game-card__flags{display:flex;gap:var(--space-3);flex-wrap:wrap}.game-card__flag{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--color-ink-subtle)}.game-card__flag svg{width:14px;height:14px}.game-card__play{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:var(--text-sm);color:var(--game-accent)}.game-card__play svg{width:15px;height:15px}.game-card--featured{flex-direction:row}.game-card--featured .game-card__media{aspect-ratio:auto;flex:1 1 45%;min-height:280px}.game-card--featured .game-card__body{flex:1 1 55%;justify-content:center;gap:var(--space-3)}.game-card--featured .game-card__title{font-size:clamp(var(--text-2xl),3vw,var(--text-4xl));font-family:var(--font-display)}.game-card--featured .game-card__desc{font-size:var(--text-base)}.game-card--featured .game-card__icon svg{width:88px;height:88px}@media(max-width:760px){.game-card--featured{flex-direction:column}.game-card--featured .game-card__media{min-height:200px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-body);font-weight:600;text-align:center;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;text-decoration:none;white-space:nowrap;transition:background-color var(--duration-fast) var(--ease-in-out),color var(--duration-fast) var(--ease-in-out),border-color var(--duration-fast) var(--ease-in-out),transform var(--duration-fast) var(--ease-spring);-webkit-user-select:none;user-select:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--sm{padding:6px 12px;font-size:var(--text-sm)}.btn--md{padding:10px 18px;font-size:var(--text-base)}.btn--lg{padding:14px 26px;font-size:var(--text-lg);border-radius:var(--radius-lg)}.btn--block{display:flex;width:100%}.btn--primary{background:var(--color-primary);color:var(--color-primary-text)}.btn--primary:hover{background:var(--color-primary-hover);color:var(--color-primary-text)}.btn--accent{background:var(--color-accent);color:var(--color-accent-text)}.btn--accent:hover{background:var(--color-accent-hover);color:var(--color-accent-text)}.btn--outline{background:transparent;color:var(--color-ink);border-color:var(--color-border-strong)}.btn--outline:hover{background:var(--color-bg-surface);color:var(--color-ink)}.btn--ghost{background:transparent;color:var(--color-ink-muted)}.btn--ghost:hover{background:var(--color-bg-surface);color:var(--color-ink)}.btn--danger{background:var(--color-error);color:#fff}.btn--danger:hover{filter:brightness(.93);color:#fff}.btn .icon{width:1.15em;height:1.15em}.home-hero{padding-block:clamp(var(--space-10),7vw,var(--space-20));background:radial-gradient(80% 120% at 100% 0%,var(--color-primary-light) 0%,transparent 55%)}.home-hero__inner{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(var(--space-8),5vw,var(--space-16))}.home-hero__text{display:flex;flex-direction:column;gap:var(--space-4)}.home-hero__text h1{margin-top:var(--space-1)}.home-hero__lead{font-size:var(--text-lg);color:var(--color-ink-muted);max-width:46ch}.home-hero__cta{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-2)}@media(max-width:880px){.home-hero__inner{grid-template-columns:1fr}.home-hero__feature{order:-1}}.home-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.home-section-head__more{display:inline-flex;align-items:center;gap:4px;font-weight:600;font-size:var(--text-sm)}.home-section-head__more .icon{width:15px;height:15px}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.home-how__list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-8) var(--space-10)}.home-how__list li{display:flex;gap:var(--space-4);align-items:flex-start}.home-how__list h3{font-size:var(--text-lg);margin-bottom:4px}.home-how__list p{font-size:var(--text-sm);max-width:34ch}.home-how__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:52px;height:52px;border-radius:var(--radius-md);background:var(--color-primary-light);color:var(--color-primary)}.home-how__icon svg{width:26px;height:26px;stroke-width:1.7}.page-head{margin-bottom:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.page-head h1{margin:0}.page-head p{max-width:54ch}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-8)}.filter-chip{padding:7px 16px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-ink-muted);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-in-out)}.filter-chip:hover{border-color:var(--color-border-strong);color:var(--color-ink)}.filter-chip--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text)}.ranking-table-wrap{overflow-x:auto}.ranking-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.ranking-table th,.ranking-table td{padding:var(--space-3) var(--space-3);text-align:left;border-bottom:1px solid var(--color-border)}.ranking-table th{font-family:var(--font-body);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-ink-subtle);font-weight:700}.ranking-table tbody tr:hover{background:var(--color-bg-surface)}.rt-rank{width:48px;font-weight:700;color:var(--color-ink-muted);text-align:center}.rt-medal{width:22px;height:22px;margin-inline:auto}.rt-name{font-weight:600;color:var(--color-ink)}.rt-score{font-weight:700;color:var(--game-accent);white-space:nowrap}.rt-time,.rt-date{color:var(--color-ink-muted);white-space:nowrap}.rt-you{color:var(--color-ink-subtle);font-weight:400}.rt-me{background:color-mix(in srgb,var(--game-accent) 12%,transparent)!important;outline:1px solid color-mix(in srgb,var(--game-accent) 40%,transparent)}@media(max-width:600px){.rt-date{display:none}}.ranking-filters{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-6)}.ranking-panel{padding:var(--space-4) var(--space-5)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade-in var(--duration-fast) var(--ease-in-out)}.modal{width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-pop var(--duration-base) var(--ease-spring)}@keyframes modal-pop{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-5) var(--space-5) var(--space-3)}.modal-title{font-size:var(--text-xl)}.modal-close{display:inline-flex;padding:6px;border:none;background:transparent;color:var(--color-ink-subtle);border-radius:var(--radius-sm);cursor:pointer}.modal-close:hover{background:var(--color-bg-surface);color:var(--color-ink)}.modal-close .icon{width:20px;height:20px}.modal-body{padding:0 var(--space-5) var(--space-5)}.auth-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-5)}.auth-tab{flex:1;padding:10px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-ink-muted);font-weight:600;cursor:pointer}.auth-tab:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.auth-tab:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.auth-tab--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text)}.auth-panel{padding:var(--space-6)}.field__hint{display:flex;gap:6px;align-items:flex-start;line-height:1.5}.icon-inline{width:14px;height:14px;flex-shrink:0;margin-top:2px}.account-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8)}.account-head h1{margin:var(--space-1) 0}.account-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-5)}.account-block{padding:var(--space-5)}.account-block__title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-lg);margin-bottom:var(--space-4)}.account-block__title .icon{width:20px;height:20px;color:var(--color-primary)}.account-block__count{margin-left:auto;font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-ink-subtle);font-weight:600}.best-list{list-style:none;display:flex;flex-direction:column}.best-list li{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.best-list li:last-child{border-bottom:none}.best-list__game{font-weight:600}.best-list__val{font-weight:700;color:var(--color-primary)}.best-list__time{color:var(--color-ink-subtle);font-weight:400}.achv-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.achv{display:flex;flex-direction:column;gap:4px;padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);opacity:.55;filter:grayscale(.6)}.achv--on{opacity:1;filter:none;border-color:var(--color-border-strong)}.achv__icon{width:24px;height:24px;color:var(--color-ink-subtle)}.achv--on .achv__icon{color:var(--color-accent)}.achv__title{font-weight:700;font-size:var(--text-sm)}.achv__desc{font-size:var(--text-xs);color:var(--color-ink-muted);line-height:1.4}.achv__date{font-size:var(--text-xs);color:var(--color-ink-subtle);margin-top:2px}.account-danger{margin-top:var(--space-10);padding-top:var(--space-5);border-top:1px solid var(--color-border)}.account-danger__btn{color:var(--color-error)}.account-danger__btn:hover{background:var(--color-error-bg);color:var(--color-error)}.notfound{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);padding-block:var(--space-24)}.notfound__icon{width:64px;height:64px;color:var(--color-ink-subtle)}.notfound p{max-width:44ch}.notfound__cta{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-top:var(--space-2)}.game-host{display:flex;flex-direction:column}.game-host__bar{display:flex;align-items:center;gap:var(--space-4);padding-block:var(--space-3)}.game-host__back{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-sm);font-weight:600;color:var(--color-ink-muted)}.game-host__back:hover{color:var(--game-accent)}.game-host__back .icon{width:16px;height:16px}.game-host__name{margin-left:auto;font-family:var(--font-display);font-weight:700;color:var(--color-ink-subtle);font-size:var(--text-sm)}
