.uname-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#000000c7;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.uname-modal{background:#161616;border:1px solid #2a2a2a;border-radius:20px;padding:32px 32px 24px;max-width:420px;width:100%;display:flex;flex-direction:column}.uname-google-user{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:11px 14px;background:#1e1e1e;border:1px solid #2a2a2a;border-radius:12px}.uname-google-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0}.uname-google-avatar--fallback{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:700}.uname-google-name{font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:500;color:#eee}.uname-google-email{font-family:DM Sans,sans-serif;font-size:.75rem;color:#555;margin-top:2px}.uname-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:900;color:#fff;margin:0 0 8px;letter-spacing:-.3px}.uname-sub{font-family:DM Sans,sans-serif;font-size:.88rem;color:#666;margin:0 0 22px;line-height:1.55}.uname-form{display:flex;flex-direction:column;gap:8px}.uname-input-wrap{display:flex;align-items:center;background:#1a1a1a;border:1px solid #2f2f2f;border-radius:12px;padding:0 14px;gap:4px;transition:border-color .15s ease;outline:none}.uname-input-wrap:focus-within{border-color:#4a4a4a}.uname-input-wrap--error{border-color:#ef444473!important}.uname-input-wrap--valid{border-color:#22c55e59}.uname-at{font-family:DM Sans,sans-serif;font-size:1rem;color:#555;flex-shrink:0;-webkit-user-select:none;user-select:none}.uname-input{flex:1;background:transparent;border:none;outline:none;padding:13px 0;font-family:DM Sans,sans-serif;font-size:.95rem;color:#fff}.uname-input::placeholder{color:#3a3a3a}.uname-len{font-family:DM Sans,sans-serif;font-size:.72rem;color:#444;flex-shrink:0}.uname-feedback{margin:0;font-family:DM Sans,sans-serif;font-size:.78rem;padding-left:2px}.uname-feedback--error{color:#f87171}.uname-feedback--ok{color:#4ade80}.uname-feedback--info{color:#555}.uname-submit{margin-top:8px;background:#fff;color:#111;border:none;border-radius:10px;padding:13px 20px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s ease,opacity .15s ease}.uname-submit:hover:not(:disabled){background:#e8e8e8}.uname-submit:disabled{opacity:.3;cursor:not-allowed}.uname-cancel{margin-top:16px;background:transparent;border:none;font-family:DM Sans,sans-serif;font-size:.78rem;color:#444;cursor:pointer;text-align:center;padding:4px 0;transition:color .15s ease;align-self:center}.uname-cancel:hover{color:#888}@media (max-width: 480px){.uname-modal{padding:24px 20px 20px}.uname-title{font-size:1.3rem}}.site-header{position:sticky;top:0;z-index:100;background:#111;border-bottom:1px solid #2a2a2a}.header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;max-width:1100px;margin:0 auto}.header-brand{display:flex;align-items:center;gap:12px;text-decoration:none}.header-logo{width:32px;height:32px;object-fit:contain;filter:invert(1);opacity:.9}.header-title-group{display:flex;flex-direction:column;line-height:1}.header-title{font-family:Playfair Display,serif;font-size:1.45rem;font-weight:900;color:#fff;margin:0;letter-spacing:-.5px}.header-tagline{font-family:DM Sans,sans-serif;font-size:.68rem;font-weight:400;color:#666;letter-spacing:.08em;text-transform:uppercase;margin-top:3px}.header-nav{display:flex;align-items:center;gap:20px}.auth-login-btn{font-family:DM Sans,sans-serif;font-size:.82rem;color:#aaa;background:transparent;border:1px solid #2f2f2f;border-radius:100px;padding:5px 12px;display:inline-flex;align-items:center;gap:5px;cursor:pointer;text-decoration:none;transition:border-color .15s ease,color .15s ease}.auth-login-icon{width:13px;height:13px;stroke-width:2;flex-shrink:0}.auth-login-label{font-size:.82rem}.auth-login-btn:hover{color:#fff;border-color:#4a4a4a}.auth-user{position:relative;display:inline-flex;align-items:center;margin-left:2px}.auth-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.1);flex-shrink:0}.auth-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:#2a2a2a;border:1px solid #3a3a3a;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:600;color:#aaa;flex-shrink:0}.auth-name{font-family:DM Sans,sans-serif;color:#ddd;font-size:.8rem;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-chevron{width:13px;height:13px;stroke-width:2.5;color:#666;flex-shrink:0;transition:transform .2s ease,color .15s ease}.auth-chevron--up{transform:rotate(180deg);color:#999}.auth-profile-btn{display:inline-flex;align-items:center;gap:7px;background:#1a1a1a;border:1px solid #2f2f2f;border-radius:100px;padding:4px 10px 4px 5px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.auth-profile-btn:hover,.auth-profile-btn--open{background:#222;border-color:#3f3f3f}.auth-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:#1a1a1a;border:1px solid #2f2f2f;border-radius:12px;box-shadow:0 8px 32px #0000008c;z-index:200;overflow:hidden;animation:dropdown-in .12s ease}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-dropdown-header{display:flex;align-items:center;gap:10px;padding:12px 14px}.auth-dropdown-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.1);flex-shrink:0}.auth-avatar-placeholder--lg{width:36px;height:36px;font-size:.85rem}.auth-dropdown-info{display:flex;flex-direction:column;min-width:0}.auth-dropdown-name{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#eee;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-dropdown-email{font-family:DM Sans,sans-serif;font-size:.72rem;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-dropdown-divider{height:1px;background:#242424;margin:0}.auth-dropdown-item{display:flex;align-items:center;gap:9px;width:100%;background:transparent;border:none;padding:9px 14px;font-family:DM Sans,sans-serif;font-size:.83rem;color:#bbb;cursor:pointer;text-align:left;transition:background .1s ease,color .1s ease}.auth-dropdown-item:hover{background:#222;color:#fff}.auth-dropdown-item--danger{color:#f87171}.auth-dropdown-item--danger:hover{background:#f8717114;color:#fca5a5}.auth-dropdown-icon{width:14px;height:14px;stroke-width:2;flex-shrink:0;opacity:.75}.auth-error{margin:0;padding:0 24px 8px;max-width:1100px;margin-inline:auto;color:#fca5a5;font-family:DM Sans,sans-serif;font-size:.75rem}.nav-link{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#aaa;text-decoration:none;letter-spacing:.03em;transition:color .15s ease}.nav-link:hover{color:#fff}.nav-link--premium{display:inline-flex;align-items:center;gap:5px;color:#eab308!important;background:#eab30814;border:1px solid rgba(234,179,8,.22);padding:5px 12px;border-radius:100px;transition:background .15s ease,border-color .15s ease!important}.nav-link--premium:hover{color:#eab308!important;background:#eab30826!important;border-color:#eab30873!important}.nav-link--premium-active{background:#eab3081f;border-color:#eab30859}.nav-premium-icon{width:13px;height:13px;object-fit:contain;filter:invert(1) sepia(1) saturate(4) hue-rotate(5deg) brightness(1.05);flex-shrink:0}.nav-premium-label{font-size:.82rem}@media (max-width: 600px){.header-inner{padding:0 16px;gap:10px}.header-brand{min-width:0;flex:1;gap:10px}.header-tagline{display:none}.header-title{font-size:1.15rem;white-space:nowrap}.header-nav{gap:8px;flex-shrink:0}.nav-link--premium{display:inline-flex!important;padding:4px 10px;gap:4px}.auth-name,.auth-chevron{display:none}.auth-profile-btn{padding:3px 5px}.nav-premium-label,.auth-login-label{display:inline;font-size:.76rem}.auth-login-btn{display:inline-flex;padding:4px 9px;gap:4px;font-size:.76rem}.auth-login-icon,.nav-premium-icon{width:12px;height:12px}.auth-dropdown{min-width:180px;right:0}}.hero{padding:64px 24px 48px;max-width:1100px;margin:0 auto}.hero-inner{max-width:540px;text-align:center;margin:0 auto}.hero-eyebrow{font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:500;color:#555;letter-spacing:.14em;text-transform:uppercase;margin:0 0 16px}.hero-headline{font-family:Playfair Display,serif;font-size:clamp(2.4rem,6vw,3.8rem);font-weight:900;color:#fff;line-height:1.1;margin:0 0 20px;letter-spacing:-1px}.hero-body{font-family:DM Sans,sans-serif;font-size:1rem;font-weight:300;color:#888;line-height:1.65;margin:0 0 36px;max-width:420px}.hero-stats{display:flex;align-items:center;gap:24px}.hero-stat{display:flex;flex-direction:column;gap:2px}.hero-stat__number{font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;color:#fff;line-height:1}.hero-stat__label{font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:400;color:#555;letter-spacing:.06em;text-transform:uppercase}.hero-stat-divider{width:1px;height:32px;background:#2a2a2a}@media (max-width: 600px){.hero{padding:40px 16px 32px}.hero-headline{font-size:2.4rem;letter-spacing:-.5px}.hero-body{font-size:.9rem}}.game-card{position:relative;background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:28px 24px 22px;height:210px;display:flex;flex-direction:column;gap:14px;overflow:hidden;transition:border-color .2s ease,transform .15s ease,background .2s ease}.game-card--available{cursor:pointer}.game-card--available:hover{background:#1e1e1e;border-color:var(--game-color);transform:translateY(-2px)}.game-card--available:hover .game-card__accent{opacity:1}.game-card--soon{opacity:.5;cursor:default}.game-card--teaser{opacity:1;cursor:default;border-style:dashed}.game-card__accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--game-color);opacity:.35;transition:opacity .2s ease;border-radius:12px 12px 0 0}.game-card--available:focus-visible .game-card__accent{opacity:1}.game-card__icon{font-size:2rem;line-height:1;color:var(--game-color);display:flex;align-items:center;flex-shrink:0}.game-card__body{flex:1;display:flex;flex-direction:column;gap:8px}.game-card__title-row{display:flex;align-items:center;gap:12px}.game-card__title-text{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.game-card__name{font-family:Playfair Display,serif;font-size:1.35rem;font-weight:700;color:#fff;margin:0;line-height:1.2}.game-card__subtitle{font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:#555}.game-card__description{font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:300;color:#888;line-height:1.55;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.game-card__footer{display:flex;align-items:center;justify-content:flex-end;margin-top:4px;gap:8px}.game-card__play-btn{display:inline-block;padding:7px 20px;border-radius:6px;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600;color:#fff;letter-spacing:.04em;text-transform:uppercase;filter:brightness(.92);transition:filter .15s ease}.game-card--available:hover .game-card__play-btn{filter:brightness(1.05)}.game-card__coming-soon{font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:500;color:#444;letter-spacing:.06em;text-transform:uppercase}@media (max-width: 600px){.game-card{padding:22px 18px 18px;border-radius:10px}.game-card__name{font-size:1.15rem}}.game-grid-section{padding:0 24px 80px;max-width:1100px;margin:0 auto}.game-grid-inner{display:flex;flex-direction:column;gap:24px}.game-grid-header{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid #222}.game-grid-title{font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700;color:#fff;margin:0}.game-grid-count{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:400;color:#555;letter-spacing:.05em}.game-grid-description{font-family:DM Sans,sans-serif;font-size:.85rem;color:#555;margin:-8px 0 0;line-height:1.5}.game-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 900px){.game-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.game-grid-section{padding:0 16px 60px}.game-grid{grid-template-columns:1fr;gap:12px}.game-grid-title{font-size:1.2rem}}.site-footer{position:fixed;left:0;right:0;bottom:0;z-index:100;border-top:1px solid #222;background:#0d0d0d;padding-bottom:env(safe-area-inset-bottom)}.footer-tabs{max-width:520px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 12px}.footer-tab{flex:1;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.02em;color:#616161;text-decoration:none;transition:color .15s ease,background-color .15s ease}.footer-tab-inner{display:flex;align-items:center;gap:7px}.footer-tab-icon{flex-shrink:0}.footer-tab-label{white-space:nowrap}.footer-tab:hover{color:#c7c7c7}.footer-tab--active{color:#fff;background:#1b1b1b}@media (max-width: 640px){.footer-tab-label{display:none}.footer-tab-inner{gap:0}}@media (min-width: 900px){.footer-tabs{max-width:640px}}.rg-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;--grid-side: min(95vw, max(480px, calc(var(--size) * 52px)), 600px)}.rg-grid{position:relative;width:var(--grid-side);aspect-ratio:1;border:2px solid #3a3a3a;border-radius:6px;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none;cursor:crosshair;transition:border-color .25s ease}.rg-grid--flash{border-color:#ef4444;animation:rg-flash .38s ease}.rg-grid--solved{border-color:#22c55e}.rg-grid--solution{border-color:#6b7280;cursor:default}.rg-solution-label{font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;color:#6b7280;letter-spacing:.1em;text-transform:uppercase}@keyframes rg-flash{0%{box-shadow:0 0 #ef444480}40%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.rg-cells{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(var(--size),1fr);grid-template-rows:repeat(var(--size),1fr)}.rg-cell{border-right:1px solid #242424;border-bottom:1px solid #242424;display:flex;align-items:center;justify-content:center;transition:background-color .12s ease}.rg-num{font-family:Playfair Display,serif;font-size:clamp(.5rem,calc(var(--grid-side, 480px) / var(--size) * .35),1.15rem);font-weight:700;color:#fff;line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2;transition:opacity .15s}.rg-num--placed{opacity:.7}.rg-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.rg-bar{display:flex;align-items:center;justify-content:space-between;width:var(--grid-side);padding:0 2px}.rg-progress{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#ccc}.rg-progress-label{font-weight:400;color:#555}.rg-reset-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#777;background:transparent;border:1px solid #333;border-radius:6px;padding:5px 14px;cursor:pointer;transition:color .15s,border-color .15s}.rg-reset-btn:hover{color:#fff;border-color:#666}.rg-hint{font-family:DM Sans,sans-serif;font-size:.75rem;color:#444;text-align:center;margin:0}.rp{min-height:100dvh;display:flex;flex-direction:column;background:#111;padding-top:58px}.rp-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;border-bottom:1px solid #2e2e2e;background:#111;position:fixed;top:0;left:0;right:0;z-index:10}.rp-back{display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#777;text-decoration:none;transition:color .15s;min-width:80px}.rp-back:hover{color:#fff}.rp-title-group{display:flex;flex-direction:column;align-items:center;gap:1px}.rp-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#fff;margin:0;line-height:1}.rp-subtitle{font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:500;color:#3b82f6;letter-spacing:.1em;text-transform:uppercase}.rp-header-spacer{min-width:80px}.rp-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:24px;padding:40px 16px 48px}.rp-instructions{font-family:DM Sans,sans-serif;font-size:.875rem;color:#666;text-align:center;max-width:360px;margin:12px 0 0;line-height:1.5}.rp-difficulty{display:flex;gap:6px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:4px}.rp-diff-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#666;background:transparent;border:none;border-radius:5px;padding:6px 14px;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.03em;white-space:nowrap}.rp-diff-btn:hover{color:#bbb}.rp-diff-btn--active{background:#3b82f6;color:#fff}.rp-diff-btn--active:hover{color:#fff}.rp-actions{display:flex;gap:10px;align-items:center}.rp-giveup-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#555;background:transparent;border:1px solid #2a2a2a;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.rp-giveup-btn:hover{color:#ef4444;border-color:#ef4444}.rp-new-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;background:transparent;border:1px solid #333;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.rp-new-btn:hover{color:#fff;border-color:#666}.rp-solution{width:100%;max-width:480px;animation:rp-slide-up .4s ease}.rp-solution-inner{background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #6b7280;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.rp-solution-icon{font-size:1.8rem;font-family:Playfair Display,serif;font-weight:700;color:#6b7280;line-height:1}.rp-win{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#000000d1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:rp-fade-in .2s ease}@keyframes rp-fade-in{0%{opacity:0}to{opacity:1}}@keyframes rp-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.rp-win-inner{position:relative;background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #22C55E;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;width:100%;max-width:400px;animation:rp-slide-up .3s ease}.rp-win-check{font-size:1.8rem;color:#22c55e;line-height:1}.rp-win-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.rp-win-body{font-family:DM Sans,sans-serif;font-size:.875rem;color:#777;margin:0;max-width:280px}.rp-win-actions{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}.rp-win-next{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#fff;background:#3b82f6;border:none;border-radius:6px;padding:9px 22px;cursor:pointer;transition:filter .15s}.rp-win-next:hover{filter:brightness(1.1)}.rp-win-next--outline{background:transparent;border:1px solid #3B82F6;color:#3b82f6;filter:none}.rp-win-next--outline:hover{background:#3b82f61a;filter:none}.rp-win-home{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;text-decoration:none;border:1px solid #333;border-radius:6px;padding:9px 22px;transition:color .15s,border-color .15s}.rp-win-home:hover{color:#fff;border-color:#666}.rp-win--inline{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:rp-slide-up .3s ease;padding:0}.rp-win--inline .rp-win-inner{animation:none}.rp-win-close{position:absolute;top:8px;right:12px;font-size:1.5rem;line-height:1;color:#666;background:transparent;border:none;cursor:pointer;padding:4px 8px;transition:color .15s}.rp-win-close:hover{color:#fff}.rp-win--inline .rp-win-close{display:none}.rp-actions-solved{display:flex;gap:10px;align-items:center}@media (max-width: 600px){.rp-main{gap:16px;padding:16px 10px 32px}.rp-diff-btn{padding:6px 10px;font-size:.74rem}}.sg-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;--board-size: min(95vw, 480px)}.sg-board{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);width:var(--board-size);aspect-ratio:1;border:2px solid #3a3a3a;border-radius:5px;overflow:hidden;touch-action:manipulation;-webkit-user-select:none;user-select:none;transition:border-color .25s}.sg-board--solution{border-color:#6b7280;cursor:default}.sg-cell{border-right:1px solid #232323;border-bottom:1px solid #232323;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:background-color .08s}.sg-cell--box-left{border-left:2px solid #3a3a3a}.sg-cell--box-top{border-top:2px solid #3a3a3a}.sg-cell--related{background-color:#ffffff0a}.sg-cell--samenum{background-color:#f59e0b29}.sg-cell--selected{background-color:#f59e0b57}.sg-cell--conflict{background-color:#ef44442e}.sg-cell--selected.sg-cell--conflict{background-color:#ef444447}.sg-num{font-family:Playfair Display,serif;font-size:clamp(.85rem,calc(var(--board-size) / 9 * .48),1.5rem);font-weight:700;color:#f59e0b;line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none}.sg-num--given{color:#fff}.sg-num--error{color:#ef4444}.sg-notes{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;padding:2px;box-sizing:border-box}.sg-note{display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:clamp(.3rem,calc(var(--board-size) / 9 * .18),.55rem);font-weight:600;color:#666;line-height:1}.sg-bar{display:flex;align-items:center;justify-content:space-between;width:var(--board-size);padding:0 2px}.sg-status{font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600}.sg-status--ok{color:#555}.sg-status--error{color:#ef4444}.sg-solution-label{font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;color:#6b7280;letter-spacing:.1em;text-transform:uppercase}.sg-reset-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#777;background:transparent;border:1px solid #333;border-radius:6px;padding:5px 14px;cursor:pointer;transition:color .15s,border-color .15s}.sg-reset-btn:hover{color:#fff;border-color:#666}.sg-controls{display:flex;flex-direction:column;align-items:center;gap:8px;width:var(--board-size)}.sg-numpad{display:grid;grid-template-columns:repeat(9,1fr);gap:5px;width:100%}.sg-num-btn{font-family:Playfair Display,serif;font-size:clamp(.95rem,2.8vw,1.25rem);font-weight:700;color:#ccc;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;aspect-ratio:1;cursor:pointer;transition:background .1s,color .1s,border-color .1s;display:flex;align-items:center;justify-content:center;padding:0}.sg-num-btn:hover,.sg-num-btn:active{background:#f59e0b;color:#111;border-color:#f59e0b}.sg-action-row{display:flex;gap:8px;width:100%}.sg-ctrl-btn{flex:1;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;color:#888;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:9px 0;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.sg-ctrl-btn:hover{color:#ccc;border-color:#555}.sg-ctrl-btn--on,.sg-ctrl-btn--on:hover{color:#f59e0b;border-color:#f59e0b}.sg-hint{font-family:DM Sans,sans-serif;font-size:.75rem;color:#444;text-align:center;margin:0}.sp{min-height:100dvh;display:flex;flex-direction:column;background:#111;padding-top:58px}.sp-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;border-bottom:1px solid #2e2e2e;background:#111;position:fixed;top:0;left:0;right:0;z-index:10}.sp-back{display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#777;text-decoration:none;transition:color .15s;min-width:80px}.sp-back:hover{color:#fff}.sp-title-group{display:flex;flex-direction:column;align-items:center;gap:1px}.sp-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#fff;margin:0;line-height:1}.sp-subtitle{font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:500;color:#f59e0b;letter-spacing:.1em;text-transform:uppercase}.sp-header-spacer{min-width:80px}.sp-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:24px;padding:0 16px 48px}.sp-instructions{font-family:DM Sans,sans-serif;font-size:.875rem;color:#666;text-align:center;max-width:360px;margin:12px 0 0;line-height:1.5}.sp-difficulty{display:flex;gap:6px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:4px}.sp-diff-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#666;background:transparent;border:none;border-radius:5px;padding:6px 14px;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.03em;white-space:nowrap}.sp-diff-btn:hover{color:#bbb}.sp-diff-btn--active{background:#f59e0b;color:#111}.sp-diff-btn--active:hover{color:#111}.sp-actions{display:flex;gap:10px;align-items:center}.sp-giveup-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#555;background:transparent;border:1px solid #2a2a2a;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.sp-giveup-btn:hover{color:#ef4444;border-color:#ef4444}.sp-new-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;background:transparent;border:1px solid #333;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.sp-new-btn:hover{color:#fff;border-color:#666}.sp-solution{width:100%;max-width:480px;animation:sp-slide-up .4s ease}.sp-solution-inner{background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #6b7280;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.sp-solution-icon{font-size:1.8rem;font-family:Playfair Display,serif;font-weight:700;color:#6b7280;line-height:1}.sp-win{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#000000d1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:sp-fade-in .2s ease}@keyframes sp-fade-in{0%{opacity:0}to{opacity:1}}@keyframes sp-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.sp-win-inner{position:relative;background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #22C55E;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;width:100%;max-width:400px;animation:sp-slide-up .3s ease}.sp-win-check{font-size:1.8rem;color:#22c55e;line-height:1}.sp-win-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.sp-win-body{font-family:DM Sans,sans-serif;font-size:.875rem;color:#777;margin:0;max-width:280px}.sp-win-actions{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}.sp-win-next{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#111;background:#f59e0b;border:none;border-radius:6px;padding:9px 22px;cursor:pointer;transition:filter .15s}.sp-win-next:hover{filter:brightness(1.1)}.sp-win-next--outline{background:transparent;border:1px solid #F59E0B;color:#f59e0b;filter:none}.sp-win-next--outline:hover{background:#f59e0b1a;filter:none}.sp-win-home{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;text-decoration:none;border:1px solid #333;border-radius:6px;padding:9px 22px;transition:color .15s,border-color .15s}.sp-win-home:hover{color:#fff;border-color:#666}.sp-win--inline{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:sp-slide-up .3s ease;padding:0}.sp-win--inline .sp-win-inner{animation:none}.sp-win-close{position:absolute;top:8px;right:12px;font-size:1.5rem;line-height:1;color:#666;background:transparent;border:none;cursor:pointer;padding:4px 8px;transition:color .15s}.sp-win-close:hover{color:#fff}.sp-win--inline .sp-win-close{display:none}.sp-actions-solved{display:flex;gap:10px;align-items:center}@media (max-width: 600px){.sp-main{gap:16px;padding:16px 10px 32px}.sp-diff-btn{padding:6px 10px;font-size:.74rem}}.ng-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}.ng-board{display:flex;flex-direction:column;-webkit-user-select:none;user-select:none;touch-action:manipulation;-webkit-touch-callout:none}.ng-board--solution .ng-cells{border-color:#6b7280}.ng-board-top{display:flex;flex-direction:row}.ng-corner{width:var(--clue-w);height:var(--clue-h);flex-shrink:0}.ng-col-clues{display:grid}.ng-col-clue{height:var(--clue-h);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:6px;gap:3px}.ng-board-middle{display:flex;flex-direction:row}.ng-row-clues{width:var(--clue-w);flex-shrink:0;display:flex;flex-direction:column}.ng-row-clue{height:var(--cell-size);display:flex;flex-direction:row;align-items:center;justify-content:flex-end;padding-right:6px;gap:4px}.ng-cells{display:grid;border:2px solid #3a3a3a;overflow:hidden;transition:border-color .25s}.ng-cell{width:var(--cell-size);height:var(--cell-size);border-right:1px solid #232323;border-bottom:1px solid #232323;box-sizing:border-box;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#1a1a1a;flex-shrink:0;transition:background .06s}.ng-cell:hover{background:#222}.ng-cell--filled{background:#14b8a6}.ng-cell--filled:hover{background:#0d9488}.ng-cell--crossed{background:#1a1a1a}.ng-cell--thick-r{border-right:2px solid #3a3a3a}.ng-cell--thick-b{border-bottom:2px solid #3a3a3a}.ng-cross{color:#4a4a4a;font-size:calc(var(--cell-size) * .55);font-family:DM Sans,sans-serif;font-weight:700;line-height:1;pointer-events:none}.ng-clue-chip{display:inline-flex;align-items:center;justify-content:center;min-width:clamp(14px,calc(var(--cell-size) * .62),26px);height:clamp(14px,calc(var(--cell-size) * .62),26px);padding:0 3px;background:#1e1e1e;border:1px solid #2e2e2e;border-radius:5px;font-family:DM Sans,sans-serif;font-size:clamp(8px,calc(var(--cell-size) * .36),14px);font-weight:700;color:#888;line-height:1;box-sizing:border-box;flex-shrink:0}.ng-clue-chip--zero{color:#333;border-color:#222;background:transparent}.ng-clue--solved .ng-clue-chip{background:#14b8a61f;border-color:#14b8a647;color:#14b8a6}.ng-bar{display:flex;align-items:center;justify-content:space-between;padding:0 2px}.ng-status{font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600}.ng-status--ok{color:#22c55e}.ng-status--info{color:#555}.ng-solution-label{font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;color:#6b7280;letter-spacing:.1em;text-transform:uppercase}.ng-reset-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#777;background:transparent;border:1px solid #333;border-radius:6px;padding:5px 14px;cursor:pointer;transition:color .15s,border-color .15s}.ng-reset-btn:hover{color:#fff;border-color:#666}.ng-controls{display:flex}.ng-ctrl-btn{flex:1;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;color:#888;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:9px 0;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.ng-ctrl-btn:hover{color:#ccc;border-color:#555}.ng-ctrl-btn--on,.ng-ctrl-btn--on:hover{color:#14b8a6;border-color:#14b8a6}.ng-hint{font-family:DM Sans,sans-serif;font-size:.75rem;color:#444;text-align:center;margin:0}.np{min-height:100dvh;display:flex;flex-direction:column;background:#111;padding-top:58px}.np-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;border-bottom:1px solid #2e2e2e;background:#111;position:fixed;top:0;left:0;right:0;z-index:10}.np-back{display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#777;text-decoration:none;transition:color .15s;min-width:80px}.np-back:hover{color:#fff}.np-title-group{display:flex;flex-direction:column;align-items:center;gap:1px}.np-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#fff;margin:0;line-height:1}.np-subtitle{font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:500;color:#14b8a6;letter-spacing:.1em;text-transform:uppercase}.np-header-spacer{min-width:80px}.np-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:24px;padding:0 16px 48px}.np-instructions{font-family:DM Sans,sans-serif;font-size:.875rem;color:#666;text-align:center;max-width:360px;margin:12px 0 0;line-height:1.5}.np-difficulty{display:flex;gap:6px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:4px}.np-diff-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#666;background:transparent;border:none;border-radius:5px;padding:6px 14px;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.03em;white-space:nowrap}.np-diff-btn:hover{color:#bbb}.np-diff-btn--active{background:#14b8a6;color:#111}.np-diff-btn--active:hover{color:#111}.np-actions{display:flex;gap:10px;align-items:center}.np-giveup-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#555;background:transparent;border:1px solid #2a2a2a;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.np-giveup-btn:hover{color:#ef4444;border-color:#ef4444}.np-new-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;background:transparent;border:1px solid #333;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.np-new-btn:hover{color:#fff;border-color:#666}.np-solution{width:100%;max-width:480px;animation:np-slide-up .4s ease}.np-solution-inner{background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #6b7280;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.np-solution-icon{font-size:1.8rem;font-family:Playfair Display,serif;font-weight:700;color:#6b7280;line-height:1}.np-win{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#000000d1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:np-fade-in .2s ease}@keyframes np-fade-in{0%{opacity:0}to{opacity:1}}@keyframes np-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.np-win-inner{position:relative;background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #22C55E;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;width:100%;max-width:400px;animation:np-slide-up .3s ease}.np-win-check{font-size:1.8rem;color:#22c55e;line-height:1}.np-win-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.np-win-body{font-family:DM Sans,sans-serif;font-size:.875rem;color:#777;margin:0;max-width:280px}.np-win-actions{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}.np-win-next{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#111;background:#14b8a6;border:none;border-radius:6px;padding:9px 22px;cursor:pointer;transition:filter .15s}.np-win-next:hover{filter:brightness(1.1)}.np-win-next--outline{background:transparent;border:1px solid #14B8A6;color:#14b8a6;filter:none}.np-win-next--outline:hover{background:#14b8a61a;filter:none}.np-win-home{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;text-decoration:none;border:1px solid #333;border-radius:6px;padding:9px 22px;transition:color .15s,border-color .15s}.np-win-home:hover{color:#fff;border-color:#666}.np-win--inline{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:np-slide-up .3s ease;padding:0}.np-win--inline .np-win-inner{animation:none}.np-win-close{position:absolute;top:8px;right:12px;font-size:1.5rem;line-height:1;color:#666;background:transparent;border:none;cursor:pointer;padding:4px 8px;transition:color .15s}.np-win-close:hover{color:#fff}.np-win--inline .np-win-close{display:none}.np-actions-solved{display:flex;gap:10px;align-items:center}@media (max-width: 600px){.np-main{gap:16px;padding:16px 10px 32px}.np-diff-btn{padding:6px 10px;font-size:.74rem}}.fg-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;--grid-side: min(95vw, max(480px, calc(var(--size) * 52px)), 600px)}.fg-grid{position:relative;width:var(--grid-side);aspect-ratio:1;border:2px solid #3a3a3a;border-radius:6px;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none;cursor:crosshair;transition:border-color .25s ease}.fg-grid--solved{border-color:#22c55e}.fg-grid--solution{border-color:#6b7280;cursor:default}.fg-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.fg-cells{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(var(--size),1fr);grid-template-rows:repeat(var(--size),1fr);pointer-events:none}.fg-cell{border-right:1px solid #1e1e1e;border-bottom:1px solid #1e1e1e}.fg-bar{display:flex;align-items:center;justify-content:space-between;width:var(--grid-side);padding:0 2px}.fg-progress{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#ccc}.fg-progress-label{font-weight:400;color:#555}.fg-filled-label{font-weight:400;color:#a855f7}.fg-solution-label{font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;color:#6b7280;letter-spacing:.1em;text-transform:uppercase}.fg-reset-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#777;background:transparent;border:1px solid #333;border-radius:6px;padding:5px 14px;cursor:pointer;transition:color .15s,border-color .15s}.fg-reset-btn:hover{color:#fff;border-color:#666}.fg-hint{font-family:DM Sans,sans-serif;font-size:.75rem;color:#444;text-align:center;margin:0}.fp{min-height:100dvh;display:flex;flex-direction:column;background:#111;padding-top:58px}.fp-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;border-bottom:1px solid #2e2e2e;background:#111;position:fixed;top:0;left:0;right:0;z-index:10}.fp-back{display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#777;text-decoration:none;transition:color .15s;min-width:80px}.fp-back:hover{color:#fff}.fp-title-group{display:flex;flex-direction:column;align-items:center;gap:1px}.fp-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#fff;margin:0;line-height:1}.fp-subtitle{font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:500;color:#a855f7;letter-spacing:.1em;text-transform:uppercase}.fp-header-spacer{min-width:80px}.fp-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:24px;padding:0 16px 48px}.fp-instructions{font-family:DM Sans,sans-serif;font-size:.875rem;color:#666;text-align:center;max-width:360px;margin:12px 0 0;line-height:1.5}.fp-difficulty{display:flex;gap:6px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:4px}.fp-diff-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#666;background:transparent;border:none;border-radius:5px;padding:6px 14px;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.03em;white-space:nowrap}.fp-diff-btn:hover{color:#bbb}.fp-diff-btn--active{background:#a855f7;color:#fff}.fp-diff-btn--active:hover{color:#fff}.fp-actions{display:flex;gap:10px;align-items:center}.fp-giveup-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#555;background:transparent;border:1px solid #2a2a2a;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.fp-giveup-btn:hover{color:#ef4444;border-color:#ef4444}.fp-new-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;background:transparent;border:1px solid #333;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.fp-new-btn:hover{color:#fff;border-color:#666}.fp-solution{width:100%;max-width:480px;animation:fp-slide-up .4s ease}.fp-solution-inner{background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #6b7280;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.fp-solution-icon{font-size:1.8rem;font-family:Playfair Display,serif;font-weight:700;color:#6b7280;line-height:1}.fp-win{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#000000d1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fp-fade-in .2s ease}@keyframes fp-fade-in{0%{opacity:0}to{opacity:1}}@keyframes fp-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fp-win-inner{position:relative;background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #22C55E;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;width:100%;max-width:400px;animation:fp-slide-up .3s ease}.fp-win-check{font-size:1.8rem;color:#22c55e;line-height:1}.fp-win-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.fp-win-body{font-family:DM Sans,sans-serif;font-size:.875rem;color:#777;margin:0;max-width:280px}.fp-win-actions{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}.fp-win-next{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#fff;background:#a855f7;border:none;border-radius:6px;padding:9px 22px;cursor:pointer;transition:filter .15s}.fp-win-next:hover{filter:brightness(1.1)}.fp-win-next--outline{background:transparent;border:1px solid #A855F7;color:#a855f7;filter:none}.fp-win-next--outline:hover{background:#a855f71a;filter:none}.fp-win-home{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;text-decoration:none;border:1px solid #333;border-radius:6px;padding:9px 22px;transition:color .15s,border-color .15s}.fp-win-home:hover{color:#fff;border-color:#666}.fp-win--inline{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:fp-slide-up .3s ease;padding:0}.fp-win--inline .fp-win-inner{animation:none}.fp-win-close{position:absolute;top:8px;right:12px;font-size:1.5rem;line-height:1;color:#666;background:transparent;border:none;cursor:pointer;padding:4px 8px;transition:color .15s}.fp-win-close:hover{color:#fff}.fp-win--inline .fp-win-close{display:none}.fp-actions-solved{display:flex;gap:10px;align-items:center}@media (max-width: 600px){.fp-main{gap:16px;padding:16px 10px 32px}.fp-diff-btn{padding:6px 10px;font-size:.74rem}}.ig-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;--grid-side: min(95vw, max(380px, calc(var(--size) * 40px)), 520px)}.ig-grid{position:relative;width:var(--grid-side);aspect-ratio:1;display:grid;grid-template-columns:repeat(var(--cols),1fr);grid-template-rows:repeat(var(--rows),1fr);border:2px solid #3a3a3a;border-radius:6px;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none;cursor:crosshair;transition:border-color .25s ease;background:#1e1e1e}.ig-grid--solved{border-color:#22c55e}.ig-grid--solution{border-color:#6b7280;cursor:default}.ig-cell{display:flex;align-items:center;justify-content:center;background:#1a3a52;transition:background-color .08s ease;border-right:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}.ig-cell--sea{background:#1a3a52}.ig-cell--island{background:#2d8a6e;border-right:1px solid rgba(0,0,0,.15);border-bottom:1px solid rgba(0,0,0,.15)}.ig-cell--clue{background:#2d8a6e;border-right:1px solid rgba(0,0,0,.15);border-bottom:1px solid rgba(0,0,0,.15);cursor:default}.ig-cell--clue.ig-cell--sea{background:#2d8a6e}.ig-cell--island+.ig-cell--island,.ig-cell--clue+.ig-cell--island,.ig-cell--island+.ig-cell--clue,.ig-cell--clue+.ig-cell--clue{border-left-color:#0000001a}.ig-num{font-family:Playfair Display,serif;font-size:clamp(.55rem,calc(var(--grid-side, 400px) / var(--size) * .38),1.3rem);font-weight:700;color:#fef3c7;text-shadow:0 1px 2px rgba(0,0,0,.4);line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2}.ig-solution-label{font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;color:#6b7280;letter-spacing:.1em;text-transform:uppercase}.ig-bar{display:flex;align-items:center;justify-content:space-between;width:var(--grid-side);padding:0 2px}.ig-progress{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#ccc}.ig-progress-label{font-weight:400;color:#555}.ig-reset-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#777;background:transparent;border:1px solid #333;border-radius:6px;padding:5px 14px;cursor:pointer;transition:color .15s,border-color .15s}.ig-reset-btn:hover{color:#fff;border-color:#666}.ig-hint{font-family:DM Sans,sans-serif;font-size:.75rem;color:#444;text-align:center;margin:0}.ip{min-height:100dvh;display:flex;flex-direction:column;background:#111;padding-top:58px}.ip-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;border-bottom:1px solid #2e2e2e;background:#111;position:fixed;top:0;left:0;right:0;z-index:10}.ip-back{display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#777;text-decoration:none;transition:color .15s;min-width:80px}.ip-back:hover{color:#fff}.ip-title-group{display:flex;flex-direction:column;align-items:center;gap:1px}.ip-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#fff;margin:0;line-height:1}.ip-subtitle{font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:500;color:#2d8a6e;letter-spacing:.1em;text-transform:uppercase}.ip-header-spacer{min-width:80px}.ip-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:24px;padding:0 16px 48px}.ip-instructions{font-family:DM Sans,sans-serif;font-size:.875rem;color:#666;text-align:center;max-width:360px;margin:12px 0 0;line-height:1.5}.ip-difficulty{display:flex;gap:6px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:4px}.ip-diff-btn{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:#666;background:transparent;border:none;border-radius:5px;padding:6px 14px;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.03em;white-space:nowrap}.ip-diff-btn:hover{color:#bbb}.ip-diff-btn--active{background:#2d8a6e;color:#fff}.ip-diff-btn--active:hover{color:#fff}.ip-actions{display:flex;gap:10px;align-items:center}.ip-giveup-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#555;background:transparent;border:1px solid #2a2a2a;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.ip-giveup-btn:hover{color:#2d8a6e;border-color:#2d8a6e}.ip-new-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;background:transparent;border:1px solid #333;border-radius:6px;padding:8px 22px;cursor:pointer;transition:color .15s,border-color .15s}.ip-new-btn:hover{color:#fff;border-color:#666}.ip-solution{width:100%;max-width:480px;animation:ip-slide-up .4s ease}.ip-solution-inner{background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #6b7280;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.ip-solution-icon{font-size:1.8rem;font-family:Playfair Display,serif;font-weight:700;color:#6b7280;line-height:1}.ip-win{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#000000d1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:ip-fade-in .2s ease}@keyframes ip-fade-in{0%{opacity:0}to{opacity:1}}@keyframes ip-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.ip-win-inner{position:relative;background:#1a1a1a;border:1px solid #2a2a2a;border-top:3px solid #22C55E;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;width:100%;max-width:400px;animation:ip-slide-up .3s ease}.ip-win-check{font-size:1.8rem;color:#22c55e;line-height:1}.ip-win-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.ip-win-body{font-family:DM Sans,sans-serif;font-size:.875rem;color:#777;margin:0;max-width:280px}.ip-win-actions{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}.ip-win-next{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#fff;background:#2d8a6e;border:none;border-radius:6px;padding:9px 22px;cursor:pointer;transition:filter .15s}.ip-win-next:hover{filter:brightness(1.1)}.ip-win-next--outline{background:transparent;border:1px solid #2d8a6e;color:#2d8a6e;filter:none}.ip-win-next--outline:hover{background:#2d8a6e1a;filter:none}.ip-win-home{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#888;text-decoration:none;border:1px solid #333;border-radius:6px;padding:9px 22px;transition:color .15s,border-color .15s}.ip-win-home:hover{color:#fff;border-color:#666}.ip-win--inline{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:ip-slide-up .3s ease;padding:0}.ip-win--inline .ip-win-inner{animation:none}.ip-win-close{position:absolute;top:8px;right:12px;font-size:1.5rem;line-height:1;color:#666;background:transparent;border:none;cursor:pointer;padding:4px 8px;transition:color .15s}.ip-win-close:hover{color:#fff}.ip-win--inline .ip-win-close{display:none}.ip-actions-solved{display:flex;gap:10px;align-items:center}@media (max-width: 600px){.ip-main{gap:16px;padding:16px 10px 32px}.ip-diff-btn{padding:6px 10px;font-size:.74rem}}.wg{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;position:relative}.wg-toast{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#fff;color:#111;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;padding:8px 16px;border-radius:6px;white-space:nowrap;z-index:20;animation:wg-toast-in .15s ease;pointer-events:none}@keyframes wg-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.wg-board{display:flex;flex-direction:column;gap:6px}.wg-row{display:flex;gap:6px}.wg-row--shake{animation:wg-shake .5s ease}@keyframes wg-shake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}35%{transform:translate(6px)}55%{transform:translate(-4px)}75%{transform:translate(4px)}}.wg-tile{width:62px;height:62px;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:1.75rem;font-weight:800;color:#fff;text-transform:uppercase;border:2px solid #3a3a3a;border-radius:4px;background:transparent;-webkit-user-select:none;user-select:none;box-sizing:border-box}.wg-tile--filled{border-color:#818384}.wg-tile--bump{animation:wg-bump .1s ease}@keyframes wg-bump{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.wg-tile--correct{background:#538d4e;border-color:#538d4e}.wg-tile--present{background:#b59f3b;border-color:#b59f3b}.wg-tile--absent{background:#3a3a3a;border-color:#3a3a3a}.wg-tile--flip{animation:wg-flip .5s ease both}@keyframes wg-flip{0%{transform:rotateX(0);background:transparent;border-color:#818384}49%{transform:rotateX(-89deg);background:transparent;border-color:#818384}51%{transform:rotateX(-91deg)}to{transform:rotateX(0)}}.wg-keyboard{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:500px}.wg-key-row{display:flex;gap:6px;justify-content:center}.wg-key{height:58px;min-width:43px;padding:0 6px;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;color:#fff;background:#818384;border:none;border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none;text-transform:uppercase;transition:background .15s,filter .1s}.wg-key:hover{filter:brightness(1.15)}.wg-key:active{filter:brightness(.9)}.wg-key--wide{min-width:65px;font-size:.75rem}.wg-key--correct{background:#538d4e}.wg-key--present{background:#b59f3b}.wg-key--absent{background:#3a3a3a}@media (max-width: 480px){.wg-tile{width:54px;height:54px;font-size:1.5rem}.wg-key{height:50px;min-width:33px;font-size:.75rem}.wg-key--wide{min-width:52px;font-size:.68rem}}@media (max-width: 380px){.wg-tile{width:46px;height:46px;font-size:1.3rem}.wg-board,.wg-row{gap:4px}.wg-key{height:46px;min-width:28px;font-size:.7rem}.wg-key--wide{min-width:44px}.wg-key-row{gap:4px}}.wp{min-height:100vh;display:flex;flex-direction:column;background:#111}.wp-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:58px;border-bottom:1px solid #222;background:#111;position:sticky;top:0;z-index:10}.wp-back{display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;color:#777;text-decoration:none;transition:color .15s;min-width:80px}.wp-back:hover{color:#fff}.wp-title-group{display:flex;flex-direction:column;align-items:center;gap:1px}.wp-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#fff;margin:0;line-height:1}.wp-subtitle{font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:500;color:#22c55e;letter-spacing:.1em;text-transform:uppercase}.wp-header-spacer{min-width:80px}.wp-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:20px;padding:24px 16px 48px}.wp-instructions{font-family:DM Sans,sans-serif;font-size:.875rem;color:#666;text-align:center;max-width:360px;margin:0;line-height:1.5}.wp-result{width:100%;max-width:480px;animation:wp-slide-up .4s ease}@keyframes wp-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.wp-result-inner{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.wp-result--win .wp-result-inner{border-top:3px solid #22C55E}.wp-result--lose .wp-result-inner{border-top:3px solid #ef4444}.wp-result-icon{font-size:1.8rem;line-height:1}.wp-result--win .wp-result-icon{color:#22c55e}.wp-result--lose .wp-result-icon{color:#ef4444}.wp-result-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.wp-result-body{font-family:DM Sans,sans-serif;font-size:.9rem;color:#888;margin:0}.wp-result-body strong{color:#ccc;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.wp-result-actions{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap;justify-content:center}.wp-btn{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;border-radius:6px;padding:9px 22px;cursor:pointer;transition:filter .15s,color .15s,border-color .15s;text-decoration:none;display:inline-flex;align-items:center}.wp-btn--primary{background:#22c55e;color:#fff;border:none}.wp-btn--primary:hover{filter:brightness(1.1)}.wp-btn--ghost{background:transparent;color:#888;border:1px solid #333}.wp-btn--ghost:hover{color:#fff;border-color:#666}@media (max-width: 600px){.wp-main{gap:16px;padding:16px 12px 40px}}.lpm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#000000b8;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.lpm-modal{background:#161616;border:1px solid #2a2a2a;border-radius:20px;padding:32px 32px 28px;max-width:360px;width:100%;display:flex;flex-direction:column;align-items:center;text-align:center}.lpm-icon-wrap{width:48px;height:48px;border-radius:14px;background:#1e1e1e;border:1px solid #2a2a2a;display:flex;align-items:center;justify-content:center;color:#aaa;margin-bottom:20px}.lpm-title{font-family:Playfair Display,serif;font-size:1.4rem;font-weight:900;color:#fff;margin:0 0 10px;letter-spacing:-.3px}.lpm-sub{font-family:DM Sans,sans-serif;font-size:.88rem;color:#666;margin:0 0 28px;line-height:1.55}.lpm-actions{display:flex;flex-direction:column;gap:10px;width:100%}.lpm-btn{width:100%;border:none;border-radius:11px;padding:13px 20px;font-family:DM Sans,sans-serif;font-size:.92rem;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,opacity .15s ease}.lpm-btn--primary{background:#fff;color:#111}.lpm-btn--primary:hover{background:#e8e8e8}.lpm-btn--ghost{background:transparent;color:#555;font-size:.85rem;font-weight:500;padding:8px 20px}.lpm-btn--ghost:hover{color:#999}@media (max-width: 480px){.lpm-modal{padding:26px 22px 22px}.lpm-title{font-size:1.25rem}}.pp-main{background:#111}.pp-section-inner{max-width:1100px;margin:0 auto;padding:0 24px}.pp-section-inner--split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}.pp-section-inner--center{display:flex;flex-direction:column;align-items:center;text-align:center}.pp-eyebrow{font-family:DM Sans,sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#eab308;margin-bottom:14px}.pp-section-title{font-family:Playfair Display,serif;font-size:clamp(1.9rem,3.5vw,2.6rem);font-weight:900;color:#fff;margin:0 0 18px;line-height:1.18;letter-spacing:-.4px}.pp-section-desc{font-family:DM Sans,sans-serif;font-size:.94rem;font-weight:300;color:#777;line-height:1.65;margin:0}.pp-section-desc--center{max-width:460px;margin-bottom:44px}.pp-btn-gold{background:linear-gradient(135deg,#eab308,#f59e0b);color:#111;border:none;padding:14px 34px;border-radius:8px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:filter .15s ease,transform .15s ease}.pp-btn-gold:hover{filter:brightness(1.1);transform:translateY(-1px)}.pp-btn-ghost{background:transparent;color:#eab308;border:1px solid rgba(234,179,8,.35);padding:14px 34px;border-radius:8px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;letter-spacing:.04em;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;transition:background .15s ease,border-color .15s ease}.pp-btn-ghost:hover{background:#eab30814;border-color:#eab308a6}.pp-hero{position:relative;padding:88px 24px 80px;text-align:center;overflow:hidden}.pp-hero__bg-glow{position:absolute;top:-80px;left:50%;transform:translate(-50%);width:700px;height:420px;background:radial-gradient(ellipse at center,rgba(234,179,8,.07) 0%,transparent 68%);pointer-events:none;z-index:0}.pp-hero__inner{position:relative;z-index:1;max-width:560px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:22px}.pp-hero__crown-wrap{position:relative;width:84px;height:84px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.pp-hero__crown-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;background:radial-gradient(ellipse at center,rgba(234,179,8,.22) 0%,transparent 68%);border-radius:50%;animation:pp-pulse 3.2s ease-in-out infinite}@keyframes pp-pulse{0%,to{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.12)}}.pp-hero__crown{position:relative;z-index:1;width:72px;height:72px;object-fit:contain;filter:invert(1) sepia(1) saturate(4) hue-rotate(5deg) brightness(1.05)}.pp-hero__eyebrow{font-family:Playfair Display,serif;font-size:clamp(2.4rem,5.5vw,3.6rem);font-weight:900;line-height:1.13;letter-spacing:-.6px;text-transform:none;color:#eab308;background:none;border:none;padding:0;border-radius:0}.pp-hero__title{font-family:Playfair Display,serif;font-size:clamp(2.4rem,5.5vw,3.6rem);font-weight:900;color:#fff;margin:0;line-height:1.13;letter-spacing:-.6px}.pp-hero__sub{font-family:DM Sans,sans-serif;font-size:1.05rem;font-weight:300;color:#777;margin:0;line-height:1.5}.pp-hero__ctas{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:4px}.pp-hero__active-badge{display:inline-flex;align-items:center;gap:9px;padding:11px 22px;background:#eab30817;border:1px solid rgba(234,179,8,.28);border-radius:100px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;color:#eab308;margin-top:4px}.pp-active-check{color:#22c55e;font-size:1rem;font-weight:700}.pp-hero__trial-note{font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:300;color:#444;letter-spacing:.04em;margin-top:-6px}.pp-features{padding:12px 0 76px;border-bottom:1px solid #1c1c1c}.pp-features .pp-section-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.pp-feature-card{background:#181818;border:1px solid #262626;border-radius:12px;padding:28px 24px 26px;transition:border-color .2s ease,background .2s ease}.pp-feature-card:hover{border-color:#eab30852;background:#191700}.pp-feature-card__icon{display:flex;align-items:center;color:#eab308;margin-bottom:16px}.pp-feature-card__title{font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700;color:#fff;margin:0 0 10px}.pp-feature-card__desc{font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:300;color:#666;line-height:1.62;margin:0}.pp-ranked{padding:84px 0;border-bottom:1px solid #1c1c1c}.pp-perks-list{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-direction:column;gap:11px}.pp-perks-list li{font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:400;color:#999;padding-left:22px;position:relative;line-height:1.4}.pp-perks-list li:before{content:"✦";position:absolute;left:0;top:1px;color:#eab308;font-size:.55rem;line-height:1.7}.pp-ranked__cards{display:flex;flex-direction:column;gap:9px}.pp-ranked-card{position:relative;background:#181818;border:1px solid #262626;border-radius:10px;padding:14px 16px 14px 22px;display:flex;align-items:center;gap:13px;overflow:hidden;transition:border-color .2s ease,background .2s ease}.pp-ranked-card:hover{border-color:var(--game-color);background:#1a1a1a}.pp-ranked-card__side-accent{position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--game-color);border-radius:10px 0 0 10px;opacity:.7}.pp-ranked-card__icon{font-size:1.3rem;color:var(--game-color);width:26px;text-align:center;flex-shrink:0}.pp-ranked-card__name{font-family:Playfair Display,serif;font-size:.98rem;font-weight:700;color:#e0e0e0;flex:1}.pp-ranked-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;background:#eab3081a;border:1px solid rgba(234,179,8,.28);border-radius:100px;font-family:DM Sans,sans-serif;font-size:.67rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:#eab308;flex-shrink:0}.pp-exclusive{padding:84px 0;border-bottom:1px solid #1c1c1c}.pp-excl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%}.pp-excl-card{position:relative;background:#181818;border:1px solid #262626;border-radius:12px;padding:28px 22px 22px;display:flex;flex-direction:column;gap:13px;overflow:hidden;transition:border-color .2s ease,background .2s ease,transform .15s ease}.pp-excl-card:hover{border-color:var(--game-color);background:#1e1e1e;transform:translateY(-2px)}.pp-excl-card:hover .pp-excl-card__accent{opacity:1}.pp-excl-card__accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--game-color);opacity:.38;border-radius:12px 12px 0 0;transition:opacity .2s ease}.pp-excl-card__premium-tag{position:absolute;top:14px;right:14px;display:inline-flex;align-items:center;gap:5px;padding:3px 9px 3px 7px;background:#eab3081a;border:1px solid rgba(234,179,8,.28);border-radius:100px;font-family:DM Sans,sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#eab308}.pp-excl-card__crown-img{width:10px;height:10px;object-fit:contain;filter:invert(1) sepia(1) saturate(4) hue-rotate(5deg)}.pp-excl-card__icon{font-size:1.9rem;line-height:1;color:var(--game-color);height:34px;display:flex;align-items:center;margin-top:6px}.pp-excl-card__body{flex:1;display:flex;flex-direction:column;gap:7px}.pp-excl-card__title-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.pp-excl-card__name{font-family:Playfair Display,serif;font-size:1.25rem;font-weight:700;color:#fff;margin:0}.pp-excl-card__subtitle{font-family:DM Sans,sans-serif;font-size:.68rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--game-color);opacity:.65}.pp-excl-card__desc{font-family:DM Sans,sans-serif;font-size:.865rem;font-weight:300;color:#666;line-height:1.58;margin:0}.pp-excl-card__footer{display:flex;align-items:center;justify-content:flex-end;margin-top:2px}.pp-excl-card__locked-label{font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:#eab30880}.pp-pricing{padding:84px 0 80px}.pp-pricing-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:620px;width:100%;margin:0 auto 28px}.pp-price-card{position:relative;background:#181818;border:1px solid #262626;border-radius:14px;padding:32px 26px 28px;display:flex;flex-direction:column;gap:18px;transition:border-color .2s ease}.pp-price-card:not(.pp-price-card--featured):hover{border-color:#3a3a3a}.pp-price-card--featured{background:#131100;border-color:#eab30899;box-shadow:0 0 0 1px #eab3081f,0 8px 40px #eab30814}.pp-price-card__best-badge{position:absolute;top:-11px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#eab308,#f59e0b);color:#111;font-family:DM Sans,sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:3px 13px;border-radius:100px;white-space:nowrap}.pp-price-card__plan{font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#555}.pp-price-card--featured .pp-price-card__plan{color:#eab308a6}.pp-price-card__amount{display:flex;align-items:baseline;gap:1px;line-height:1}.pp-price-card__currency{font-family:DM Sans,sans-serif;font-size:1.05rem;font-weight:600;color:#888;align-self:flex-start;margin-top:5px}.pp-price-card__price{font-family:Playfair Display,serif;font-size:2.9rem;font-weight:900;color:#fff;letter-spacing:-1.5px;line-height:1}.pp-price-card--featured .pp-price-card__price{color:#eab308}.pp-price-card__period{font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:400;color:#444;margin-left:2px}.pp-price-card__price-block{display:flex;flex-direction:column;gap:8px}.pp-price-card__billed-row{display:flex;align-items:center;gap:8px}.pp-price-card__billed{font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:300;color:#444}.pp-price-card__save-tag{display:inline-block;background:#22c55e1a;border:1px solid rgba(34,197,94,.24);color:#22c55e;font-family:DM Sans,sans-serif;font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:100px}.pp-price-card__perks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px;flex:1}.pp-price-card__perks li{font-family:DM Sans,sans-serif;font-size:.84rem;font-weight:400;color:#777;padding-left:20px;position:relative;line-height:1.4}.pp-price-card__perks li:before{content:"✓";position:absolute;left:0;color:#eab308;font-size:.78rem;font-weight:700;top:0}.pp-price-card--featured .pp-price-card__perks li{color:#999}.pp-price-card__btn{width:100%;padding:13px;border-radius:8px;font-family:DM Sans,sans-serif;font-size:.84rem;font-weight:600;letter-spacing:.04em;cursor:pointer;border:none;transition:filter .15s ease,background .15s ease,border-color .15s ease}.pp-price-card__btn:disabled{opacity:.5;cursor:default}.pp-price-card__btn--gold{background:linear-gradient(135deg,#eab308,#f59e0b);color:#111}.pp-price-card__btn--gold:not(:disabled):hover{filter:brightness(1.1)}.pp-price-card__btn--outline{background:transparent;border:1px solid #2a2a2a;color:#777}.pp-price-card__btn--outline:not(:disabled):hover{border-color:#eab30880;color:#eab308;background:#eab3080a}.pp-pricing-footnote{font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:300;color:#3a3a3a;text-align:center;margin:0;letter-spacing:.02em}@media (max-width: 900px){.pp-features .pp-section-inner{grid-template-columns:1fr;gap:12px}.pp-section-inner--split{grid-template-columns:1fr;gap:52px}.pp-excl-grid{grid-template-columns:1fr}}@media (max-width: 600px){.pp-hero{padding:60px 16px 52px}.pp-section-inner{padding:0 16px}.pp-ranked,.pp-exclusive{padding:60px 0}.pp-pricing{padding:60px 0 52px}.pp-features{padding:8px 0 60px}.pp-pricing-cards{grid-template-columns:1fr;max-width:100%;gap:24px}.pp-hero__title{font-size:2.2rem}.pp-section-title{font-size:1.85rem}}.rp{min-height:100dvh;background:#0d0d0d;display:flex;flex-direction:column;padding-bottom:calc(64px + env(safe-area-inset-bottom))}.rp-main{flex:1;padding:0 14px;max-width:520px;margin:0 auto;width:100%;box-sizing:border-box}.rp-hero{text-align:center;padding:20px 0 18px;border-bottom:1px solid #1a1a1a;margin-bottom:14px}.rp-hero-icon{color:gold;display:block;margin:0 auto 10px}.rp-hero-title{font-size:1.35rem;font-weight:800;color:#fff;margin:0 0 5px;letter-spacing:-.03em}.rp-hero-sub{font-size:.76rem;color:#4a4a4a;margin:0 0 16px}.rp-tier-strip{display:flex;align-items:center;justify-content:center;gap:5px;flex-wrap:wrap}.rp-tier-pip{display:inline-flex;align-items:center;gap:4px;font-size:.67rem;font-weight:700;letter-spacing:.01em}.rp-tier-arrow{color:#252525;font-size:1rem;line-height:1}.rp-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.rp-card{display:flex;align-items:center;gap:13px;background:#111;border:1px solid #1e1e1e;border-radius:14px;padding:15px 13px;text-decoration:none;transition:background .15s ease,border-color .15s ease,transform .1s ease;cursor:pointer}.rp-card:hover{border-color:#2a2a2a;background:#141414}.rp-card:active{transform:scale(.985);background:#161616}.rp-card-game-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rp-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.rp-card-name-row{display:flex;align-items:baseline;gap:7px}.rp-card-name{font-size:.9rem;font-weight:700;color:#e8e8e8;line-height:1}.rp-card-sub{font-size:.7rem;color:#3a3a3a;font-weight:500}.rp-card-rank-row{display:flex;align-items:center;gap:7px}.rp-rank-chip{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:20px;letter-spacing:.025em;flex-shrink:0}.rp-card-elo{font-size:.72rem;color:#404040;font-variant-numeric:tabular-nums}.rp-card-diff{font-size:.7rem;font-weight:600;opacity:.7}.rp-card-progress-bar{height:3px;background:#1e1e1e;border-radius:2px;overflow:hidden}.rp-card-progress-fill{height:100%;border-radius:2px;transition:width .5s ease}.rp-card-progress-label{font-size:.64rem;color:#333}.rp-card-arrow{flex-shrink:0;color:#333;transition:color .15s}.rp-card:hover .rp-card-arrow{color:#555}.rp-rules{border-top:1px solid #161616;padding:16px 0 8px}.rp-rules-title{font-size:.72rem;font-weight:700;color:#383838;text-transform:uppercase;letter-spacing:.08em;margin:0 0 8px}.rp-rules-desc{font-size:.76rem;color:#484848;margin:0 0 14px;line-height:1.5}.rp-rules-desc strong{color:#666;font-weight:700}@media (min-width: 900px){.rp-main{max-width:640px}}.rgp{min-height:100dvh;background:#0d0d0d;display:flex;flex-direction:column}.rgp-header{display:flex;align-items:center;justify-content:space-between;padding:0 14px;height:54px;border-bottom:1px solid #1a1a1a;gap:10px;flex-shrink:0}.rgp-back{display:flex;align-items:center;gap:4px;color:#555;text-decoration:none;font-size:.82rem;font-weight:600;flex-shrink:0;transition:color .15s}.rgp-back:hover{color:#888}.rgp-give-up{display:flex;align-items:center;gap:5px;background:none;border:none;padding:0;cursor:pointer;color:#3a3a3a;font-size:.82rem;font-weight:600;flex-shrink:0;transition:color .15s}.rgp-give-up:hover{color:#ef4444}.rgp-title-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0}.rgp-game-name{font-size:.92rem;font-weight:700;color:#e8e8e8;line-height:1}.rgp-rank-chip{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;font-weight:700;letter-spacing:.02em;opacity:.85}.rgp-timer{display:flex;align-items:center;gap:5px;font-size:.9rem;font-weight:700;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:52px;justify-content:flex-end;transition:color .4s ease}.rgp-timer-text{letter-spacing:-.01em}.rgp-timer--normal{color:#666}.rgp-timer--warning{color:#f59e0b}.rgp-timer--critical{color:#ef4444;animation:timer-pulse .75s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.45}}.rgp-bar-wrap{height:3px;background:#161616;flex-shrink:0}.rgp-bar-fill{height:100%;transition:width .1s linear,background-color .4s ease;border-radius:0 2px 2px 0}.rgp-bar-fill--normal{background:#22c55e}.rgp-bar-fill--warning{background:#f59e0b}.rgp-bar-fill--critical{background:#ef4444}.rgp-main{flex:1;display:flex;flex-direction:column;align-items:center;overflow-y:auto;padding:20px 0 calc(64px + env(safe-area-inset-bottom))}.rgp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;background:#000000a6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:overlay-fade .2s ease forwards}@keyframes overlay-fade{0%{opacity:0}to{opacity:1}}.rgp-overlay-card{width:100%;background:#111;border-top:1px solid #222;border-radius:22px 22px 0 0;padding:24px 22px;padding-bottom:max(28px,calc(28px + env(safe-area-inset-bottom)));animation:card-slide-up .35s cubic-bezier(.34,1.56,.64,1) forwards;max-width:520px;margin:0 auto;box-sizing:border-box}@keyframes card-slide-up{0%{transform:translateY(120%)}to{transform:translateY(0)}}.rgp-overlay-status{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:700;margin-bottom:18px}.rgp-overlay-status--win{color:#22c55e}.rgp-overlay-status--loss{color:#ef4444}.rgp-overlay-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}.rgp-overlay-status--win .rgp-overlay-icon{background:#22c55e1f}.rgp-overlay-status--loss .rgp-overlay-icon{background:#ef44441f}.rgp-change{font-size:3.8rem;font-weight:900;line-height:1;margin-bottom:10px;font-variant-numeric:tabular-nums;letter-spacing:-.05em;animation:change-pop .45s cubic-bezier(.34,1.56,.64,1) .05s both}@keyframes change-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.rgp-change--up{color:#22c55e}.rgp-change--zero{color:#444}.rgp-change--down{color:#ef4444}.rgp-elo-row{display:flex;align-items:center;gap:7px;font-size:.9rem;margin-bottom:12px}.rgp-elo-old{color:#444;font-variant-numeric:tabular-nums}.rgp-elo-arrow{color:#2a2a2a}.rgp-elo-new{font-weight:700;font-variant-numeric:tabular-nums}.rgp-elo-label{color:#333;font-size:.76rem}.rgp-rank-change{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:700;padding:5px 10px;border-radius:8px;margin-bottom:12px;animation:rank-change-pop .4s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes rank-change-pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.rgp-rank-change--up{background:#22c55e14;color:#22c55e}.rgp-rank-change--down{background:#ef444414;color:#ef4444}.rgp-new-rank-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.rgp-new-rank-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:20px;letter-spacing:.025em}.rgp-new-elo{font-size:.76rem;color:#444;font-variant-numeric:tabular-nums}.rgp-overlay-progress-bar{height:4px;background:#1e1e1e;border-radius:2px;overflow:hidden;margin-bottom:4px}.rgp-overlay-progress-fill{height:100%;border-radius:2px;transition:width .9s cubic-bezier(.34,1.56,.64,1) .25s}.rgp-overlay-progress-label{font-size:.66rem;color:#333;margin-bottom:20px}.rgp-overlay-actions{display:flex;gap:10px}.rgp-btn{flex:1;height:44px;border-radius:10px;font-size:.84rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;border:none;transition:opacity .15s,transform .1s;font-family:inherit;letter-spacing:.01em}.rgp-btn:active{transform:scale(.97)}.rgp-btn--primary{background:#fff;color:#000}.rgp-btn--primary:hover{opacity:.88}.rgp-btn--outline{background:#181818;color:#777;border:1px solid #252525}.rgp-btn--outline:hover{color:#aaa;border-color:#333}@media (min-width: 900px){.rgp-overlay-card{max-width:640px}}.profile-main{max-width:1100px;margin:0 auto;padding:0 24px 80px}.profile-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:12px}.profile-not-found__code{font-family:Playfair Display,serif;font-size:5rem;font-weight:900;color:#2a2a2a;line-height:1}.profile-not-found__title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff}.profile-not-found__sub{font-family:DM Sans,sans-serif;font-size:.9rem;color:#666}.profile-not-found__link{font-family:DM Sans,sans-serif;font-size:.85rem;color:#aaa;margin-top:8px;transition:color .15s ease}.profile-not-found__link:hover{color:#fff}.profile-hero{padding:40px 0 36px;border-bottom:1px solid #1e1e1e}.profile-hero__inner{display:flex;align-items:flex-start;gap:28px}.profile-avatar-wrap{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px}.profile-avatar-frame{position:relative;display:inline-block;line-height:0}.profile-avatar-edit{position:absolute;bottom:0;right:0;width:26px;height:26px;border-radius:50%;background:#252525;border:2px solid #111;display:flex;align-items:center;justify-content:center;color:#bbb;cursor:pointer;transition:background .15s ease,color .15s ease}.profile-avatar-edit:hover{background:#333;color:#fff}.profile-avatar-edit.is-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.profile-avatar-file-input{display:none}.profile-avatar-error{margin:0;max-width:150px;text-align:center;font-family:DM Sans,sans-serif;font-size:.66rem;color:#f87171}.profile-avatar{width:88px;height:88px;border-radius:50%;object-fit:cover;border:2px solid #2a2a2a}.profile-avatar--initials{display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:1.75rem;font-weight:700;color:#fff;letter-spacing:-.5px;border:2px solid rgba(139,92,246,.4)}.profile-info{flex:1;min-width:0}.profile-name-row{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:6px}.profile-name{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:900;color:#fff;letter-spacing:-.5px;line-height:1.1;margin:0}.profile-premium-badge{display:inline-flex;align-items:center;gap:5px;background:#eab3081a;border:1px solid rgba(234,179,8,.32);color:#eab308;font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600;padding:3px 9px 3px 7px;border-radius:100px;letter-spacing:.02em;flex-shrink:0}.profile-premium-crown{width:12px;height:12px;object-fit:contain;filter:invert(1) sepia(1) saturate(4) hue-rotate(5deg) brightness(1.05)}.follow-btn{display:inline-flex;align-items:center;gap:6px;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600;padding:6px 14px;border-radius:100px;border:1.5px solid #fff;background:#fff;color:#111;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;flex-shrink:0}.follow-btn:hover{background:#e5e5e5;border-color:#e5e5e5}.follow-btn--following{background:transparent;border-color:#3a3a3a;color:#aaa}.follow-btn--following:hover{border-color:#ef4444;color:#ef4444}.profile-joined{font-family:DM Sans,sans-serif;font-size:.8rem;color:#555;margin-bottom:14px}.profile-stats-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.profile-stat{display:flex;flex-direction:column;gap:1px}.profile-stat__value{font-family:DM Sans,sans-serif;font-size:1.15rem;font-weight:700;color:#fff;line-height:1.2}.profile-stat__label{font-family:DM Sans,sans-serif;font-size:.72rem;color:#555;text-transform:uppercase;letter-spacing:.06em}.profile-stat-sep{width:1px;height:28px;background:#1e1e1e;flex-shrink:0}.profile-section{padding:36px 0;border-bottom:1px solid #1e1e1e}.profile-section--last{border-bottom:none}.profile-section__heading{display:flex;align-items:center;gap:9px;color:#888;margin-bottom:20px}.profile-section__heading h2{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#666;margin:0}.ranked-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.ranked-card{background:#181818;border:1px solid #242424;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;transition:border-color .15s ease}.ranked-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--game-color, #fff);opacity:.7}.ranked-card:hover{border-color:#333}.ranked-card__game-row{display:flex;align-items:center;gap:7px}.ranked-card__game-icon{font-size:1rem;opacity:.8}.ranked-card__game-name{font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;color:#aaa}.ranked-card__rank-badge{display:inline-flex;align-self:flex-start;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:100px;border:1px solid transparent;letter-spacing:.05em;text-transform:uppercase}.ranked-card__elo{font-family:DM Sans,sans-serif;font-size:1.35rem;font-weight:700;color:#fff;line-height:1}.ranked-card__elo-unit{font-size:.72rem;font-weight:500;color:#555;letter-spacing:.05em}.ranked-card__bar-bg{height:3px;background:#2a2a2a;border-radius:100px;overflow:hidden}.ranked-card__bar-fill{height:100%;border-radius:100px;transition:width .4s ease;opacity:.85}.ranked-card__next-rank{font-family:DM Sans,sans-serif;font-size:.68rem;color:#444;line-height:1.3}.puzzles-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.puzzle-card{background:#181818;border:1px solid #242424;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transition:border-color .15s ease}.puzzle-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--game-color, #fff);opacity:.7}.puzzle-card:hover{border-color:#333}.puzzle-card__header{display:flex;align-items:flex-start;gap:9px}.puzzle-card__game-icon{font-size:1.1rem;opacity:.8;flex-shrink:0;margin-top:1px}.puzzle-card__game-name{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#ddd;line-height:1.2}.puzzle-card__total{font-family:DM Sans,sans-serif;font-size:.72rem;color:#555;margin-top:2px}.puzzle-card__diffs{display:flex;flex-direction:column;gap:7px}.puzzle-card__diff-row{display:flex;align-items:center;justify-content:space-between;gap:7px}.puzzle-card__diff-label{font-family:DM Sans,sans-serif;font-size:.68rem;color:#555;text-transform:uppercase;letter-spacing:.04em}.puzzle-card__diff-count{font-family:DM Sans,sans-serif;font-size:.72rem;color:#888}.cal-container{display:flex;flex-direction:column;gap:12px}.cal-legend-text{font-family:DM Sans,sans-serif;font-size:.8rem;color:#555}.cal-scroll{overflow-x:auto;padding-bottom:4px}.cal-inner{display:flex;flex-direction:column;gap:4px;min-width:max-content}.cal-months-row{display:flex;align-items:flex-end;gap:4px}.cal-axis-spacer{width:22px;flex-shrink:0}.cal-months{display:flex;gap:3px}.cal-month-slot{width:13px;font-family:DM Sans,sans-serif;font-size:.62rem;color:#555;white-space:nowrap;overflow:visible}.cal-grid-row{display:flex;align-items:flex-start;gap:4px}.cal-day-labels{display:flex;flex-direction:column;gap:3px;width:18px;flex-shrink:0}.cal-day-label{height:10px;font-family:DM Sans,sans-serif;font-size:.62rem;color:#555;display:flex;align-items:center;justify-content:flex-end;padding-right:3px}.cal-weeks{display:flex;gap:3px}.cal-week{display:flex;flex-direction:column;gap:3px}.cal-day{width:10px;height:10px;border-radius:2px}.cal-day--future{visibility:hidden}.cal-day--l0{background:#1f1f1f}.cal-day--l1{background:#164525}.cal-day--l2{background:#238636}.cal-day--l3{background:#3fb950}.cal-day--l4{background:#56d364}.cal-color-legend{display:flex;align-items:center;gap:3px;margin-top:4px;padding-left:22px}.cal-color-legend__label{font-family:DM Sans,sans-serif;font-size:.62rem;color:#444;padding:0 4px}@media (max-width: 900px){.ranked-grid,.puzzles-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.profile-main{padding:0 16px 60px}.profile-hero__inner{flex-direction:column;align-items:center;text-align:center;gap:18px}.profile-name-row,.profile-stats-row{justify-content:center}.profile-name{font-size:1.45rem}.ranked-grid,.puzzles-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 420px){.ranked-grid,.puzzles-grid{grid-template-columns:1fr}}.social-main{min-height:calc(100vh - 64px)}.social-inner{max-width:780px;margin:0 auto;padding:48px 24px 80px;display:flex;flex-direction:column;gap:40px}.social-page-header{display:flex;flex-direction:column;gap:6px}.social-page-title{font-family:Playfair Display,serif;font-size:2rem;font-weight:900;color:#fff;letter-spacing:-.5px;margin:0}.social-page-sub{font-family:DM Sans,sans-serif;font-size:.9rem;color:#555;margin:0}.social-search-wrap{position:relative;display:flex;align-items:center}.social-search-icon{position:absolute;left:14px;color:#555;pointer-events:none;flex-shrink:0}.social-search-input{width:100%;background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:13px 44px 13px 42px;font-family:DM Sans,sans-serif;font-size:.95rem;color:#fff;outline:none;transition:border-color .15s ease}.social-search-input::placeholder{color:#444}.social-search-input:focus{border-color:#3a3a3a}.social-search-clear{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#2a2a2a;color:#888;cursor:pointer;transition:background .15s ease,color .15s ease;border:none}.social-search-clear:hover{background:#333;color:#fff}.social-section{display:flex;flex-direction:column;gap:14px}.social-section__header{display:flex;align-items:center;gap:10px}.social-section__title{font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#555;margin:0}.social-section__count{font-family:DM Sans,sans-serif;font-size:.72rem;color:#333;background:#1e1e1e;border:1px solid #2a2a2a;border-radius:100px;padding:2px 8px}.social-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 0;text-align:center}.social-empty__icon{font-size:2rem;margin:0}.social-empty__text{font-family:DM Sans,sans-serif;font-size:.9rem;color:#555;margin:0}.social-user-list{display:flex;flex-direction:column;gap:2px}.user-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#141414;border:1px solid #1e1e1e;border-radius:12px;transition:border-color .15s ease,background .15s ease}.user-card:hover{border-color:#2a2a2a;background:#181818}.user-card__avatar-link{flex-shrink:0;display:block;text-decoration:none}.user-card__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:1px solid #2a2a2a;display:block}.user-card__avatar--initials{display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:700;color:#fff;border:1px solid rgba(255,255,255,.08)}.user-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.user-card__name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-card__name{font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600;color:#fff;text-decoration:none;transition:color .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card__name:hover{color:#ddd}.user-card__premium-badge{display:inline-flex;align-items:center;gap:4px;background:#eab3081a;border:1px solid rgba(234,179,8,.28);color:#eab308;font-family:DM Sans,sans-serif;font-size:.66rem;font-weight:600;padding:2px 7px 2px 5px;border-radius:100px;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.user-card__crown{width:10px;height:10px;object-fit:contain;filter:invert(1) sepia(1) saturate(4) hue-rotate(5deg) brightness(1.05)}.user-card__meta{font-family:DM Sans,sans-serif;font-size:.78rem;color:#555;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.user-card__sep{color:#333}.user-card__actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.user-card__follow-btn{display:inline-flex;align-items:center;gap:5px;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;padding:6px 13px;border-radius:100px;border:1.5px solid #fff;background:#fff;color:#111;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap}.user-card__follow-btn:hover{background:#e5e5e5;border-color:#e5e5e5}.user-card__follow-btn--following{background:transparent;border-color:#2a2a2a;color:#666}.user-card__follow-btn--following:hover{border-color:#ef4444;color:#ef4444}.user-card__you-badge{font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:600;color:#555;background:#1e1e1e;border:1px solid #2a2a2a;border-radius:100px;padding:4px 10px;white-space:nowrap}.user-card__profile-link{display:inline-flex;align-items:center;gap:3px;font-family:DM Sans,sans-serif;font-size:.72rem;color:#444;text-decoration:none;transition:color .15s ease;white-space:nowrap}.user-card__profile-link:hover{color:#888}@media (max-width: 600px){.social-inner{padding:32px 16px 60px;gap:28px}.social-page-title{font-size:1.6rem}.user-card{padding:12px 14px}.user-card__actions{gap:4px}.user-card__profile-link{display:none}}@media (max-width: 420px){.user-card__avatar{width:40px;height:40px}.user-card__meta{display:none}}.login-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:24px}.login-card{display:flex;flex-direction:column;align-items:center;gap:16px;background:#161616;border:1px solid #2a2a2a;border-radius:16px;padding:48px 40px;max-width:380px;width:100%;text-align:center}.login-title{font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;color:#fff;margin:0}.login-subtitle{font-family:DM Sans,sans-serif;font-size:.9rem;color:#777;margin:0;line-height:1.5}.login-google-btn{margin-top:8px;min-height:40px;opacity:0;transition:opacity .12s ease}.login-google-btn.is-ready{opacity:1}.login-error{font-family:DM Sans,sans-serif;font-size:.8rem;color:#fca5a5;margin:0}.settings-main{min-height:calc(100vh - 64px)}.settings-inner{max-width:640px;margin:0 auto;padding:48px 24px 96px;display:flex;flex-direction:column;gap:36px}.settings-page-header{display:flex;flex-direction:column;gap:6px}.settings-page-title{font-family:Playfair Display,serif;font-size:2rem;font-weight:900;color:#fff;letter-spacing:-.5px;margin:0}.settings-page-sub{font-family:DM Sans,sans-serif;font-size:.9rem;color:#555;margin:0}.settings-section{display:flex;flex-direction:column;gap:12px}.settings-section-title{font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#555;margin:0;padding:0 4px}.settings-card{background:#111;border:1px solid #222;border-radius:14px;overflow:hidden}.settings-divider{height:1px;background:#1e1e1e;margin:0 16px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px}.settings-row__left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.settings-row__icon{flex-shrink:0;color:#888;display:flex;align-items:center}.settings-row__text{display:flex;flex-direction:column;gap:2px;min-width:0}.settings-row__label{font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;color:#e0e0e0}.settings-row__desc{font-family:DM Sans,sans-serif;font-size:.78rem;color:#555}.settings-row__control{flex-shrink:0}.settings-toggle{width:44px;height:26px;border-radius:13px;border:none;background:#2a2a2a;cursor:pointer;position:relative;transition:background .2s ease;padding:0;outline:none}.settings-toggle:focus-visible{box-shadow:0 0 0 2px #fff3}.settings-toggle--on{background:#4ade80}.settings-toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s ease;pointer-events:none}.settings-toggle--on .settings-toggle-thumb{transform:translate(18px)}.app{min-height:100vh;display:flex;flex-direction:column;background:#111}.app-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:0;box-sizing:border-box}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:#111;color:#fff;font-family:DM Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-top:env(safe-area-inset-top);padding-bottom:calc(env(safe-area-inset-bottom) + 68px);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}*{-webkit-tap-highlight-color:transparent}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid #fff;outline-offset:3px;border-radius:4px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#111}::-webkit-scrollbar-thumb{background:#2e2e2e;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#444}a{color:inherit;text-decoration:none}button{background:none;border:none;cursor:pointer;color:inherit;font:inherit}img{display:block;max-width:100%}
