:root{--radius-lg:24px;--radius-md:16px;--radius-sm:12px;--font-sans:"Manrope",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-display:"Space Grotesk","Manrope",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}:root,[data-theme=dark]{color-scheme:dark;--bg:#050912;--card-bg:#0b1224eb;--border:#ffffff14;--border-strong:#6ff5c459;--text:#e9f1ff;--subtle:#9fb3d2;--accent:#6ff5c4;--accent-strong:#3ad9ff;--danger:#fb7185;--danger-soft:#ffc0cc;--muted-bg:#ffffff0a;--shadow-1:0 30px 90px #000000a6;--shadow-soft:0 18px 55px #3ad9ff24;--input-bg:#1e293ba6;--overlay-bg:#090e1af2;--glass-bg:#090e1ad9;--panel-bg:var(--overlay-bg);--btn-secondary-bg:#ffffff0a;--btn-secondary-hover:#6ff5c414}[data-theme=light]{color-scheme:light;--bg:#fff;--card-bg:#fff;--border:#00000014;--border-strong:#6ff5c459;--text:#111827;--subtle:#6b7280;--accent:#6ff5c4;--accent-strong:#3ad9ff;--danger:#ef4444;--danger-soft:#fecaca;--muted-bg:#f3f4f6;--shadow-1:0 4px 24px #00000014;--shadow-soft:0 8px 32px #6ff5c414;--input-bg:#f9fafb;--overlay-bg:#fffffffa;--glass-bg:#fffffff2;--panel-bg:var(--overlay-bg);--btn-secondary-bg:#f3f4f6;--btn-secondary-hover:#6ff5c41f}*{box-sizing:border-box}html{height:100%;font-size:clamp(14px,.75vw,16px)}body{--page-padding:clamp(1.1rem,4vw,1.8rem);height:100%;padding:var(--page-padding);padding-bottom:calc(var(--page-padding) + var(--ios-banner-height,0px));background:radial-gradient(circle at 12% 18%,#6ff5c41f,transparent 32%),radial-gradient(circle at 82% 6%,#3ad9ff24,transparent 28%),radial-gradient(circle at 50% 90%,#3ad9ff14,transparent 36%),var(--bg);color:var(--text);min-height:100vh;font-family:var(--font-sans);margin:0;line-height:1.6;position:relative;overflow-x:hidden}html,body{overscroll-behavior:none}button,input,select,textarea{font-family:inherit}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em;margin:0}h1{line-height:1.2}h1,h2,h3,h4,h5,h6,p{margin:0}[data-theme=light] body{background:radial-gradient(circle at 12% 18%,#6ff5c40f,transparent 32%),radial-gradient(circle at 82% 6%,#3ad9ff0f,transparent 28%),var(--bg)}[data-theme=light] .bg-flares{opacity:.4}[data-theme=light] .flare-1{background:radial-gradient(circle,#6ff5c466,#0000 60%)}[data-theme=light] .flare-2{background:radial-gradient(circle,#3ad9ff4d,#0000 55%)}[data-theme=light] .flare-3{background:radial-gradient(circle,#6366f126,#0000 60%)}[data-theme=light] .glow-grid{opacity:.5;background-image:radial-gradient(circle at 1px 1px,#0000000a 1px,#0000 0)}[data-theme=light] .card,[data-theme=light] .profile-card,[data-theme=light] .account-modal,[data-theme=light] .account-modal-content,[data-theme=light] .pm-modal,[data-theme=light] .camera-overlay,[data-theme=light] .image-viewer,[data-theme=light] .game-panel,[data-theme=light] .game-selection-panel,[data-theme=light] .ios-install-banner,[data-theme=light] .queue-game-resume-overlay{-webkit-backdrop-filter:none}[data-theme=light] .card{background:var(--card-bg)}.bg-flares{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.flare{filter:blur(140px);opacity:.7;border-radius:999px;width:420px;height:420px;position:absolute}.flare-1{background:radial-gradient(circle,#6ff5c4cc,#0000 60%);top:-120px;left:-80px}.flare-2{background:radial-gradient(circle,#3ad9ffa6,#0000 55%);top:-60px;right:-40px}.flare-3{background:radial-gradient(circle,#6fa7ff4d,#0000 60%);bottom:-140px;right:16%}.glow-grid{opacity:.08;mix-blend-mode:screen;background-image:radial-gradient(circle at 1px 1px,#ffffff14 1px,#0000 0);background-size:34px 34px;position:absolute;inset:0}.app-shell{z-index:1;flex-direction:column;gap:1.2rem;max-width:1120px;min-height:100%;margin:0 auto;display:flex;position:relative}.app-hero{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#3ad9ff1f,#6ff5c414),#090e1ad9;flex-direction:column;gap:.75rem;padding:clamp(1.1rem,3vw,1.6rem);display:flex}[data-theme=light] .app-hero{background:var(--card-bg);box-shadow:var(--shadow-1)}.app-hero h1{font-size:clamp(1.7rem,4vw,2.3rem)}.hero-top{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:.85rem;display:flex}.hero-actions{flex-wrap:nowrap;justify-content:flex-end;align-items:stretch;gap:.6rem;display:inline-flex}.hero-pm-btn{position:relative}body .hero-pm-btn{border-radius:12px;width:auto;height:auto;padding:.55rem .7rem;line-height:1;display:none;box-shadow:0 4px 12px #0003}body.signed-in .hero-pm-btn{display:inline-flex}.pm-unread-dot{background:#f97373;border-radius:999px;width:.5rem;height:.5rem;position:absolute;top:.15rem;right:.2rem;box-shadow:0 0 0 3px #0f172acc}.coins-pill{border:1px solid var(--border);white-space:nowrap;background:#090e1ae6;border-radius:12px;align-items:center;gap:.3rem;padding:.55rem .9rem;font-size:.95rem;font-weight:700;line-height:1;display:inline-flex;position:relative}[data-theme=light] .coins-pill{background:var(--muted-bg)}.coins-icon{justify-content:center;align-items:center;width:1.1rem;height:1.1rem;display:inline-flex}.coins-icon-svg{width:100%;height:100%;display:block}.coins-text{align-items:baseline;gap:.12rem;display:inline-flex}.coins-help-btn{box-sizing:border-box;border:1px solid var(--border);width:18px;min-width:0;height:18px;min-height:0;color:var(--text-muted);cursor:pointer;background:#ffffff0d;border-radius:999px;justify-content:center;align-items:center;margin-left:.15rem;padding:0;font-size:.78rem;font-weight:800;line-height:1;display:inline-flex}.coins-help-btn:hover{color:var(--text);background:#ffffff1a}.coins-help-popover{z-index:1200;border-radius:var(--radius-lg);border:1px solid var(--border);width:min(320px,92vw);box-shadow:var(--shadow-soft);background:#090e1afa;padding:.9rem 1rem;position:fixed;top:5.4rem;right:1.2rem}[data-theme=light] .coins-help-popover{background:var(--card-bg);box-shadow:var(--shadow-1)}.coins-help-popover h3{margin:0 0 .5rem;font-size:1.1rem}.coins-help-popover ul{color:var(--text-muted);gap:.35rem;margin:0;padding-left:1.1rem;font-size:.95rem;display:grid}.coin-float{z-index:1300;color:var(--accent-strong);text-shadow:0 6px 18px #0000008c;pointer-events:none;font-weight:800;animation:1.6s ease-out forwards coin-float-up;position:fixed}@keyframes coin-float-up{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-36px)}}.hero-profile-btn{border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:.55rem 1rem;font-weight:700;line-height:1;display:inline-flex}.hero-avatar{object-fit:cover;filter:grayscale()opacity(.6);border-radius:50%;width:24px;height:24px;transition:filter .2s}body.signed-in .hero-avatar{filter:none}.hero-shop-btn{border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:.55rem 1rem;font-weight:700;line-height:1;display:inline-flex}.hero-profile-text{display:inline}@media (width<=640px){.hero-top{align-items:center}.hero-actions{flex-wrap:nowrap;justify-content:flex-end;margin-left:auto}}@media (width<=720px){.hero-actions{gap:.4rem}.coins-pill{gap:.2rem;padding:.5rem .6rem;font-size:.85rem}.hero-shop-text{display:none}.hero-shop-btn{padding:.55rem .7rem}.hero-profile-text{display:none}.hero-profile-btn{padding:.55rem .7rem}}@media (width<=480px){.hero-shop-text{display:none}.hero-shop-btn{padding:.55rem .7rem}body.signed-in .hero-profile-text{display:none}body.signed-in .hero-profile-btn{padding:.55rem .7rem}.hero-actions{flex-wrap:nowrap;gap:.35rem}.coins-pill{gap:.2rem;padding:.55rem .6rem;font-size:.85rem}.coins-icon{width:1rem;height:1rem}.coins-help-btn{width:15px;height:15px;font-size:.68rem}}@media (width<=360px){.brand-lockup .eyebrow{display:none}}.brand-lockup{align-items:center;gap:.75rem;display:flex}.brand-mark{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex;overflow:hidden;box-shadow:0 4px 16px #3b82f659}.brand-logo{object-fit:cover;width:100%;height:100%}.live-pill{color:var(--text);background:#3ad9ff1f;border:1px solid #3ad9ff59;border-radius:999px;align-items:center;gap:.45rem;padding:.45rem .85rem;font-weight:700;display:inline-flex;box-shadow:0 8px 20px #3ad9ff2e}.live-pill span{align-items:center;line-height:1;display:inline-flex}.live-pill .dot{background:linear-gradient(135deg,var(--accent),var(--accent-strong));vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;width:10px;height:10px;animation:1.8s ease-out infinite pulse-soft;display:inline-flex;box-shadow:0 0 #6ff5c48c}@keyframes pulse-soft{0%{box-shadow:0 0 #6ff5c48c}70%{box-shadow:0 0 0 8px #6ff5c400}to{box-shadow:0 0 #6ff5c400}}.presence-wrapper{flex-direction:column;align-items:flex-end;gap:.2rem;margin-left:auto;padding-bottom:.35rem;display:flex}@media (width<=600px){.presence-wrapper{align-items:center;width:100%;margin-left:0}.live-pill{margin-inline:auto}}.presence-note{color:var(--subtle);text-align:center;align-self:center;margin:0;font-size:.85rem}.tagline{color:var(--subtle);max-width:760px;font-size:1rem}.hero-pills{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.pill-soft{border:1px dashed var(--border);color:var(--text);background:#ffffff0f}.card{background:linear-gradient(160deg,#ffffff05,#ffffff08),var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);backdrop-filter:blur(6px);padding:clamp(1rem,3vw,1.4rem)}.entry-card{width:min(900px,100%);margin:0 auto;position:relative;overflow:hidden}.entry-card:after{content:"";pointer-events:none;background:radial-gradient(circle at 80% 0,#3ad9ff1a,#0000 45%);position:absolute;inset:0}@media (width>=1024px){.entry-card{padding:1.5rem 1.75rem}}.card-heading{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.card-heading h2{font-size:1.35rem}.helper-text{color:var(--subtle);font-size:.95rem}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}[data-theme=light] .kindness-card{background:linear-gradient(135deg,#6ff5c40f,#3ad9ff0a),#fff;box-shadow:0 4px 20px #0000000f}[data-theme=light] .kindness-icon{background:linear-gradient(135deg,#6ff5c4,#3ad9ff);box-shadow:0 8px 20px #6ff5c440}[data-theme=light] .daily-overlay{-webkit-backdrop-filter:blur(3px)saturate(130%);background:0 0}[data-theme=light] .daily-overlay p{background:#ffffffd1;border:1px solid #0000000f;border-radius:999px;padding:.45rem .8rem;display:inline-block;box-shadow:0 10px 25px #00000014}[data-theme=light] #daily-picks-card{background:#fff;box-shadow:0 4px 20px #0000000f}[data-theme=light] .pick-card{background:#f9fafb;border-color:#0000000f}[data-theme=light] .pick-card:hover{border-color:#6ff5c44d;box-shadow:0 8px 24px #6ff5c41f}.kindness-card{background:linear-gradient(135deg,#6ff5c414,#3ad9ff0f),var(--card-bg);border:1px solid var(--border-strong);box-shadow:var(--shadow-soft);flex-direction:column;gap:.9rem;display:flex}.kindness-body{align-items:flex-start;gap:1rem;display:flex}.kindness-icon{background:#6ff5c426;border:1px solid #6ff5c466;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;display:inline-flex;box-shadow:0 10px 25px #3ad9ff33}.kindness-text{flex-direction:column;gap:.35rem;display:flex}.kindness-quote{color:var(--text);margin:0;font-size:1.05rem;line-height:1.6}.kindness-author{color:var(--subtle);margin:0;font-weight:600}.event-notifications-container{flex-direction:column;gap:.5rem;width:100%;margin-bottom:1rem;display:flex}.event-notifications-container.hidden{display:none}.event-notification-banner{width:100%;color:var(--text);text-align:center;background:linear-gradient(135deg,#38bdf826,#0ea5e914);border:1px solid #38bdf84d;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;line-height:1.5;display:flex}.event-notification-banner:before{content:"ℹ";color:#38bdf8;background:#38bdf840;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;min-width:20px;height:20px;font-size:.75rem;font-weight:700;display:flex}.event-notification-banner.type-warning{background:linear-gradient(135deg,#f59e0b26,#d9770614);border-color:#f59e0b4d}.event-notification-banner.type-warning:before{content:"⚠";color:#fbbf24;background:#f59e0b40}.event-notification-banner.type-success{background:linear-gradient(135deg,#22c55e26,#16a34a14);border-color:#22c55e4d}.event-notification-banner.type-success:before{content:"✓";color:#4ade80;background:#22c55e40}.event-notification-banner.type-event{background:linear-gradient(135deg,#a855f726,#8b5cf614);border-color:#a855f74d}.event-notification-banner.type-event:before{content:"★";color:#c084fc;background:#a855f740}.entry-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:.35rem;display:grid}#entry-panel .consent-row{grid-column:1/-1}@media (width>=1024px){#entry-panel .entry-grid{grid-template-columns:repeat(2,minmax(280px,1fr));row-gap:1.15rem}#terms-consent-text{white-space:nowrap}}.form-control{flex-direction:column;gap:.35rem;margin-bottom:.75rem;display:flex}.form-control label{letter-spacing:-.01em;color:var(--text);font-size:.875rem;font-weight:600}.form-hint{opacity:.6;margin-top:-.1rem;font-size:.7rem;font-style:italic}.auth-form .form-control label{font-size:.9rem}.segmented-control{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff08;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.4rem;padding:.3rem;display:grid;box-shadow:inset 0 1px #ffffff0a}.segment{border-radius:calc(var(--radius-md) - 4px);isolation:isolate;cursor:pointer;color:var(--subtle);background:var(--muted-bg);border:1px solid #0000;justify-content:center;align-items:center;font-weight:700;transition:color .2s,background .2s,border .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.segment input{opacity:0;cursor:pointer;appearance:none;position:absolute;inset:0}.segment span{text-align:center;width:100%;padding:.65rem .85rem}.segment input:focus-visible+span{outline-offset:2px;outline:2px solid #3ad9ff73}.segment:has(input:checked){background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#041224;box-shadow:0 12px 32px #3ad9ff47}.segment:hover{color:var(--text);background:#6ff5c414}.segmented-control.disabled{opacity:.55}.segmented-control.disabled .segment{cursor:not-allowed;pointer-events:none;box-shadow:none}.segmented-control.disabled .segment:has(input:checked){background:var(--muted-bg);color:var(--subtle);box-shadow:none}.consent-check{color:var(--text);text-transform:none;letter-spacing:normal;background:#ffffff0a;border:1.5px solid #ffffff1a;border-radius:14px;align-items:flex-start;gap:.85rem;padding:1rem 1.15rem;font-size:.9rem;font-weight:500;line-height:1.6;transition:all .2s;display:flex;box-shadow:inset 0 1px 2px #0000001a}.consent-check:hover{background:#ffffff0f;border-color:#ffffff26}.consent-check input{width:20px;min-width:20px;height:20px;accent-color:var(--accent);cursor:pointer;flex-shrink:0;margin-top:.15rem}.consent-check a{color:var(--text);text-underline-offset:2px;font-weight:700;text-decoration:underline}.consent-check a:hover,.consent-check a:focus-visible{color:var(--accent)}.consent-check.disabled{opacity:.6;cursor:not-allowed}input:not([type=checkbox]){color:var(--text);appearance:none;background:#ffffff0d;border:1.5px solid #ffffff1a;border-radius:12px;width:100%;padding:.95rem 1.15rem;font-size:1rem;transition:all .2s;box-shadow:inset 0 1px 2px #0000001a,0 1px #ffffff0d}input:not([type=checkbox]):focus{background:#ffffff14;border-color:#6ff5c480;outline:none;box-shadow:0 0 0 3px #6ff5c426,inset 0 1px 2px #0000001a}input:not([type=checkbox]):hover:not(:disabled):not(:focus){background:#ffffff0f;border-color:#ffffff26}input:not([type=checkbox])::placeholder{color:#ffffff59;opacity:1}input:not([type=checkbox]):disabled{opacity:.5;cursor:not-allowed}[data-theme=light] input:not([type=checkbox]){border-color:var(--border);background:var(--input-bg);box-shadow:inset 0 1px 2px #0000000a}[data-theme=light] input:not([type=checkbox]):focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #6ff5c41f,inset 0 1px 2px #0000000a}[data-theme=light] input:not([type=checkbox]):hover:not(:disabled):not(:focus){background:#fff;border-color:#00000026}[data-theme=light] input:not([type=checkbox])::placeholder{color:var(--subtle)}select{border-radius:var(--radius-md);border:1px solid var(--border);width:100%;color:var(--text);appearance:none;background:#ffffff08;outline:none;padding:.75rem 1rem;font-size:1rem}select option{background:var(--card-bg);color:var(--text)}select option:checked,select option:hover,select option:focus{color:var(--text);background:#3ad9ff33}select::-ms-expand{display:none}input:not([type=checkbox]):disabled{opacity:.6}.segmented-control .segment input:disabled{opacity:0}select:disabled{opacity:.6}button{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#041224;cursor:pointer;border:none;border-radius:999px;padding:.85rem 1.35rem;font-size:1rem;font-weight:700;transition:transform .12s,box-shadow .2s,filter .2s,opacity .2s;box-shadow:0 18px 40px #3ad9ff38}button:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0);box-shadow:0 12px 28px #3ad9ff2e}button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}button.secondary{border:1px solid var(--border);color:var(--text);box-shadow:none;background:#ffffff0a}button.secondary:hover:not(:disabled){border-color:var(--border-strong);background:#6ff5c414}[data-theme=light] button{box-shadow:0 4px 12px #6ff5c433}[data-theme=light] button.secondary{background:var(--btn-secondary-bg)}[data-theme=light] button.secondary:hover:not(:disabled){background:var(--btn-secondary-hover)}#chat-leave-btn{color:#0b0f18;background:linear-gradient(135deg,#ff7a9e,#fb7185);border:none}.select-field{align-items:center;display:flex;position:relative}.select-field select{padding-right:2.75rem}.select-field .select-arrow{pointer-events:none;color:var(--subtle);background:#ffffff0d;border-radius:.45rem;justify-content:center;align-items:center;padding:.2rem .35rem;transition:color .2s,background .2s;display:flex;position:absolute;right:.9rem}.select-field select:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px #3ad9ff59}.select-field select:focus-visible+.select-arrow{color:var(--accent);background:#3ad9ff26}.select-field select:disabled+.select-arrow{opacity:.4}.actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.primary-actions{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.65rem;width:100%;margin-top:.35rem;display:grid}.primary-actions button{width:100%}.waiting-card{border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:#ffffff08;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.waiting-state{text-align:center;flex-direction:column;align-items:center;gap:.75rem;display:flex}.waiting-state h2{margin:0}.spinner{border:3px solid #94a3b840;border-top-color:var(--accent-strong);border-radius:50%;width:32px;height:32px;animation:1s linear infinite spin}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.waiting-state .status{color:var(--subtle);justify-content:center;align-items:center;height:5.5em;margin-top:.5rem;line-height:1.5;display:flex;overflow:hidden}.queue-wait-notice{border:1px solid var(--border);width:100%;max-width:560px;color:var(--text);text-align:left;background:#ffffff0a;border-radius:16px;align-items:flex-start;gap:.55rem;padding:.65rem .8rem;font-size:.85rem;line-height:1.4;display:flex;box-shadow:inset 0 1px #ffffff0a}.queue-wait-notice-text{min-width:0;color:var(--text);flex-wrap:wrap;flex:auto;align-items:flex-start;gap:.35rem;margin:0;display:flex}.queue-wait-notice-label{color:var(--text);align-items:center;height:26px;font-weight:700;display:inline-flex}.queue-wait-notice-body{color:var(--text);flex:1 1 0;min-width:0;display:inline}.queue-wait-notice .notice-icon{flex:none;width:22px;height:22px;margin-top:.1rem}body.chatting #chat-status{display:none}.friend-request-banner{border-radius:var(--radius-md);color:var(--text);background:#3b82f61f;border:1px solid #38bdf873;justify-content:space-between;align-items:center;gap:.85rem;padding:.75rem .85rem;display:flex}.friend-request-banner-text{white-space:nowrap;text-overflow:ellipsis;flex:auto;min-width:0;font-weight:650;overflow:hidden}.friend-request-banner-actions{flex:none;gap:.5rem;display:flex}.friend-request-banner-actions button{box-shadow:none;padding:.55rem .95rem;font-size:.9rem}[data-theme=light] .friend-request-banner{background:#3b82f614;border-color:#3b82f638}@keyframes typingDot{0%{opacity:.4;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}to{opacity:.4;transform:translateY(0)}}#chat-panel{flex-direction:column;gap:1rem;height:clamp(560px,85vh,1200px);min-height:560px;display:flex}.chat-card{background:linear-gradient(155deg,#ffffff05,#ffffff08),var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);padding:clamp(1rem,3vw,1.3rem)}.panel-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding-bottom:.65rem;display:flex}.partner-info{flex:auto;min-width:0}.partner-info h2{margin-top:.25rem;font-size:1.25rem;font-weight:700}.partner-main-row{align-items:center;gap:.6rem;min-width:0;display:flex}.partner-avatar{border:1px solid var(--border-strong);background:radial-gradient(circle at 30% 20%,#ffffff2e,#6ff5c44d),linear-gradient(135deg,#6ff5c43d,#3ad9ff4d);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex;overflow:hidden}.partner-avatar img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.partner-save-btn{flex-shrink:0;margin-left:auto}.header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.header-actions .icon-btn{border-radius:.65rem;width:2.4rem;height:2.4rem;padding:.3rem;box-shadow:0 4px 12px #0003}.header-actions .icon-btn svg,.header-actions .icon-btn img{width:1.1rem;height:1.1rem}.header-square-btn{box-sizing:border-box;text-align:center;border-radius:8px;justify-content:center;align-items:center;gap:.35rem;min-height:2.4rem;padding:.45rem .9rem;font-size:.85rem;font-weight:500;line-height:1;display:inline-flex}#save-partner-btn,.add-friend-btn{color:#dbeafe;cursor:pointer;background:linear-gradient(135deg,#3b82f633,#38bdf840);border:1px solid #38bdf8b3;transition:background .2s,border-color .2s,transform .12s}#save-partner-btn:hover:not(:disabled),.add-friend-btn:hover:not(:disabled){background:linear-gradient(135deg,#3b82f659,#38bdf866);border-color:#38bdf8e6;transform:translateY(-1px)}#save-partner-btn:disabled,.add-friend-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=light] #save-partner-btn,[data-theme=light] .add-friend-btn{color:#0b1220;background:#3b82f61f;border-color:#3b82f661}[data-theme=light] #save-partner-btn:hover:not(:disabled),[data-theme=light] .add-friend-btn:hover:not(:disabled){background:#3b82f62e;border-color:#3b82f67a}#save-partner-btn svg,.add-friend-btn svg,#save-partner-btn img,.add-friend-btn img{flex-shrink:0;width:1.1rem;height:1.1rem}#save-partner-btn svg,.add-friend-btn svg{stroke:currentColor;stroke-width:1.6px;fill:none;stroke-linecap:round;stroke-linejoin:round}.header-pill-label{white-space:nowrap}.disconnect-btn{color:#e08080;cursor:pointer;background:#b4464626;border:1px solid #dc646466;border-radius:8px;padding:.45rem .9rem;font-size:.85rem;font-weight:500;transition:background .2s,border-color .2s,transform .12s}.disconnect-btn:hover:not(:disabled){background:#b4464640;border-color:#dc64648c;transform:translateY(-1px)}.disconnect-btn:disabled{opacity:.5;cursor:not-allowed}.eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--subtle);font-size:.7rem;font-weight:500}[data-theme=light] .message-window{background:#fff;box-shadow:inset 0 1px #00000005}[data-theme=light] #chat-panel img[src*=icon-]{filter:brightness(.35)saturate(0)}[data-theme=light] .message .audio-play-btn{background:var(--btn-secondary-bg);border:1px solid var(--border);color:var(--text);box-shadow:0 2px 6px #0000001f}[data-theme=light] .message .audio-play-btn:hover{background:var(--btn-secondary-hover);box-shadow:0 3px 9px #00000024}[data-theme=light] .message .audio-play-btn.playing{color:#14532d;background:#6ff5c42e;border-color:#6ff5c459;box-shadow:0 2px 8px #6ff5c42e}[data-theme=light] .message{background:#f3f4f6;box-shadow:0 2px 8px #0000000f}[data-theme=light] .message.you,[data-theme=light] .message.self{color:#064e3b;background:#dcfce7;border-color:#6ff5c447;box-shadow:0 6px 18px #10b9811f}[data-theme=light] .message.you .meta,[data-theme=light] .message.self .meta{color:#064e3bb8}[data-theme=light] .message.typing .typing-bubble,[data-theme=light] .message.recording .typing-bubble{background:#6ff5c41a;border-color:#6ff5c44d;box-shadow:0 4px 12px #00000014}.message-window{border:1px solid var(--border);border-radius:var(--radius-md);background:linear-gradient(180deg,#ffffff05,#ffffff03),var(--glass-bg);flex:auto;min-height:0;padding:1rem;overflow:hidden auto;box-shadow:inset 0 1px #ffffff0a}#message-list{flex-direction:column;justify-content:flex-end;gap:.7rem;min-height:100%;margin:0;padding:0;list-style:none;display:flex}.message{border:1px solid var(--border);background:#ffffff0a;border-radius:16px;max-width:80%;padding:.85rem .95rem;box-shadow:0 12px 32px #00000047}.message.typing,.message.recording{box-shadow:none;background:0 0;border:none;padding:0}.message.typing .typing-bubble,.message.recording .typing-bubble{white-space:nowrap;background:#3ad9ff1f;border:1px solid #3ad9ff73;border-radius:1rem;flex-direction:row;align-items:center;gap:.5rem;padding:.55rem .9rem;display:inline-flex;box-shadow:0 10px 28px #0f172a73}.message.typing .typing-label,.message.recording .typing-label{color:var(--text);font-size:.85rem;line-height:1.1}.message.typing .typing-dots,.message.recording .typing-dots{flex-shrink:0;align-items:center;gap:.25rem;display:flex;transform:translateY(4px)}.message.typing .typing-dot,.message.recording .typing-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1s ease-in-out infinite typingDot}.message.typing .typing-dot:nth-child(2){animation-delay:.15s}.message.typing .typing-dot:nth-child(3){animation-delay:.3s}.message .meta{color:var(--subtle);flex-wrap:wrap;justify-content:space-between;gap:.35rem;font-size:.8rem;display:flex}.message .meta span:first-child{font-weight:700}.message .text{white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;margin-top:.35rem}.message.you{color:var(--text);background:linear-gradient(135deg,#6ff5c452,#3ad9ff5c),#070c16d9;border-color:#6ff5c4c7;border-radius:16px 16px 8px;align-self:flex-end;box-shadow:0 16px 36px #3ad9ff40}.message.you .meta{color:#e9f1ffcc}.message:not(.you){align-self:flex-start}.message.system{color:var(--subtle);box-shadow:none;background:0 0;border:none;align-self:center}.message .photo-block{max-width:min(90vw,320px);margin:.5rem 0 0}.message .photo-block img{object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--border);cursor:zoom-in;background:#ffffff08;width:100%;max-width:100%;height:auto;max-height:240px;display:block;box-shadow:0 12px 30px #00000052}@media (width>=768px){.message .photo-block{max-width:min(55vw,240px)}.message .photo-block img{max-height:220px}}.message .photo-caption{color:var(--text);white-space:pre-wrap;word-break:break-word;margin:.35rem 0 0;font-size:.95rem}.message .audio-block{max-width:min(80vw,260px);margin:.35rem 0 0}.message .audio-player{border:1px solid var(--border);background:#ffffff0d;border-radius:999px;align-items:center;gap:.45rem;padding:.45rem .65rem;display:flex;box-shadow:inset 0 1px #ffffff0a}.message .audio-play-btn{background:radial-gradient(circle at 30% 30%,#f8fafc38,transparent 55%),linear-gradient(135deg,var(--accent),var(--accent-strong));color:#041224;cursor:pointer;border:none;border-radius:50%;flex:0 0 22px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:transform .12s ease-out,box-shadow .12s ease-out,opacity .12s ease-out;display:inline-flex;position:relative;box-shadow:0 4px 10px #0f172a73}.message .audio-play-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px #0f172a8c}.message .audio-play-btn:active{transform:translateY(0);box-shadow:0 2px 6px #0f172a66}.message .audio-play-btn.playing{color:#f9fafb;background:radial-gradient(circle at 30% 30%,#f8fafc2e,#0000 55%),linear-gradient(135deg,#22c55e,#16a34a)}.message .audio-icon{width:12px;height:12px;display:inline-block;position:relative}.message .audio-icon-play:before{content:"";border-top:5px solid #0000;border-bottom:5px solid #0000;border-left:8px solid;width:0;height:0;position:absolute;top:50%;left:50%;transform:translate(-40%,-50%)}.message .audio-icon-pause:before,.message .audio-icon-pause:after{content:"";background:currentColor;border-radius:999px;width:2px;height:10px;position:absolute;top:50%;transform:translateY(-50%)}.message .audio-icon-pause:before{left:3px}.message .audio-icon-pause:after{right:3px}.message .audio-timeline{cursor:pointer;background:#ffffff14;border-radius:999px;flex:auto;height:3px;overflow:hidden}.message .audio-timeline-fill{border-radius:inherit;background:linear-gradient(135deg,var(--accent),var(--accent-strong));width:0%;height:100%;transition:width .1s linear}.message .audio-time{color:var(--subtle);text-align:right;font-variant-numeric:tabular-nums;min-width:40px;font-size:.75rem}.message .audio-caption{color:var(--text);white-space:pre-wrap;word-break:break-word;margin:.35rem 0 0;font-size:.95rem}.image-viewer-open{overflow:hidden}.image-viewer{backdrop-filter:blur(10px);z-index:1200;background:#040710d1;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.image-viewer__content{border:1px solid var(--border);border-radius:var(--radius-lg);width:min(960px,96vw);max-height:90vh;box-shadow:var(--shadow-1);background:#090e1af2;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.image-viewer__frame{border:1px solid var(--border-strong);border-radius:var(--radius-md);cursor:grab;background:radial-gradient(circle at top,#3ad9ff2e,#090e1ae6);justify-content:center;align-items:center;padding:.9rem;display:flex;overflow:hidden}.image-viewer__image{object-fit:contain;user-select:none;pointer-events:none;width:auto;max-width:100%;height:auto;max-height:70vh;transition:transform .15s ease-out}.image-viewer__frame.dragging{cursor:grabbing}.image-viewer__caption{color:var(--text);text-align:center;white-space:pre-wrap;word-break:break-word;margin:0}.image-viewer__controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.image-viewer__btn{color:var(--text);border:1px solid var(--border);cursor:pointer;background:#ffffff0d;border-radius:.7rem;padding:.35rem .8rem;font-weight:700;transition:all .15s ease-out}.image-viewer__btn:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 10px 30px #38bdf833}.image-viewer__btn:active{transform:translateY(1px)}.image-viewer__close{margin-left:auto}.image-viewer__scale{color:var(--text);text-align:center;font-variant-numeric:tabular-nums;min-width:60px}.shake{animation:.3s shake}@keyframes shake{0%{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}to{transform:translate(0)}}#message-form{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--btn-secondary-bg);align-items:center;gap:.65rem;padding:.65rem .75rem;display:flex;box-shadow:inset 0 1px #ffffff0a}#message-form input{background:var(--input-bg);border:1px solid var(--border);border-radius:14px;flex:auto;min-width:0;padding:.75rem .9rem}#message-form button{flex-shrink:0}#message-form .send-btn{justify-content:center;align-items:center;gap:.45rem;display:inline-flex}#message-form .send-btn .mic-icon{width:22px;height:22px;display:block}#message-form .send-btn:has(.mic-icon:not(.hidden)){border:1px solid var(--border);background:#ffffff0d;border-radius:14px;width:48px;height:48px;padding:.38rem;box-shadow:0 8px 20px #00000040}#message-form .send-btn:has(.mic-icon:not(.hidden)):hover{border-color:var(--border-strong);background:#6ff5c414;transform:translateY(-1px)}#message-form .send-btn.recording{border-color:var(--danger);color:var(--danger-soft);background:#f8717129}#message-form .send-icon{width:20px;height:20px;display:block}#message-form .send-icon path{stroke:currentColor;stroke-width:1.9px;fill:none;stroke-linecap:round;stroke-linejoin:round}.icon-btn{border:1px solid var(--border);width:48px;height:48px;color:var(--text);background:#ffffff0d;border-radius:14px;justify-content:center;align-items:center;padding:.38rem;font-size:1.1rem;transition:transform .12s,box-shadow .2s,border-color .2s,background .2s;display:inline-flex;box-shadow:0 8px 20px #00000040}.icon-btn svg,.icon-btn img{stroke-width:1.8px;fill:none;stroke-linecap:round;stroke-linejoin:round;width:22px;height:22px}.icon-btn:hover{border-color:var(--border-strong);background:#6ff5c414;transform:translateY(-1px)}.icon-btn.recording{border-color:var(--danger);color:var(--danger-soft);background:#f8717129}.icon-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.voice-recorder{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--btn-secondary-bg);align-items:center;gap:.75rem;margin-top:.65rem;padding:.65rem .75rem;display:flex;box-shadow:inset 0 1px #ffffff0a}.voice-recorder-info{flex-direction:column;flex:auto;gap:.15rem;min-width:0;display:flex}.voice-recorder-timer{font-weight:600}.voice-recorder-label{color:var(--subtle);font-size:.85rem}.voice-recorder-actions{align-items:center;gap:.4rem;display:flex}.voice-recorder-actions .icon-btn{flex:0 0 40px;width:40px;height:40px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.camera-overlay{background:var(--overlay-bg);backdrop-filter:blur(10px);z-index:950;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.camera-overlay-panel{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel-bg);width:min(520px,100%);max-height:90vh;box-shadow:var(--shadow-1);flex-direction:column;gap:.9rem;padding:1.1rem 1.25rem 1.25rem;display:flex}.camera-overlay-header h3{margin-bottom:.25rem;font-size:1.15rem}.camera-overlay-header p{color:var(--subtle);margin:0;font-size:.9rem}.camera-preview-shell{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--input-bg);justify-content:center;align-items:center;min-height:220px;display:flex;overflow:hidden}.camera-preview-shell video{object-fit:cover;width:100%;height:auto;max-height:320px;display:block}.camera-overlay-actions{flex-wrap:wrap;justify-content:flex-end;gap:.6rem;margin-top:.75rem;display:flex}.camera-overlay-actions button{flex:calc(50% - .3rem)}@media (width<=600px){.camera-overlay{align-items:flex-end;padding:1rem}.camera-overlay-panel{width:100%;max-height:80vh;padding:1rem 1rem calc(1rem + env(safe-area-inset-bottom,0));border-radius:1.25rem 1.25rem 0 0}.camera-overlay-actions button{flex:100%}}[data-theme=light] .account-modal{background:#ffffffd9}[data-theme=light] .account-modal-content{background:#fff;border-color:#00000014;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d}[data-theme=light] .account-modal-header{background:#00000005;border-bottom-color:#0000000f}[data-theme=light] .auth-status{color:#7f1d1d;background:#ef444414;border-color:#ef444438}[data-theme=light] .pm-modal{background:#ffffffd9}[data-theme=light] .pm-modal-content{background:#fff;border-color:#00000014;box-shadow:0 20px 60px #00000026}[data-theme=light] .pm-modal-header{border-bottom-color:#0000000f}[data-theme=light] .pm-modal-footer{border-top-color:#0000000f}[data-theme=light] .pm-modal .icon-btn{background:var(--btn-secondary-bg);box-shadow:0 4px 12px #00000014}[data-theme=light] .pm-modal .icon-btn:hover{background:var(--btn-secondary-hover)}[data-theme=light] #pm-modal img[src*=icon-]{filter:brightness(.35)saturate(0)}[data-theme=light] .pm-section,[data-theme=light] .pm-thread-messages{background:var(--muted-bg)}[data-theme=light] .pm-thread-item,[data-theme=light] .pm-request-item{background:#fff;border-color:#00000014}[data-theme=light] .pm-message-bubble{background:#fff;border-color:#0000001a}[data-theme=light] .pm-message-item.self .pm-message-bubble{background:#6ff5c429;border-color:#6ff5c447}[data-theme=light] .pm-thread-unread-dot{box-shadow:0 0 0 2px #fffffff2}.account-modal{-webkit-backdrop-filter:blur(16px)saturate(180%);z-index:900;overscroll-behavior:contain;background:#050912e0;justify-content:center;align-items:center;padding:1.5rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.account-modal-content{backdrop-filter:blur(20px);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:#090e1afa;border:1px solid #ffffff1f;border-radius:24px;flex-direction:column;width:min(540px,100%);max-height:90vh;padding:0;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff0d}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.account-modal-header{background:#ffffff05;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:.75rem;padding:1.5rem 1.75rem 1rem;display:flex}.account-modal-header h2{letter-spacing:-.02em;margin:0;font-size:1.35rem;font-weight:700}.auth-view,.verify-view{flex-direction:column;gap:1.5rem;padding:1.75rem 1.75rem 2rem;display:flex}.auth-header{flex-direction:column;gap:.5rem;display:flex}.auth-header h3{letter-spacing:-.02em;color:var(--text);margin:0;font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--subtle);margin:0;font-size:.95rem;line-height:1.5}.auth-status-wrapper{min-height:1.5rem}.auth-status{color:#fecdd3;background:#fb71851a;border:1px solid #fb718533;border-radius:12px;margin:0;padding:.75rem 1rem;font-size:.9rem;line-height:1.5}.auth-status.is-success{color:#bbf7d0;background:#22c55e26;border-color:#22c55e59}[data-theme=light] .auth-status.is-success{color:#065f46;background:#6ff5c41f;border-color:#6ff5c447}.auth-status:empty{display:none}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.auth-actions{flex-direction:column;gap:.75rem;margin-top:.5rem;display:flex}.auth-primary-btn{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#041224;cursor:pointer;border:none;border-radius:14px;width:100%;padding:.95rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s;position:relative;overflow:hidden;box-shadow:0 4px 12px #6ff5c440}.auth-primary-btn:before{content:"";opacity:0;background:linear-gradient(135deg,#fff3,#0000);transition:opacity .2s;position:absolute;inset:0}.auth-primary-btn:hover:not(:disabled):before{opacity:1}.auth-primary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #6ff5c459}.auth-primary-btn:active:not(:disabled){transform:translateY(0)}.auth-primary-btn:disabled{opacity:.6;cursor:not-allowed}.auth-secondary-btn{width:100%;color:var(--text);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:14px;padding:.95rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.auth-secondary-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff2e;transform:translateY(-1px)}.auth-secondary-btn:active:not(:disabled){transform:translateY(0)}.auth-secondary-btn:disabled{opacity:.6;cursor:not-allowed}#account-auth-view[data-mode=login] .auth-actions{flex-direction:column}#account-auth-view[data-mode=register] .auth-actions{flex-direction:column-reverse}#account-auth-view[data-mode=register] #account-register-btn{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#041224;font-weight:600;position:relative;overflow:hidden;box-shadow:0 4px 12px #6ff5c440}#account-auth-view[data-mode=register] #account-register-btn:before{content:"";opacity:0;background:linear-gradient(135deg,#fff3,#0000);transition:opacity .2s;position:absolute;inset:0}#account-auth-view[data-mode=register] #account-register-btn:hover:not(:disabled):before{opacity:1}#account-auth-view[data-mode=register] #account-register-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #6ff5c459}#account-auth-view[data-mode=register] #account-login-btn{color:var(--subtle);box-shadow:none;background:0 0;border:none;padding:.75rem 1.25rem;font-size:.875rem}#account-auth-view[data-mode=register] #account-login-btn:hover:not(:disabled){color:var(--text);background:#ffffff0d;border:none;transform:none}#account-auth-view[data-mode=login] #account-forgot-btn{color:var(--subtle);box-shadow:none;background:0 0;border:none;padding:.75rem 1.25rem;font-size:.875rem}#account-auth-view[data-mode=login] #account-forgot-btn:hover:not(:disabled){color:var(--text);background:#ffffff0d;border:none;transform:none}#account-auth-view[data-mode=register] #account-forgot-btn{display:none}.code-input{text-align:center;letter-spacing:.5em;font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:600}.account-close-btn{width:36px;height:36px;color:var(--text);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:1.2rem;transition:all .2s;display:inline-flex}.account-close-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff26;transform:scale(1.05)}.account-close-btn:active:not(:disabled){transform:scale(.95)}.sheet-handle{background:#fff3;border:1px solid #ffffff1a;border-radius:999px;flex-shrink:0;width:56px;height:5px;margin:.75rem auto .5rem;display:none}@media (width<=768px),(pointer:coarse){.account-modal{background:#050912eb;align-items:flex-end;padding:0}.account-modal-content{border-bottom:none;border-left:none;border-right:none;border-radius:24px 24px 0 0;width:100%;max-height:90vh;padding:0;animation:.35s cubic-bezier(.16,1,.3,1) slideUpMobile;box-shadow:0 -12px 40px #00000080}@keyframes slideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.sheet-handle{display:block}.account-modal-header{z-index:10;backdrop-filter:blur(20px);background:#090e1afa;border-bottom:1px solid #ffffff1a;margin-bottom:0;padding:1rem 1.25rem .75rem;position:sticky;top:0}.account-modal-header h2{font-size:1.2rem}.auth-view,.verify-view,.profile-view{padding:1.25rem 1.25rem calc(1.5rem + env(safe-area-inset-bottom,0));gap:1.25rem}.auth-header h3{font-size:1.3rem}.auth-subtitle{font-size:.9rem}.auth-form{gap:1rem}.form-control{gap:.45rem}input:not([type=checkbox]){padding:.9rem 1rem;font-size:16px}.auth-primary-btn,.auth-secondary-btn{min-height:48px;padding:1rem 1.5rem;font-size:1rem}.profile-hero{border-radius:18px;gap:1rem;padding:1.25rem}.profile-identity{flex-direction:column;align-items:flex-start;gap:1rem}.profile-avatar{width:64px;height:64px;font-size:1.35rem}.profile-name{font-size:1.25rem}.profile-card{border-radius:16px;padding:1.25rem}.profile-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.premium-actions,.logout-actions{flex-direction:column}.premium-actions button,.logout-actions button{width:100%}.code-input{padding:1rem;font-size:1.35rem}}@media (width<=480px){.auth-view,.verify-view,.profile-view{padding:1rem 1rem calc(1.25rem + env(safe-area-inset-bottom,0))}.account-modal-header{padding:.875rem 1rem .625rem}.auth-header h3{font-size:1.2rem}.profile-hero,.profile-card{padding:1rem}}.profile-view{flex-direction:column;gap:1.5rem;padding:1.75rem 1.75rem 2rem;display:flex}.profile-hero{background:linear-gradient(135deg,#6ff5c41f,#3ad9ff14);border:1px solid #ffffff1f;border-radius:20px;flex-wrap:wrap;align-items:flex-start;gap:1.25rem;margin-bottom:0;padding:1.5rem;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 24px #0000004d,0 0 0 1px #ffffff0d}.profile-hero:before{content:"";background:linear-gradient(90deg,#0000,#6ff5c466,#0000);height:1px;position:absolute;top:0;left:0;right:0}.profile-identity{flex:260px;align-items:flex-start;gap:1.15rem;min-width:0;display:flex}.profile-avatar{width:72px;height:72px;color:var(--text);background:radial-gradient(circle at 30% 20%,#fff3,#6ff5c459),linear-gradient(135deg,#6ff5c447,#3ad9ff66);border:2px solid #fff3;border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:inline-flex;box-shadow:0 8px 24px #3ad9ff40,0 0 0 1px #ffffff1a}.profile-avatar-btn{cursor:pointer;padding:0;position:relative;overflow:hidden}.profile-avatar-edit-overlay{opacity:.16;pointer-events:none;background:linear-gradient(#0000,#00000061);transition:opacity .14s;position:absolute;inset:0}.profile-avatar-edit-icon{color:#ffffffeb;opacity:.88;pointer-events:none;background:#0000006b;border:1px solid #ffffff29;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;transition:opacity .14s,transform .14s,background .14s;display:inline-flex;position:absolute;bottom:8px;right:8px;transform:translateY(0);box-shadow:0 12px 20px #00000038}.profile-avatar-edit-icon svg{fill:currentColor;width:14px;height:14px;display:block}.profile-avatar-btn:hover .profile-avatar-edit-overlay,.profile-avatar-btn:focus-visible .profile-avatar-edit-overlay{opacity:.3}.profile-avatar-btn:hover .profile-avatar-edit-icon,.profile-avatar-btn:focus-visible .profile-avatar-edit-icon{opacity:1;background:#00000085;transform:translateY(-1px)}.profile-avatar-btn:disabled{cursor:not-allowed;opacity:.75}#profile-avatar-img{object-fit:cover;border-radius:inherit;width:100%;height:100%;display:block}#profile-avatar-initial{text-transform:uppercase}.profile-heading{flex-direction:column;flex:1;gap:.5rem;min-width:0;display:flex}.profile-eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--subtle);margin:0;font-size:.75rem;font-weight:600}.profile-name-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.profile-name{letter-spacing:-.02em;color:var(--text);font-size:1.4rem;font-weight:700}.profile-badges{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.profile-badge{padding:.4rem .75rem;font-size:.8rem}.premium-star{color:var(--accent);text-shadow:0 0 14px #6ff5c499;font-size:1.2rem}.profile-email{color:var(--subtle);word-break:break-word;margin:0;font-size:.9rem}.profile-status-wrapper{min-height:1.5rem}.profile-status{color:#6ff5c4e6;background:#6ff5c41a;border:1px solid #6ff5c433;border-radius:12px;margin:0;padding:.75rem 1rem;font-size:.9rem;line-height:1.5}.profile-status:empty{display:none}.profile-hero-meta{text-align:right;flex-direction:column;flex:0 0 220px;justify-content:center;align-items:flex-end;gap:.35rem;min-width:200px;display:flex}.profile-premium{color:var(--text);border:1px solid var(--border-strong);background:#6ff5c424;border-radius:.75rem;width:100%;padding:.55rem .75rem;font-size:1rem;font-weight:700;box-shadow:0 12px 20px #3ad9ff26}.profile-premium.active{border-color:var(--border-strong);color:var(--text);background:linear-gradient(135deg,#6ff5c438,#3ad9ff47)}.profile-premium.inactive{box-shadow:none;color:var(--subtle);background:#94a3b824;border-color:#94a3b859}.profile-callout{border:1px solid var(--border-strong);background:#6ff5c41f;border-radius:.9rem;align-items:flex-start;gap:.75rem;margin-top:.4rem;padding:.9rem 1rem;display:flex}#profile-callout.hidden{display:none!important}.profile-callout-icon{border:1px solid var(--border-strong);background:#6ff5c433;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex;box-shadow:0 10px 24px #3ad9ff26}#account-profile-status{color:var(--text);margin:0;line-height:1.5}.subtle-status{color:var(--subtle)}.profile-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin-top:.75rem;display:grid}.profile-card{backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff1a;border-radius:18px;flex-direction:column;gap:1rem;min-height:0;margin-bottom:1rem;padding:1.5rem;transition:all .2s;display:flex;box-shadow:0 4px 12px #0003}.profile-card:hover{border-color:#ffffff26;box-shadow:0 6px 16px #00000040}.profile-card .eyebrow{color:var(--subtle)}.stat-value{color:var(--text);font-size:1.4rem;font-weight:700}.stat-helper{color:var(--subtle);font-size:.9rem}.stat-inline{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.mono{word-break:break-all;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.chip-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:999px;padding:.35rem .8rem;font-size:.9rem;transition:all .2s}.chip-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--accent);background:#6ff5c41f}.profile-referral-card{border:1px solid var(--border-strong);box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#6ff5c424,#3ad9ff14);grid-column:1/-1}.referral-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.referral-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.referral-feedback{color:var(--accent);margin:0;font-size:.9rem;font-weight:600}.profile-card-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.25rem;display:flex}.profile-card-header .eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--subtle);margin:0 0 .25rem;font-size:.75rem;font-weight:600}.profile-card-header .status{margin:0;font-size:.875rem}.profile-preferences{background:var(--panel-bg);gap:.5rem}.profile-preferences .form-control{margin:0}.pill{border:1px solid var(--border);color:var(--text);background:#ffffff14;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .7rem;font-size:.85rem;font-weight:700;display:inline-flex}.pill-ghost{color:var(--subtle);background:#ffffff0a;border-style:dashed}body.shop-route #entry-panel,body.shop-route #chat-panel,body.shop-route #kindness-card,body.shop-route #daily-picks-card{display:none!important}.shop-page-header{justify-content:space-between;align-items:flex-start;gap:.85rem;display:flex}.shop-page-header h2{margin:.25rem 0 0}.shop-page-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:inline-flex}.shop-auth-note{background:#ffffff08;border:1px solid #ffffff1a;border-radius:16px;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.75rem;padding:.85rem .95rem;display:flex}[data-theme=light] .shop-auth-note{border-color:var(--border);background:var(--muted-bg)}[data-theme=light] .shop-auth-note .subtle-status{color:#374151}.shop-page .shop-orders{margin-top:1rem}.shop-items{gap:.65rem;display:grid}.shop-item{background:#ffffff08;border:1px solid #ffffff1a;border-radius:16px;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.85rem .95rem;display:flex}.shop-item-title{margin:0;font-weight:700}.shop-item-meta{color:var(--subtle);margin:.25rem 0 0;font-size:.9rem;line-height:1.35}.shop-item-actions{flex-direction:column;flex:none;align-items:flex-end;gap:.45rem;display:flex}.shop-orders{flex-direction:column;gap:.5rem;display:flex}.shop-subtitle{margin:.5rem 0 0;font-size:1rem}.shop-orders-list{gap:.5rem;display:grid}.shop-order{background:#ffffff05;border:1px solid #ffffff14;border-radius:14px;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .75rem;display:flex}.shop-order-title{margin:0;font-weight:700}.shop-order-meta{color:var(--subtle);margin:.15rem 0 0;font-size:.85rem;line-height:1.35}.shop-page{flex-direction:column;gap:1.25rem;display:flex}.shop-page-header{flex-direction:column;align-items:flex-start;gap:1rem;display:flex}.shop-page-header-text{flex:1}.shop-page-header h2{margin:.25rem 0 0;font-size:1.5rem}.shop-page-actions{gap:.5rem;width:100%;display:flex}.shop-page-actions button{flex:1;min-height:44px}@media (width>=480px){.shop-page-header{flex-direction:row;justify-content:space-between;align-items:flex-start}.shop-page-actions{flex:none;width:auto}.shop-page-actions button{min-height:unset;flex:none}}.shop-items{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=480px){.shop-items{grid-template-columns:repeat(2,1fr)}}@media (width>=768px){.shop-items{gap:1.25rem}}@media (width>=1024px){.shop-items{grid-template-columns:repeat(3,1fr)}}.shop-item{border-radius:var(--radius-md);border:1px solid var(--border);background:linear-gradient(160deg,#ffffff0a,#ffffff03);flex-direction:column;gap:.75rem;padding:1.25rem;transition:transform .15s,border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.shop-item:before{content:"";pointer-events:none;background:radial-gradient(circle at 80% 0,#6ff5c414,#0000 70%);width:120px;height:120px;position:absolute;top:0;right:0}.shop-item:hover{border-color:#ffffff2e;transform:translateY(-2px);box-shadow:0 12px 32px #3ad9ff1a}.shop-item-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.shop-item-title{color:var(--text);margin:0;font-size:1.1rem;font-weight:700;line-height:1.3}.shop-item-description{color:var(--subtle);margin:0;font-size:.9rem;line-height:1.45}.shop-item-footer{border-top:1px solid #ffffff0f;justify-content:space-between;align-items:center;gap:.75rem;margin-top:auto;padding-top:.75rem;display:flex}.shop-item-price{color:var(--text);align-items:center;gap:.45rem;font-size:1rem;font-weight:700;display:inline-flex}.shop-item-price .coins-icon{width:1rem;height:1rem}.shop-item-price-text{line-height:1}.shop-item-redeem-btn{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#041224;cursor:pointer;border:none;border-radius:12px;min-width:100px;min-height:44px;padding:.65rem 1.1rem;font-size:.95rem;font-weight:700;transition:transform .12s,box-shadow .2s,filter .12s;box-shadow:0 6px 18px #6ff5c440}.shop-item-redeem-btn:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 8px 24px #6ff5c459}.shop-item-redeem-btn:active:not(:disabled){transform:translateY(0)}.shop-item-redeem-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;color:var(--subtle);background:#ffffff1a}@media (width<=360px){.shop-item-footer{flex-direction:column;align-items:stretch;gap:.65rem}.shop-item-redeem-btn{width:100%}}.shop-auth-note{border-radius:var(--radius-md);background:#fbbf240f;border:1px dashed #fbbf2459;flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem 1.1rem;display:flex}.shop-auth-note p{text-align:center;color:#fef08a;margin:0}.shop-auth-note button{min-height:44px}@media (width>=480px){.shop-auth-note{flex-direction:row;justify-content:space-between;align-items:center}.shop-auth-note p{text-align:left}.shop-auth-note button{min-height:unset;flex:none}}.shop-orders-section{margin-top:.5rem}.shop-subtitle{color:var(--text);margin:0 0 .75rem;font-size:1.1rem;font-weight:600}.shop-orders-list{flex-direction:column;gap:.65rem;display:flex}.shop-order{background:#ffffff06;border:1px solid #ffffff14;border-radius:14px;flex-direction:column;gap:.65rem;padding:1rem 1.1rem;transition:border-color .2s;display:flex}.shop-order:hover{border-color:#ffffff24}.shop-order-info{flex:1;min-width:0}.shop-order-header{justify-content:space-between;align-items:flex-start;gap:.65rem;display:flex}.shop-order-title{margin:0;font-size:1rem;font-weight:700;line-height:1.3}.shop-order-note{color:var(--subtle);background:#ffffff0a;border-radius:10px;margin:.5rem 0 0;padding:.65rem .85rem;font-size:.9rem;font-style:italic}@media (width>=480px){.shop-order{flex-direction:row;justify-content:space-between;align-items:center}}.pill{border:1px solid var(--border);color:var(--text);white-space:nowrap;background:#ffffff14;border-radius:999px;flex-shrink:0;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8rem;font-weight:700;display:inline-flex}.pill:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.pill-success{color:#86efac;background:#22c55e1f;border-color:#22c55e4d}.pill-success:before{background:#22c55e;box-shadow:0 0 6px #22c55e99}.pill-warning{color:#fde047;background:#fbbf241a;border-color:#fbbf244d}.pill-warning:before{background:#fbbf24;animation:2s ease-in-out infinite pulse-warning}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.5}}.pill-danger{color:#fda4af;background:#fb71851a;border-color:#fb718540}.pill-danger:before{background:#fb7185}.shop-items .subtle-status,.shop-orders-list .subtle-status{text-align:center;border-radius:var(--radius-md);border:1px dashed var(--border);background:#ffffff05;padding:2rem 1rem}.shop-item.loading{pointer-events:none}.shop-item.loading .shop-item-redeem-btn{color:#0000;position:relative}.shop-item.loading .shop-item-redeem-btn:after{content:"";border:2px solid #0412244d;border-top-color:#041224;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin;position:absolute}.partner-name-row{flex-wrap:nowrap;flex:auto;align-items:center;gap:.5rem;min-width:0;display:flex}.partner-name-row h2{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.gender-badge{text-transform:capitalize;letter-spacing:.02em;border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.7rem;font-weight:600;display:inline-flex}.gender-badge.gender-female{color:#f9a8d4;background:#ec48992e;border:1px solid #ec489966}.gender-badge.gender-male{color:#93c5fd;background:#3b82f62e;border:1px solid #3b82f666}.profile-actions{border:1px solid var(--border);background:#0f172acc;border-radius:.9rem;flex-direction:column;gap:.6rem;margin-top:.75rem;margin-bottom:.35rem;padding:.9rem 1rem;display:flex}.profile-actions .actions{justify-content:flex-end}.profile-actions-copy{color:var(--subtle);font-size:.95rem}body.modal-open{overflow:hidden}@media (width<=768px){body.modal-open{width:100%;position:fixed}}.profile-progress{gap:.5rem}.premium-actions{justify-content:flex-end;margin-top:.5rem}.premium-actions button{flex:200px;line-height:1.35}.premium-actions .label-mobile{display:none}.profile-logout{box-shadow:none;text-align:center;background:0 0;border:none;align-items:center;margin-top:.25rem;margin-bottom:.35rem;padding:0}.logout-actions{justify-content:center;width:100%}.progress-bar{background:#ffffff14;border:1px solid #ffffff1f;border-radius:999px;width:100%;height:10px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,var(--accent),var(--accent-strong));width:0%;height:100%;transition:width .3s;position:absolute;top:0;left:0}.referral-link-row{flex-direction:column;gap:.35rem;margin-top:.35rem;display:flex}.referral-link{color:var(--text);word-break:break-all;text-underline-offset:3px;text-decoration:underline}.referral-link:hover,.referral-link:focus-visible{color:var(--accent)}.daily-card{margin-top:1rem}.daily-header{justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.75rem;display:flex}.daily-header h2{margin:0;font-size:1.1rem}.daily-header .status{color:var(--subtle);margin:0;font-size:.85rem}.daily-body{position:relative}.daily-list{justify-content:space-between;align-items:stretch;gap:.5rem;display:flex}.daily-item{text-align:center;flex-direction:column;flex:1 1 0;align-items:center;gap:.25rem;min-width:0;max-width:90px;display:flex}.daily-avatar{border:1px solid var(--border-strong);background:radial-gradient(circle at 30% 20%,#ffffff2e,#3ad9ff4d),linear-gradient(135deg,#3ad9ff3d,#6ff5c44d);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex;overflow:hidden}.daily-avatar img{object-fit:cover;filter:none;width:100%;height:100%}.daily-item-placeholder .daily-username,.daily-item-placeholder .daily-status{filter:blur(2px);opacity:.9}.daily-item-placeholder .daily-avatar img{filter:blur(5px);opacity:.9;transform:scale(1.15)}.daily-username{white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.85rem;font-weight:600;overflow:hidden}.daily-status{color:var(--accent);font-size:.75rem}.daily-action-btn{margin-top:.2rem;padding:.2rem .55rem;font-size:.75rem}.daily-overlay{border-radius:inherit;text-align:center;z-index:1;background:radial-gradient(circle at 30% 20%,#0f172a26,#0f172a73);justify-content:center;align-items:center;padding:.75rem;display:flex;position:absolute;inset:0}.daily-overlay p{color:var(--text);margin:0;font-size:.9rem}.daily-loading{justify-content:center;align-items:center;width:100%;min-height:100px;display:flex}@media (width<=640px){.daily-list{gap:.35rem}.daily-item{max-width:64px}.daily-avatar{width:52px;height:52px}.daily-username{font-size:.75rem}}body.chatting .kindness-card{display:none}.pm-modal{backdrop-filter:blur(10px);z-index:1200;background:#0f172acc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pm-modal.hidden{display:none}.pm-modal-content{background:var(--panel-bg);border:1px solid var(--border-strong);border-radius:1.25rem;flex-direction:column;width:min(560px,100% - 2rem);max-height:min(80vh,520px);display:flex;box-shadow:0 24px 60px #0000008c}.pm-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.9rem 1.1rem;display:flex}.pm-modal-header h3{margin:0;font-size:1.1rem}.pm-close-btn{width:32px;height:32px}.pm-modal-body{grid-template-columns:minmax(0,3fr) minmax(0,2fr);gap:.85rem;padding:.85rem 1.1rem;display:grid;overflow-y:auto}.pm-thread-view{flex-direction:column;flex:1;gap:.65rem;min-height:0;padding:.85rem 1.1rem 1rem;display:flex}.pm-thread-view.hidden{display:none}.pm-thread-header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.pm-thread-title{text-align:center;flex:1;min-width:0}.pm-thread-title-name{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.pm-thread-messages{border:1px solid var(--border);background:#0f172adb;border-radius:.9rem;flex:1;min-height:0;padding:.6rem .75rem;overflow-y:auto}.pm-message-list{flex-direction:column;gap:.45rem;margin:0;padding:0;list-style:none;display:flex}.pm-message-item{display:flex}.pm-message-bubble{word-break:break-word;background:#0f172af5;border:1px solid #94a3b859;border-radius:.9rem;max-width:min(420px,92%);padding:.45rem .6rem;line-height:1.25}.pm-message-item.self{justify-content:flex-end}.pm-message-item.self .pm-message-bubble{background:#3b82f638;border-color:#3b82f659}.pm-message-meta{color:var(--subtle);margin-top:.2rem;font-size:.75rem}@media (width<=640px){.message-avatar{width:28px;height:28px}.message .meta{font-size:.75rem}}.pm-message-form{gap:.5rem;display:flex}.pm-message-form input{flex:1;min-width:0}.pm-section{border:1px solid var(--border);background:#0f172adb;border-radius:.9rem;flex-direction:column;gap:.4rem;padding:.6rem .75rem;display:flex}.pm-inbox-section{grid-column:1/-1}.pm-inbox-label{letter-spacing:.08em;text-transform:uppercase;color:var(--subtle);padding:.1rem .15rem;font-size:.75rem}.pm-section-header{justify-content:space-between;align-items:baseline;gap:.35rem;display:flex}.pm-thread-list,.pm-request-list{flex-direction:column;gap:.4rem;max-height:260px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.pm-thread-item,.pm-request-item{background:#0f172af5;border:1px solid #94a3b866;border-radius:.7rem;justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem;display:flex}.pm-thread-main,.pm-request-main{align-items:center;gap:.5rem;min-width:0;display:flex}.pm-thread-meta{flex-direction:column;gap:.05rem;display:flex}.pm-thread-name{white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:.95rem;font-weight:600;overflow:hidden}.pm-thread-name-row{align-items:center;gap:.4rem;display:flex}.pm-thread-unread-dot{background:#ef4444;border-radius:999px;flex-shrink:0;width:9px;height:9px;box-shadow:0 0 0 2px #0f172ae6}.pm-thread-unread-dot.hidden{display:none}.pm-thread-subtitle{color:var(--subtle);font-size:.8rem}.pm-request-main .pm-thread-subtitle{text-transform:capitalize}.pm-thread-avatar{border:1px solid var(--border-strong);background:radial-gradient(circle at 30% 20%,#ffffff2e,#6ff5c44d),linear-gradient(135deg,#6ff5c43d,#3ad9ff4d);border-radius:999px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex;overflow:hidden}.pm-thread-avatar img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.pm-thread-actions,.pm-request-actions{flex-shrink:0;gap:.35rem;display:flex}.pm-thread-actions button,.pm-request-actions button{padding:.25rem .5rem;font-size:.8rem}.pm-modal-footer{border-top:1px solid var(--border);padding:.55rem 1.1rem .8rem}@media (width<=640px){.pm-modal-content{border-radius:1.1rem 1.1rem 0 0;width:100%;max-height:100vh;margin-top:auto}.pm-modal-body{grid-template-columns:1fr}}.ios-install-banner{-webkit-backdrop-filter:blur(20px);padding:1.25rem;padding-bottom:calc(1.25rem + env(safe-area-inset-bottom,0));z-index:1000;background:linear-gradient(165deg,#0f172afa 0%,#090e1afc 100%);border-top:1px solid #6ff5c426;flex-direction:column;gap:1rem;animation:.4s cubic-bezier(.16,1,.3,1) iosBannerSlideUp;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -20px 60px #00000080,0 -4px 20px #6ff5c414,inset 0 1px #ffffff0d}.ios-install-banner:before{content:"";background:#fff3;border-radius:2px;width:36px;height:4px;margin-top:-12px;position:absolute;top:0;left:50%;transform:translate(-50%)}@keyframes iosBannerSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.ios-banner-close{color:var(--subtle);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:all .2s;display:flex;position:absolute;top:.75rem;right:.75rem}.ios-banner-close:hover,.ios-banner-close:active{color:var(--text);background:#ffffff1f;border-color:#fff3;transform:scale(1.05)}.ios-banner-close svg{width:12px;height:12px}.ios-banner-header{align-items:center;gap:.875rem;padding-right:2rem;display:flex}.ios-banner-app-icon{background:linear-gradient(135deg,var(--accent)0%,var(--accent-strong)100%);border-radius:12px;flex-shrink:0;width:52px;height:52px;overflow:hidden;box-shadow:0 4px 12px #0000004d,0 0 0 1px #ffffff1a}.ios-banner-app-icon img{object-fit:cover;width:100%;height:100%}.ios-banner-title-group{flex:1;min-width:0}.ios-banner-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;margin:0 0 .15rem;font-size:1.1rem;font-weight:700}.ios-banner-subtitle{color:var(--subtle);margin:0;font-size:.8rem;line-height:1.3}.ios-banner-steps{background:#ffffff08;border:1px solid #ffffff0f;border-radius:14px;align-items:center;gap:.5rem;padding:.875rem 1rem;display:flex}.ios-banner-step{flex:1;align-items:center;gap:.5rem;display:flex}.ios-step-number{background:linear-gradient(135deg,var(--accent)0%,#6ff5c4b3 100%);color:#050912;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex;box-shadow:0 2px 8px #6ff5c44d}.ios-step-text{color:var(--text);flex:1;font-size:.8rem;line-height:1.3}.ios-step-text strong{color:var(--accent);font-weight:600}.ios-step-icon{color:var(--accent);opacity:.9;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ios-step-icon svg{width:18px;height:18px}.ios-banner-step-divider{background:linear-gradient(#0000,#ffffff26,#0000);flex-shrink:0;width:1px;height:28px;margin:0 .25rem}@media (width<=768px){.account-modal{align-items:flex-end;padding:.75rem}.sheet-handle{display:block}.account-modal-content{width:100%;max-height:85vh;padding:1rem 1.1rem calc(1.1rem + env(safe-area-inset-bottom,0));border-radius:1.25rem 1.25rem 0 0;box-shadow:0 -12px 36px #00000073}.account-modal-header{z-index:2;background:inherit;border-bottom:1px solid var(--border);margin-bottom:.35rem;padding-bottom:.65rem;position:sticky;top:-1rem}.profile-grid{grid-template-columns:1fr}.profile-referral-card{grid-column:1/-1}.profile-actions .actions{width:100%}.profile-actions .actions button{flex:1;width:auto}.premium-actions button{flex:none;padding:.55rem .9rem;font-size:.9rem;line-height:1.25}#account-buy-premium-btn,#account-claim-premium-btn{justify-content:center;align-items:center;gap:.25rem;height:auto;min-height:0;font-size:.85rem;line-height:1.15;display:inline-flex;padding-block:.35rem!important;padding-inline:.7rem!important}.premium-actions .label-desktop{display:none}.premium-actions .label-mobile{white-space:nowrap;display:inline}.profile-hero,.profile-card,.profile-actions{border-radius:1rem;margin-left:-.25rem;margin-right:-.25rem}}@media (width<=768px),(pointer:coarse) and (height<=900px){html.chatting,body.chatting{--page-padding:0;--mobile-border:var(--border);overscroll-behavior:none;-webkit-overflow-scrolling:touch;width:100%;height:100dvh;min-height:100dvh;max-height:100dvh;margin:0;padding:0;overflow:hidden}body.chatting .app-shell{display:contents!important}body.chatting .app-shell>:not(#chat-panel){display:none!important}body.chatting #chat-panel{height:var(--viewport-height,100dvh);max-height:var(--viewport-height,100dvh);background:var(--panel-bg);min-height:0;box-shadow:none;border:none;border-radius:0;grid-template-rows:auto auto 1fr auto;gap:0;padding:0;display:grid;position:fixed;inset:0;overflow:hidden}body.chatting #chat-panel .panel-header{grid-row:1}body.chatting #chat-friend-request{border-radius:0;grid-row:2;margin:0}body.chatting .message-window{grid-row:3}body.chatting #voice-recorder-bar,body.chatting #message-form{grid-row:4}body.chatting .panel-header{background:var(--card-bg);border-bottom:1px solid var(--mobile-border);align-items:center;gap:.5rem;padding:.65rem .85rem;box-shadow:0 6px 24px #00000059}body.chatting .panel-header .eyebrow{display:none}body.chatting .panel-header h2{margin:0;font-size:1rem}body.chatting .header-actions{flex-direction:row;align-items:center;gap:.35rem}body.chatting .header-actions button:not(.icon-btn):not(.disconnect-btn):not(.header-square-btn){background:var(--card-bg);border:1px solid var(--mobile-border);width:auto;padding:.4rem .75rem;font-size:.9rem}body.chatting .header-actions .icon-btn{border-radius:10px;width:36px;height:36px;padding:.25rem}body.chatting .header-actions .disconnect-btn{padding:.35rem .7rem;font-size:.8rem}body.chatting .header-square-btn{min-height:2.2rem;padding:.35rem .7rem;font-size:.8rem}body.chatting .message-window{border:1px solid var(--mobile-border);background:linear-gradient(180deg,#ffffff05,#ffffff03),var(--glass-bg);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border-radius:0;flex:auto;height:auto;min-height:0;max-height:none;padding:.65rem .85rem .25rem;overflow-y:auto}body.chatting #message-list{justify-content:flex-end;gap:.85rem;min-height:100%}body.chatting .message{max-width:100%}body.chatting #message-form{padding:.65rem .85rem calc(.85rem + env(safe-area-inset-bottom,0));border-top:1px solid var(--mobile-border);background:var(--panel-bg);border-radius:0;grid-template-columns:auto auto 1fr auto;align-items:center;gap:.75rem;margin:0;transition:grid-template-columns .2s;display:grid;box-shadow:0 -18px 32px #00000059}body.chatting #message-form:has(input:focus){grid-template-columns:1fr auto;gap:.75rem}body.chatting #message-form:has(input:focus) #photo-btn,body.chatting #message-form:has(input:focus) #gift-btn{display:none}body.chatting #message-form button{width:auto;min-width:0}body.chatting #message-form input{background:var(--input-bg);border-radius:.85rem;width:100%;padding:.85rem;font-size:16px;transition:padding .2s,font-size .2s}body.chatting #message-form:has(input:focus) input{padding:1rem;font-size:17px}body.chatting #message-form .icon-btn{border:1px solid var(--mobile-border);background:#ffffff05;width:48px;min-width:48px;height:48px;min-height:48px;padding:.3rem}body.chatting #message-form #send-record-btn{color:#041224;background:linear-gradient(135deg,#6ff5c4d9,#3ad9ffd9);border:none;border-radius:999px;width:48px;min-width:48px;height:48px;padding:0;box-shadow:0 4px 12px #3ad9ff26}body.chatting #message-form #send-record-btn:has(.mic-icon:not(.hidden)){border:1px solid var(--mobile-border);background:#ffffff05;border-radius:14px;box-shadow:0 8px 20px #00000040}body.chatting #message-form .send-label{display:none}body.chatting #message-form .send-icon{opacity:.95;width:16px;height:16px}body.chatting #message-form .mic-icon{width:22px;height:22px}body.chatting #message-form button:active,body.chatting #message-form .icon-btn:active{opacity:.7;transition:transform 60ms cubic-bezier(.4,0,.2,1),opacity 60ms;transform:scale(.9)}body.chatting #message-form #send-record-btn:active{opacity:.75;transform:scale(.85);box-shadow:0 3px 8px #3ad9ff40}@media (pointer:coarse){body.chatting #message-form button,body.chatting #message-form .icon-btn{-webkit-tap-highlight-color:transparent;transition:transform 80ms cubic-bezier(.4,0,.2,1),opacity 80ms,box-shadow 80ms}body.chatting #message-form button:active,body.chatting #message-form .icon-btn:active{transform:scale(.9)}body.chatting #message-form button,body.chatting #message-form .icon-btn{transition:transform .12s cubic-bezier(.34,1.56,.64,1),opacity .12s,box-shadow .12s}}@media (width<=390px){body.chatting #message-form{gap:.5rem;padding-left:.65rem;padding-right:.65rem}body.chatting #message-form .icon-btn{width:44px;min-width:44px;height:44px;min-height:44px}body.chatting #message-form #send-record-btn{width:44px;min-width:44px;height:44px}}body.chatting.keyboard-open #chat-panel{grid-template-rows:auto 1fr auto}body.chatting.keyboard-open .panel-header{padding:.5rem .75rem .35rem;box-shadow:0 4px 16px #00000040}body.chatting.keyboard-open #message-form{padding:.5rem .75rem calc(.65rem + env(safe-area-inset-bottom,0));box-shadow:0 -10px 24px #0000004d}}@media (width<=600px){body{--page-padding:1rem;padding-bottom:calc(var(--page-padding) + env(safe-area-inset-bottom,0) + var(--ios-banner-height,0px))}.profile-hero{flex-direction:column}.profile-identity{flex:auto}.profile-hero-meta{text-align:left;align-items:flex-start;width:100%;min-width:0}.profile-callout{flex-direction:column}.profile-card{padding:.9rem}.referral-actions{justify-content:flex-start;width:100%}.premium-actions,.logout-actions,.premium-actions button,.logout-actions button{width:100%}.actions{flex-direction:column}#chat-panel{min-height:70vh}.panel-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:row;justify-content:center;gap:.5rem;width:100%}.header-actions button{flex:1}.kindness-body{flex-direction:column;align-items:flex-start}body.chatting #message-form .icon-btn{border-radius:.65rem;place-self:center flex-start;width:44px;min-width:44px;height:44px;padding:.2rem}body.chatting #message-form .icon-btn svg,body.chatting #message-form .icon-btn img{width:18px;height:18px}body.chatting #message-form #send-record-btn{color:#041224;background:linear-gradient(135deg,#6ff5c4d9,#3ad9ffd9);border:none;border-radius:999px;place-self:center flex-end;width:44px;min-width:44px;height:44px;padding:0;box-shadow:0 3px 10px #3ad9ff26}body.chatting #message-form #send-record-btn:has(.mic-icon:not(.hidden)){border:1px solid var(--mobile-border);background:#ffffff05;border-radius:.65rem;box-shadow:0 8px 20px #00000040}body.chatting #message-form .send-label{display:none}body.chatting #message-form .send-icon{width:15px;height:15px}body.chatting #message-form #send-record-btn .send-icon{opacity:1}}.entry-contact{color:var(--subtle);justify-content:center;align-items:center;gap:.5rem;margin-top:1.25rem;font-size:.9rem;display:flex}body.waiting .entry-contact{display:none}.entry-contact-icon{flex-shrink:0;width:16px;height:16px}.entry-contact a{color:var(--text);font-weight:600;text-decoration:none;transition:color .15s}.entry-contact a:hover,.entry-contact a:focus-visible{color:var(--accent)}.blocked-overlay{z-index:9999;background:radial-gradient(circle at 12% 18%,#fb718526,transparent 32%),radial-gradient(circle at 82% 6%,#fb71851f,transparent 28%),radial-gradient(circle at 50% 90%,#fb718514,transparent 36%),var(--bg);padding:var(--page-padding);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.blocked-overlay.hidden{display:none}.blocked-panel{text-align:center;border-radius:var(--radius-lg);background:linear-gradient(135deg,#fb71851f,#fb71850a);border:1px solid #fb718559;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 30px 90px #00000080,0 0 60px #fb718526}.blocked-icon{filter:drop-shadow(0 4px 12px #fb718566);margin-bottom:1rem;font-size:4rem}.blocked-title{font-family:var(--font-display);color:var(--danger);letter-spacing:-.02em;margin:0 0 .75rem;font-size:1.75rem;font-weight:700}.blocked-message{color:var(--text);opacity:.9;margin:0 0 1rem;font-size:1.05rem}.blocked-until{color:var(--danger-soft);border-radius:var(--radius-sm);background:#fb71851f;border:1px solid #fb718540;margin:0;padding:.75rem 1rem;font-size:1.1rem;font-weight:600}.blocked-until:empty{display:none}.maintenance-overlay{z-index:9998;padding:var(--page-padding);background:radial-gradient(circle at 12% 18%,#6ff5c424,transparent 32%),radial-gradient(circle at 82% 6%,#3ad9ff29,transparent 28%),radial-gradient(circle at 50% 90%,#3ad9ff1a,transparent 36%),var(--bg);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.maintenance-overlay.hidden{display:none}.maintenance-panel{border-radius:var(--radius-lg);text-align:center;background:linear-gradient(135deg,#6ff5c41a,#3ad9ff0f);border:1px solid #6ff5c440;width:100%;max-width:560px;padding:2.4rem 2.1rem;box-shadow:0 30px 90px #0000008c,0 0 60px #3ad9ff1f}.maintenance-brand{justify-content:center;align-items:center;gap:.85rem;margin-bottom:1.35rem;display:flex}.maintenance-mark{border-radius:12px;flex-shrink:0;place-items:center;width:46px;height:46px;display:grid;overflow:hidden;box-shadow:0 4px 16px #3b82f659}.maintenance-eyebrow{letter-spacing:-.02em;font-weight:800}.maintenance-kicker{color:var(--subtle);font-size:.95rem}.maintenance-icon{filter:drop-shadow(0 10px 22px #3ad9ff2e);margin-bottom:.9rem;font-size:3.25rem}.maintenance-title{margin-bottom:.75rem;font-size:1.8rem}.maintenance-message{color:var(--text);opacity:.9;max-width:42ch;margin:0 auto 1.35rem;font-size:1.05rem}.maintenance-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.maintenance-link{border:1px solid var(--border);color:var(--text);background:#ffffff0a;border-radius:999px;justify-content:center;align-items:center;padding:.85rem 1.35rem;font-weight:700;text-decoration:none;transition:transform .12s,border-color .2s,background .2s;display:inline-flex}.maintenance-link:hover,.maintenance-link:focus-visible{border-color:var(--border-strong);background:#6ff5c414;transform:translateY(-1px)}.header-actions .game-invite-btn,.game-invite-btn{cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:.35rem;font-size:.7rem;font-weight:500;transition:all .2s;display:inline-flex;color:#6ff5c4!important;background:linear-gradient(135deg,#6ff5c42e,#3ad9ff1f)!important;border:1px solid #6ff5c466!important;flex:none!important}.header-actions .game-invite-btn svg,.game-invite-btn svg{flex-shrink:0;width:14px;height:14px;fill:#6ff5c4!important}[data-theme=light] .header-actions .game-invite-btn,[data-theme=light] .game-invite-btn{color:#14532d!important;background:#6ff5c42e!important;border-color:#6ff5c480!important}[data-theme=light] .header-actions .game-invite-btn svg,[data-theme=light] .game-invite-btn svg{fill:currentColor!important}.header-actions .game-invite-btn:hover:not(:disabled),.game-invite-btn:hover:not(:disabled){background:linear-gradient(135deg,#6ff5c447,#3ad9ff33)!important}[data-theme=light] .header-actions .game-invite-btn:hover:not(:disabled),[data-theme=light] .game-invite-btn:hover:not(:disabled){background:#6ff5c447!important}.header-actions .game-invite-btn:disabled,.game-invite-btn:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){#save-partner-btn,.add-friend-btn{padding:.35rem .7rem;font-size:.8rem}#save-partner-btn svg,.add-friend-btn svg,.game-invite-btn svg,#save-partner-btn img,.add-friend-btn img{width:14px;height:14px}}@media (width<=480px){body.chatting .header-actions .game-invite-btn,.game-invite-btn{padding:.35rem .7rem!important;font-size:.8rem!important}}body.game-panel-visible #chat-panel>:not(.message-window),body.game-panel-visible #message-window>:not(#game-container){display:none!important}body.game-panel-visible .message-window{box-shadow:none;background:0 0;border-color:#0000;padding:0;overflow:visible}.game-panel{background:var(--card-bg);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:min(100vw - 2rem,60rem);height:min(90vh,100vh - 2rem);box-shadow:var(--shadow-1),0 0 60px #6ff5c41a;z-index:100;backdrop-filter:blur(20px);padding:0;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.game-panel.hidden{display:none}.game-panel-layout{width:100%;height:100%;min-height:0;display:flex}.game-panel-main{flex-direction:column;flex:auto;min-width:0;min-height:0;padding:1.25rem;display:flex;overflow:hidden}.game-mini-chat{border-left:1px solid var(--border);background:#060a16b3;flex-direction:column;flex:0 0 17.5rem;gap:.6rem;width:17.5rem;min-height:0;padding:.9rem;display:flex;overflow:hidden}.game-mini-chat-header{color:var(--text);opacity:.9;font-size:.95rem;font-weight:700}.game-mini-message-window{border:1px solid var(--border);border-radius:var(--radius-md);background:#050912bf;flex:auto;min-height:0;padding:.6rem;overflow:hidden auto}[data-theme=light] .game-mini-chat{background:var(--muted-bg)}[data-theme=light] .game-mini-message-window{background:#fff;box-shadow:inset 0 1px #00000005}.game-mini-message-list{flex-direction:column;justify-content:flex-end;gap:.5rem;min-height:100%;margin:0;padding:0;list-style:none;display:flex}.game-mini-chat .message{max-width:100%;padding:.6rem .7rem;font-size:.9rem}.game-mini-chat .meta{font-size:.75rem}.game-mini-chat-input-slot{flex-direction:column;gap:.5rem;display:flex}.game-mini-chat #message-form{border-radius:var(--radius-sm);gap:.45rem;padding:.45rem}body.game-panel-visible .game-mini-chat #message-form{border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff0a;border-top:none;align-items:center;gap:.45rem;padding:.45rem;display:flex;box-shadow:inset 0 1px #ffffff0a}[data-theme=light] body.game-panel-visible .game-mini-chat #message-form{background:var(--btn-secondary-bg);box-shadow:inset 0 1px #00000005}body.game-panel-visible .game-mini-chat #message-form input{padding:.55rem .7rem;font-size:.9rem}body.game-panel-visible .game-mini-chat #message-form .icon-btn,.game-mini-chat #message-form .send-label{display:none}@media (width<=720px){.game-panel{-webkit-overflow-scrolling:touch;border-radius:0;width:100%;max-width:100%;margin:0;inset:0;overflow:hidden auto;transform:none;height:var(--viewport-height,100dvh)!important;max-height:var(--viewport-height,100dvh)!important}.game-panel-layout{flex-direction:column;height:100%}.game-panel-main{-webkit-overflow-scrolling:touch;flex:auto;min-height:0;padding:1rem;overflow:hidden auto}.game-board{flex:auto;min-height:0;overflow:visible}.game-actions{margin-top:auto}.game-mini-chat{border-left:none;border-top:1px solid var(--border);flex:0 0 clamp(9rem,30dvh,15rem);width:100%;max-height:clamp(9rem,30dvh,15rem);padding:.75rem}.game-mini-message-window{max-height:none}.game-board-battleship{overscroll-behavior:auto;touch-action:pan-y;height:auto;overflow-y:visible}.battleship-grids{flex-direction:column;max-width:100%}.battleship-section{max-width:100%}}.game-header{justify-content:center;align-items:center;margin-bottom:1rem;display:flex}.game-title{font-family:var(--font-display);color:var(--accent);letter-spacing:-.02em;margin:0;font-size:1.1rem;font-weight:700}.game-status{text-align:center;color:var(--subtle);background:var(--muted-bg);border-radius:var(--radius-sm);margin-bottom:1rem;padding:.5rem;font-size:.95rem}.game-status.your-turn{color:var(--accent);background:#6ff5c41a;border:1px solid #6ff5c433}.game-status.game-ended{color:var(--accent-strong);background:#3ad9ff1a;border:1px solid #3ad9ff33}.game-board{flex-shrink:0;width:100%;margin-bottom:1rem;overflow:visible}.game-board-tictactoe{aspect-ratio:1;grid-template-columns:repeat(3,1fr);gap:8px;max-width:min(100%,45vh);margin:0 auto;display:grid}.game-cell{border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-display);color:var(--text);cursor:pointer;aspect-ratio:1;background:#ffffff08;justify-content:center;align-items:center;font-size:2rem;font-weight:700;transition:all .15s;display:flex}.game-cell:hover:not(:disabled){border-color:var(--border-strong);background:#6ff5c41a}.game-cell:disabled{cursor:default}.game-cell.cell-x{color:var(--accent)}.game-cell.cell-o{color:var(--accent-strong)}.game-cell.winning-cell{border-color:var(--accent);background:#6ff5c433;animation:.6s ease-in-out infinite alternate pulse-win}@keyframes pulse-win{0%{box-shadow:0 0 10px #6ff5c44d}to{box-shadow:0 0 20px #6ff5c480}}.game-actions{justify-content:center;gap:.75rem;margin-top:.75rem;display:flex}.game-btn{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-radius:var(--radius-sm);color:var(--bg);font-family:var(--font-sans);cursor:pointer;border:none;flex:1;padding:.65rem 1rem;font-size:.9rem;font-weight:700;transition:all .2s}.game-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6ff5c44d}.game-btn.secondary{color:var(--subtle);border:1px solid var(--border);background:#ffffff14}.game-btn.secondary:hover{border-color:var(--danger);color:var(--danger);box-shadow:none;background:#fb718526}.game-board-connectfour{--connectfour-size:min(40rem,80vw,65vh);flex-direction:column;gap:8px;display:flex}.connectfour-columns{width:var(--connectfour-size);grid-template-columns:repeat(7,1fr);gap:4px;max-width:40rem;margin:0 auto;padding:6px;display:grid}.connectfour-col-btn{border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;background:#6ff5c426;border:1px solid #6ff5c44d;justify-content:center;align-items:center;padding:.4rem;font-size:.9rem;transition:all .15s;display:flex}.connectfour-col-btn:hover:not(:disabled){background:#6ff5c440;transform:translateY(-2px)}.connectfour-col-btn:disabled{opacity:.3;cursor:default}.connectfour-col-btn.column-full{opacity:.2}.connectfour-grid{border-radius:var(--radius-md);width:var(--connectfour-size);background:#3ad9ff14;border:2px solid #3ad9ff33;grid-template-rows:repeat(6,1fr);grid-template-columns:repeat(7,1fr);gap:4px;max-width:40rem;margin:0 auto;padding:6px;display:grid}.connectfour-cell{aspect-ratio:1;border:1px solid var(--border);background:#ffffff0d;border-radius:50%;transition:all .2s}.connectfour-cell.cell-x{background:radial-gradient(circle at 35% 35%,#a3f7d0,var(--accent));border-color:var(--accent);box-shadow:0 2px 8px #6ff5c466}.connectfour-cell.cell-o{background:radial-gradient(circle at 35% 35%,#7dd3fc,var(--accent-strong));border-color:var(--accent-strong);box-shadow:0 2px 8px #3ad9ff66}.connectfour-cell.winning-cell{animation:.6s ease-in-out infinite alternate pulse-win;transform:scale(1.05)}.game-selection-panel{background:var(--card-bg);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:min(100vw - 1.5rem,25rem);max-width:25rem;max-height:min(90vh,100vh - 2rem);box-shadow:var(--shadow-1),0 0 60px #6ff5c426;z-index:110;backdrop-filter:blur(20px);flex-direction:column;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.game-selection-panel.hidden{display:none}.game-selection-header{border-bottom:1px solid var(--border);background:#6ff5c40d;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.game-selection-header h3{font-family:var(--font-display);color:var(--accent);margin:0;font-size:1.1rem;font-weight:700}.game-bet-config{border-bottom:1px solid var(--border);background:#ffffff05;flex-direction:column;gap:.4rem;padding:.75rem 1rem;display:flex}.game-bet-label{color:var(--subtle);font-size:.8rem;font-weight:600}.game-bet-input-row{align-items:center;gap:.5rem;display:flex}.game-bet-input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:#ffffff0a;flex:0 0 120px;padding:.45rem .6rem;font-size:.9rem}.game-bet-input:disabled{opacity:.6}.game-bet-balance{color:var(--subtle);font-size:.8rem}.game-bet-hint{color:var(--subtle);margin:0;font-size:.75rem}.game-selection-close{border:1px solid var(--border);width:1.75rem;height:1.75rem;color:var(--subtle);cursor:pointer;background:#ffffff0d;border-radius:.375rem;justify-content:center;align-items:center;font-size:1.25rem;transition:all .15s;display:flex}.game-selection-close:hover{border-color:var(--danger);color:var(--danger);background:#fb718526}.game-selection-grid{flex-direction:column;gap:.4rem;padding:.75rem 1rem;display:flex;overflow-y:auto}.game-selection-card{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;background:#ffffff08;align-items:center;gap:.75rem;padding:.65rem .85rem;transition:all .2s;display:flex}.game-selection-card:hover{border-color:var(--accent);background:#6ff5c414;transform:translate(4px)}.game-selection-card:active{transform:translate(4px)scale(.98)}.game-card-icon{border-radius:var(--radius-sm);background:#ffffff0d;flex-shrink:0;justify-content:center;align-items:center;width:2.4rem;height:2.4rem;font-size:1.5rem;display:flex}.game-card-name{font-family:var(--font-display);color:var(--text);font-size:.95rem;font-weight:600;display:block}.game-card-desc{color:var(--subtle);margin-top:.15rem;font-size:.75rem;line-height:1.3;display:block}.game-board-rps{flex-direction:column;gap:1rem;display:flex}.rps-score{background:var(--muted-bg);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.9rem;display:flex}.rps-score .score-x{color:var(--accent);font-weight:600}.rps-score .score-o{color:var(--accent-strong);font-weight:600}.rps-score .score-round{color:var(--subtle)}.rps-choices-area{flex-direction:column;align-items:center;gap:1rem;display:flex}.rps-buttons{justify-content:center;gap:.75rem;display:flex}.rps-btn{border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;background:#ffffff0d;flex-direction:column;align-items:center;gap:.5rem;min-width:80px;padding:1rem;transition:all .2s;display:flex}.rps-btn:hover{border-color:var(--accent);background:#6ff5c41a;transform:translateY(-4px)}.rps-btn .choice-icon{font-size:2rem}.rps-btn .choice-name{color:var(--subtle);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.rps-result{align-items:center;gap:1.5rem;display:flex}.rps-choice{flex-direction:column;align-items:center;gap:.5rem;display:flex}.rps-choice .choice-icon{font-size:3rem}.rps-choice .choice-label{color:var(--subtle);font-size:.85rem}.rps-choice.revealed{animation:.3s ease-out rpsReveal}@keyframes rpsReveal{0%{opacity:0;transform:scale(0)rotate(-180deg)}to{opacity:1;transform:scale(1)rotate(0)}}.rps-vs{font-family:var(--font-display);color:var(--subtle);font-size:1.25rem;font-weight:700}.rps-round-result{border-radius:var(--radius-sm);text-align:center;padding:.5rem 1rem;font-weight:600}.rps-round-result.win{color:var(--accent);background:#6ff5c426}.rps-round-result.lose{color:var(--danger);background:#fb718526}.rps-round-result.tie{color:var(--accent-strong);background:#3ad9ff26}.rps-waiting{flex-direction:column;align-items:center;gap:.75rem;display:flex}.rps-waiting p{color:var(--subtle);font-size:.9rem}.rps-waiting .rps-choice.selected .choice-icon{font-size:3rem;animation:1.5s ease-in-out infinite pulse}.rps-next-btn{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-radius:var(--radius-sm);color:var(--bg);cursor:pointer;border:none;padding:.65rem 1.5rem;font-weight:600;transition:all .2s}.rps-next-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6ff5c44d}.game-board-pong{flex-direction:column;gap:.75rem;max-height:55vh;display:flex}.pong-score{background:var(--muted-bg);border-radius:var(--radius-sm);justify-content:space-between;padding:.5rem 1rem;font-weight:600;display:flex}.pong-score .score-x{color:var(--accent)}.pong-score .score-o{color:var(--accent-strong)}.pong-field{aspect-ratio:4/3;border:2px solid var(--border-strong);border-radius:var(--radius-sm);touch-action:none;user-select:none;background:linear-gradient(#1a1a2e 0%,#16213e 100%);width:100%;max-height:40vh;position:relative;overflow:hidden}.game-board-pong{touch-action:none;user-select:none}.pong-ball{background:#fff;border-radius:50%;width:.75rem;height:.75rem;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 10px #fff,0 0 20px #ffffff80}.pong-paddle{background:linear-gradient(180deg,var(--accent),var(--accent-strong));border-radius:4px;width:.5rem;position:absolute;box-shadow:0 0 10px #6ff5c480}.pong-paddle-x{left:4%}.pong-paddle-o{right:4%}.pong-center-line{background:repeating-linear-gradient(#0000,#0000 8px,#ffffff4d 8px 16px);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.pong-controls{justify-content:center;gap:1rem;display:flex}.pong-controls-hint{background:var(--muted-bg);border-radius:var(--radius-sm);justify-content:center;gap:1rem;padding:.5rem;display:flex}.pong-controls-hint .key-hint{color:var(--subtle);font-size:.8rem}.pong-guide-overlay{z-index:200;cursor:pointer;background:#000000d9;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.pong-guide-overlay.fading{animation:2s forwards fadeOut}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.pong-guide{background:var(--card-bg);border:1px solid var(--border-strong);border-radius:var(--radius-lg);text-align:center;max-width:320px;padding:1.5rem 2rem;box-shadow:0 0 60px #6ff5c433}.pong-guide h3{font-family:var(--font-display);color:var(--accent);margin:0 0 1rem;font-size:1.3rem}.pong-guide .guide-section{border-radius:var(--radius-sm);background:#ffffff08;margin-bottom:1rem;padding:.75rem}.pong-guide .guide-title{color:var(--text);margin-bottom:.5rem;font-size:.9rem;font-weight:600}.pong-guide .guide-keys{flex-direction:column;gap:.4rem;display:flex}.pong-guide .guide-key-row{color:var(--subtle);justify-content:center;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.pong-guide .key-box{border:1px solid var(--border);min-width:28px;height:28px;color:var(--text);background:#ffffff1a;border-radius:4px;justify-content:center;align-items:center;padding:0 6px;font-family:monospace;font-weight:600;display:inline-flex}.pong-guide .key-action{color:var(--accent);margin-left:.25rem}.pong-guide .guide-touch{color:var(--subtle);font-size:.85rem;line-height:1.4}.pong-guide .guide-tip{color:var(--accent-strong);margin-bottom:.75rem;font-size:.9rem;font-weight:600}.pong-guide .guide-dismiss{color:var(--subtle);opacity:.7;font-size:.75rem}.pong-countdown{font-family:var(--font-display);color:#fffc;text-shadow:0 0 30px #ffffff80;font-size:4rem;font-weight:700;animation:1s ease-in-out infinite countdownPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes countdownPulse{0%,to{opacity:1;transform:translate(-50%,-50%)scale(1)}50%{opacity:.7;transform:translate(-50%,-50%)scale(1.2)}}.game-board-battleship{flex-direction:column;gap:.75rem;width:100%;display:flex;overflow:hidden}.battleship-grids{gap:.75rem;width:100%;max-width:min(100%,70vh);margin:0 auto;display:flex}.battleship-section{flex-direction:column;flex:1;gap:.35rem;min-width:0;max-width:50%;display:flex}.battleship-label{color:var(--subtle);text-align:center;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.battleship-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:repeat(10,1fr);gap:1px;width:100%;max-width:100%;display:grid;overflow:hidden}.battleship-cell{aspect-ratio:1;box-shadow:none;cursor:default;border:none;border-radius:4px;justify-content:center;align-items:center;min-width:0;min-height:0;padding:0;font-size:.6rem;transition:all .15s;display:flex;overflow:hidden}.battleship-cell.cell-water{background:linear-gradient(135deg,#1e3a5f,#2d4a6f)}.enemy-grid .battleship-cell.cell-water:not(:disabled){cursor:crosshair}.enemy-grid .battleship-cell.cell-water:not(:disabled):hover{background:#fb71854d}.battleship-cell.cell-ship{background:linear-gradient(135deg,#4a5568,#718096);box-shadow:inset 0 0 4px #fff3}.battleship-cell.cell-hit{background:radial-gradient(circle at 40% 40%,#ff6b6b,#c53030,#7f1d1d);font-size:.85rem;animation:1.5s ease-in-out infinite hitPulse;box-shadow:0 0 8px #ff6b6bcc,inset 0 0 6px #ffc86480}.enemy-grid .battleship-cell.cell-hit{background:radial-gradient(circle at 40% 40%,#ff6b6b,#dc2626,#991b1b);box-shadow:0 0 10px #ff3b3be6}.your-grid .battleship-cell.cell-hit{background:radial-gradient(circle at 40% 40%,#fca5a5,#ef4444,#b91c1c);box-shadow:0 0 6px #ef4444b3}@keyframes hitPulse{0%,to{box-shadow:0 0 8px #ff6b6bcc,inset 0 0 6px #ffc86480}50%{box-shadow:0 0 14px #ff6b6b,inset 0 0 8px #ffc864b3}}@keyframes hitFlash{0%{transform:scale(1.3)}to{transform:scale(1)}}.battleship-cell.cell-miss{background:linear-gradient(135deg,#1e3a5f,#2d4a6f);position:relative}.battleship-cell.cell-miss:after{content:"";background:radial-gradient(circle,#ffffffe6,#c8dcff99);border-radius:50%;width:40%;height:40%;position:absolute;box-shadow:0 0 4px #ffffff80}.enemy-grid .battleship-cell.cell-miss{background:linear-gradient(135deg,#1e3a5f,#234567)}.enemy-grid .battleship-cell.cell-miss:after{background:radial-gradient(circle,#fff,#c8e6ffb3);width:50%;height:50%;box-shadow:0 0 6px #fff9}.your-grid .battleship-cell.cell-miss:after{background:#ffffff80;width:35%;height:35%}.battleship-ships-status{color:var(--subtle);background:var(--muted-bg);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.75rem}.battleship-stats{flex-direction:column;gap:.35rem;display:flex}.battleship-stats .stat-group{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.battleship-stats .stat-label{color:var(--text);min-width:90px;font-weight:600}.battleship-stats .stat-hits{color:#ef4444}.battleship-stats .stat-misses{color:#94a3b8}.battleship-stats .stat-sunk{color:var(--accent)}.battleship-last-shot{text-align:center;border-radius:var(--radius-sm);padding:.5rem;font-weight:600;animation:.3s ease-out slideUp}.battleship-last-shot.hit,.battleship-last-shot.sunk{color:var(--danger);background:#fb718526}.battleship-last-shot.miss{color:var(--accent-strong);background:#3ad9ff26}.game-board-checkers{flex-direction:column;gap:.75rem;display:flex}.checkers-score{background:var(--muted-bg);border-radius:var(--radius-sm);justify-content:space-between;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:flex}.checkers-score .score-you{color:var(--accent)}.checkers-score .score-opp{color:var(--accent-strong)}.checkers-grid{border:2px solid var(--border-strong);border-radius:var(--radius-sm);aspect-ratio:1;grid-template-columns:repeat(8,1fr);gap:0;width:min(32rem,65vw,45vh);max-width:32rem;margin:0 auto;display:grid;overflow:hidden}.checkers-cell{aspect-ratio:1;cursor:default;border:none;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex;position:relative}.checkers-cell.light{background:#f0d9b5}.checkers-cell.dark{background:#b58863}.checkers-cell.selectable{cursor:pointer}.checkers-cell.selectable:hover{filter:brightness(1.1)}.checkers-cell.selected{box-shadow:inset 0 0 0 3px var(--accent)}.checkers-cell.valid-move{position:relative}.checkers-cell.valid-move:after{content:"";background:#6ff5c499;border-radius:50%;width:30%;height:30%;position:absolute;box-shadow:0 0 8px #6ff5c4cc}.checkers-cell.must-jump{animation:.8s ease-in-out infinite mustJumpPulse}@keyframes mustJumpPulse{0%,to{box-shadow:inset 0 0 0 3px #fb718580}50%{box-shadow:inset 0 0 0 3px #fb7185}}.checkers-piece{border-radius:50%;justify-content:center;align-items:center;width:70%;height:70%;font-size:.7rem;transition:transform .15s;display:flex;box-shadow:0 2px 4px #0000004d,inset 0 -2px 4px #0003}.checkers-piece.my-piece{background:linear-gradient(#4ade80,#22c55e);border:2px solid #16a34a}.checkers-piece.enemy-piece{background:linear-gradient(#f87171,#ef4444);border:2px solid #dc2626}.checkers-piece.king{box-shadow:0 2px 4px #0000004d,inset 0 -2px 4px #0003,0 0 10px #ffd70080}.checkers-cell.selectable:hover .checkers-piece{transform:scale(1.1)}.checkers-hint{text-align:center;color:var(--subtle);background:var(--muted-bg);border-radius:var(--radius-sm);padding:.5rem;font-size:.8rem}.checkers-hint.must-jump-hint{color:var(--danger);background:#fb71851a;border:1px solid #fb71854d}.game-board-chess{flex-direction:column;gap:.5rem;padding:.5rem;display:flex}.chess-status{text-align:center;background:var(--muted-bg);border-radius:var(--radius-sm);padding:.5rem;font-size:.9rem;font-weight:600}.chess-status.in-check{color:var(--danger);background:#fb718533;border:1px solid #fb718566}.chess-captured{justify-content:space-between;gap:.5rem;padding:.25rem .5rem;font-size:.75rem;display:flex}.captured-row{align-items:center;gap:.25rem;display:flex}.captured-label{color:var(--subtle)}.captured-pieces{letter-spacing:1px;font-size:1rem}.chess-grid{border:2px solid var(--border-strong);border-radius:var(--radius-sm);aspect-ratio:1;grid-template-columns:repeat(8,1fr);gap:0;width:min(32rem,65vw,45vh);max-width:32rem;margin:0 auto;display:grid;overflow:hidden}.chess-cell{aspect-ratio:1;cursor:default;border:none;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex;position:relative}.chess-cell.light{background:#f0d9b5}.chess-cell.dark{background:#b58863}.chess-cell.selectable{cursor:pointer}.chess-cell.selectable:hover{filter:brightness(1.1)}.chess-cell.selected{box-shadow:inset 0 0 0 3px var(--accent)}.chess-cell.last-move{background:#ff06}.chess-cell.last-move.light{background:#cdd26a}.chess-cell.last-move.dark{background:#aba23a}.chess-cell.valid-move{position:relative}.chess-cell.valid-move:after{content:"";background:#6ff5c499;border-radius:50%;width:30%;height:30%;position:absolute;box-shadow:0 0 8px #6ff5c4cc}.chess-cell.valid-move.capture-move:after{background:0 0;border:3px solid #fb7185b3;border-radius:50%;width:90%;height:90%;box-shadow:0 0 8px #fb718580}.chess-cell.king-in-check{animation:.8s ease-in-out infinite checkPulse;background:#fb718580!important}@keyframes checkPulse{0%,to{box-shadow:inset 0 0 10px #fb718580}50%{box-shadow:inset 0 0 20px #fb7185cc}}.chess-piece{text-shadow:0 1px 2px #0000004d;user-select:none;font-size:1.8rem;line-height:1;transition:transform .15s}.chess-cell.selectable:hover .chess-piece{transform:scale(1.15)}.chess-hint{text-align:center;color:var(--subtle);background:var(--muted-bg);border-radius:var(--radius-sm);padding:.5rem;font-size:.8rem}@media (width<=480px){.game-panel{padding:0}.game-board-battleship,.game-board-checkers,.game-board-chess,.game-board-backgammon{margin:0}.rps-btn{min-width:65px;padding:.75rem}.rps-btn .choice-icon{font-size:1.5rem}.rps-choice .choice-icon{font-size:2rem}.battleship-grids{flex-direction:column;gap:1rem}.battleship-section{max-width:100%}.battleship-grid{grid-template-columns:repeat(10,minmax(24px,1fr));gap:3px}.battleship-cell{min-width:24px;min-height:24px;font-size:.7rem}.enemy-grid .battleship-cell.cell-water:not(:disabled){position:relative}.enemy-grid .battleship-cell.cell-water:not(:disabled):before{content:"";position:absolute;inset:-2px}.enemy-grid .battleship-cell.cell-water:not(:disabled):active{background:#fb718580;transform:scale(.95)}.battleship-label{padding:.25rem 0;font-size:.85rem}.battleship-stats .stat-group{font-size:.7rem}.pong-field{aspect-ratio:3/2}.checkers-grid{grid-template-columns:repeat(8,minmax(32px,1fr))}.checkers-cell{min-width:32px;min-height:32px}.chess-grid{grid-template-columns:repeat(8,minmax(32px,1fr))}.chess-cell{min-width:32px;min-height:32px}.chess-piece{font-size:1.4rem}.chess-captured{font-size:.65rem}.captured-pieces{font-size:.85rem}}.queue-minigame-wrapper{margin-top:1rem}[data-theme=light] .queue-minigame-toggle{background:linear-gradient(135deg,#6ff5c424 0%,#3ad9ff1f 100%)}[data-theme=light] .queue-minigame-toggle:hover{background:linear-gradient(135deg,#6ff5c438 0%,#3ad9ff2e 100%)}[data-theme=light] .queue-minigame-wrapper.expanded .queue-minigame-toggle,[data-theme=light] .queue-game-picker,[data-theme=light] .queue-game-playing{background:var(--muted-bg)}[data-theme=light] .queue-game-card{background:#fff;border-color:#0000000f}[data-theme=light] .queue-game-card:hover{background:#f9fafb}[data-theme=light] .queue-game-back{background:var(--btn-secondary-bg);color:var(--subtle)}[data-theme=light] .queue-game-back:hover{background:var(--btn-secondary-hover)}[data-theme=light] .queue-game-resume-overlay{color:var(--text);text-shadow:none;background:#ffffffeb}[data-theme=light] .queue-pong-message,[data-theme=light] .queue-snake-message,[data-theme=light] .queue-breakout-message,[data-theme=light] .queue-runner-message,[data-theme=light] .queue-tetris-message,[data-theme=light] .queue-flappy-message{color:var(--text);background:#fffffff5;border:1px solid #00000014}.queue-minigame-toggle{border:1px dashed var(--accent);border-radius:var(--radius-lg);width:100%;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;user-select:none;background:linear-gradient(135deg,#6366f126 0%,#8b5cf626 100%);padding:.85rem 1rem;font-size:.95rem;font-weight:600;transition:all .2s}.queue-minigame-toggle:hover{background:linear-gradient(135deg,#6366f140 0%,#8b5cf640 100%);border-style:solid}.queue-minigame-wrapper.expanded .queue-minigame-toggle{border-radius:var(--radius-lg)var(--radius-lg)0 0;background:#ffffff0d;border-style:solid;border-bottom-width:medium;border-bottom-color:currentColor}.queue-game-picker{border:1px solid var(--accent);border-radius:0 0 var(--radius-lg)var(--radius-lg);background:#0003;border-top:none;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.6rem;padding:1rem;display:none}.queue-game-card{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;-webkit-tap-highlight-color:transparent;user-select:none;background:#ffffff0d;flex-direction:column;align-items:center;gap:.35rem;padding:.75rem .5rem;transition:all .15s;display:flex}.queue-game-card:hover{border-color:var(--accent);background:#ffffff1f;transform:translateY(-2px)}.queue-game-card:active{transform:translateY(0)}.queue-game-card-icon{font-size:1.8rem;line-height:1}.queue-game-card-name{color:var(--subtle);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.7rem;overflow:hidden}.queue-game-playing{border:1px solid var(--accent);border-radius:0 0 var(--radius-lg)var(--radius-lg);background:#0003;border-top:none;padding-top:.5rem;display:none;position:relative}.queue-minigame-wrapper.playing .queue-game-playing{display:block}.queue-game-back{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--subtle);cursor:pointer;-webkit-tap-highlight-color:transparent;user-select:none;background:#ffffff14;align-items:center;gap:.4rem;margin:0 .75rem .5rem;padding:.5rem .75rem;font-size:.8rem;transition:all .15s;display:none}.queue-game-back:hover{color:var(--text);background:#ffffff1f}.queue-game-container{max-width:100%;padding:.75rem;display:none;overflow:hidden}.queue-game-resume-overlay{color:#fff;text-shadow:0 2px 6px #0009;z-index:10;backdrop-filter:blur(2px);background:#000000bf;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:none;position:absolute;inset:0}.queue-game-resume-overlay.active{display:flex}.queue-minigame{-webkit-tap-highlight-color:transparent;user-select:none;flex-direction:column;align-items:center;gap:.5rem;display:flex}.queue-minigame canvas,.queue-minigame button{-webkit-tap-highlight-color:transparent;user-select:none;outline:none}.queue-pong{width:100%}.queue-pong-score{color:var(--text);text-align:center;padding:.25rem 0;font-size:1rem;font-weight:600}.queue-pong-field{aspect-ratio:2;border:2px solid var(--border-strong);border-radius:var(--radius-md);cursor:crosshair;touch-action:none;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);width:100%;max-height:200px;position:relative;overflow:hidden}.queue-pong-center-line{background:repeating-linear-gradient(#ffffff4d 0 8px,#0000 8px 16px);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.queue-pong-ball{aspect-ratio:1;background:#fff;border-radius:50%;width:3%;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 10px #ffffff80}.queue-pong-paddle{background:#fff;border-radius:2px;width:2%;transition:top 50ms linear;position:absolute}.queue-pong-paddle-player{background:var(--accent);box-shadow:0 0 8px var(--accent);left:2%}.queue-pong-paddle-ai{background:#f87171;right:2%;box-shadow:0 0 8px #f87171}.queue-pong-countdown{color:var(--accent);text-shadow:0 0 20px var(--accent),0 0 40px var(--accent);z-index:10;justify-content:center;align-items:center;font-size:3rem;font-weight:700;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-pong-message{border-radius:var(--radius-md);z-index:20;color:#fff;text-align:center;cursor:pointer;background:#000000e6;padding:.5rem 1rem;font-size:.9rem;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-pong-controls{justify-content:center;gap:1rem;padding:.25rem 0;display:flex}.queue-pong-controls .key-hint{color:var(--subtle);font-size:.75rem}.queue-memory{width:100%}.queue-memory-stats{color:var(--subtle);text-align:center;padding:.25rem 0;font-size:.85rem}.queue-memory-grid{grid-template-columns:repeat(4,1fr);gap:.5rem;max-width:17.5rem;margin:0 auto;display:grid}.queue-memory-card{aspect-ratio:1;border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;min-width:3.125rem;min-height:3.125rem;color:var(--subtle);background:linear-gradient(135deg,#2d3748 0%,#1a202c 100%);justify-content:center;align-items:center;font-size:1.5rem;transition:all .2s;display:flex}.queue-memory-card:hover:not(:disabled){border-color:var(--accent);transform:scale(1.05)}.queue-memory-card.flipped{border-color:var(--accent);color:#fff;background:linear-gradient(135deg,#4a5568 0%,#2d3748 100%)}.queue-memory-card.matched{cursor:default;background:linear-gradient(135deg,#22c55e4d 0%,#16a34a4d 100%);border-color:#22c55e}.queue-memory-message{border-radius:var(--radius-md);color:#22c55e;text-align:center;cursor:pointer;background:#22c55e33;border:1px solid #22c55e;margin-top:.5rem;padding:.5rem 1rem;font-size:.85rem;display:none}.queue-snake{width:100%;position:relative}.queue-snake-score{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-snake-canvas{border:2px solid var(--border-strong);border-radius:var(--radius-md);touch-action:none;margin:0 auto;display:block}.queue-snake-message{border-radius:var(--radius-md);color:#fff;cursor:pointer;z-index:10;background:#000c;padding:.5rem 1rem;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-breakout{width:100%}.queue-breakout-score{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-breakout-canvas{border:2px solid var(--border-strong);border-radius:var(--radius-md);cursor:crosshair;touch-action:none;margin:0 auto;display:block}.queue-breakout-message{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#000c;padding:.5rem 1rem;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-breakout{position:relative}.queue-simon{width:100%}.queue-simon-score{text-align:center;color:var(--text);padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-simon-buttons{touch-action:manipulation;grid-template-columns:repeat(2,1fr);gap:.75rem;max-width:12.5rem;margin:0 auto;display:grid}.queue-simon-btn{aspect-ratio:1;cursor:pointer;border:3px solid #0000004d;border-radius:.75rem;min-width:5rem;transition:all .15s;box-shadow:0 4px 8px #0000004d}.queue-simon-btn:first-child{background:#ef4444!important}.queue-simon-btn:nth-child(2){background:#22c55e!important}.queue-simon-btn:nth-child(3){background:#3b82f6!important}.queue-simon-btn:nth-child(4){background:#eab308!important}.queue-simon-btn.lit{filter:brightness(1.4);transform:scale(1.08);box-shadow:0 0 20px}.queue-simon-message{border-radius:var(--radius-md);color:#ef4444;text-align:center;cursor:pointer;background:#ef444433;border:1px solid #ef4444;margin-top:.5rem;padding:.5rem 1rem;display:none}.queue-runner{width:100%;position:relative}.queue-runner-score{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-runner-canvas{border:2px solid var(--border-strong);border-radius:var(--radius-md);cursor:pointer;touch-action:manipulation;margin:0 auto;display:block}.queue-runner-message{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#000c;padding:.5rem 1rem;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-2048{width:100%}.queue-2048-score{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-2048-grid{border-radius:var(--radius-md);touch-action:none;background:#bbada0;grid-template-rows:repeat(4,2.75rem);grid-template-columns:repeat(4,2.75rem);gap:.25rem;width:fit-content;margin:0 auto;padding:.375rem;display:grid}.queue-2048-tile{border-radius:.25rem;justify-content:center;align-items:center;width:2.75rem;height:2.75rem;font-size:1rem;font-weight:700;display:flex}.queue-2048-message{border-radius:var(--radius-md);color:#22c55e;text-align:center;cursor:pointer;background:#22c55e33;border:1px solid #22c55e;margin-top:.5rem;padding:.5rem 1rem;display:none}.queue-minesweeper{width:100%}.queue-mine-stats{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}div.queue-mine-grid{grid-template-columns:repeat(5,2.5rem)!important;gap:.3125rem!important;width:fit-content!important;max-width:100%!important;margin:0 auto!important;display:grid!important}button.queue-mine-cell{cursor:pointer;color:#fff;background:#4a5568;border:2px solid #374151;border-radius:.25rem;font-size:1rem;font-weight:700;box-sizing:border-box!important;justify-content:center!important;align-items:center!important;width:2.5rem!important;height:2.5rem!important;margin:0!important;padding:0!important;display:flex!important}.queue-mine-cell.revealed{cursor:default;background:#2d3748;border-color:#1f2937}.queue-mine-cell.mine{background:#ef4444;border-color:#dc2626}.queue-mine-cell[data-count="1"]{color:#3b82f6}.queue-mine-cell[data-count="2"]{color:#22c55e}.queue-mine-cell[data-count="3"]{color:#ef4444}.queue-mine-cell[data-count="4"]{color:#8b5cf6}.queue-mine-message{border-radius:var(--radius-md);color:#ef4444;text-align:center;cursor:pointer;background:#ef444433;border:1px solid #ef4444;margin-top:.5rem;padding:.5rem 1rem;display:none}.queue-tetris{width:100%;position:relative}.queue-tetris-score{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-tetris-canvas{border:2px solid var(--border-strong);border-radius:var(--radius-md);touch-action:none;margin:0 auto;display:block}.queue-tetris-message{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#000c;padding:.5rem 1rem;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-flappy{width:100%;position:relative}.queue-flappy-score{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-flappy-canvas{border:2px solid var(--border-strong);border-radius:var(--radius-md);cursor:pointer;touch-action:manipulation;margin:0 auto;display:block}.queue-flappy-message{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#000c;padding:.5rem 1rem;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.queue-solitaire{width:100%}.queue-solitaire-stats{text-align:center;padding:.25rem 0;font-size:.9rem;font-weight:600}.queue-solitaire-grid{grid-template-columns:repeat(4,1fr);gap:.4rem;max-width:15rem;margin:0 auto;display:grid}.queue-solitaire-card{aspect-ratio:1;border-radius:var(--radius-md);cursor:pointer;color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:2px solid #fff3;justify-content:center;align-items:center;min-width:3.125rem;font-size:1.5rem;font-weight:700;transition:transform .2s,background .2s;display:flex}.queue-solitaire-card:hover{transform:scale(1.05)}.queue-solitaire-card.face-up{background:#fff;border-color:#d1d5db;font-size:1.8rem}.queue-solitaire-card.matched{color:#22c55e;background:#22c55e4d;border-color:#22c55e;font-size:1.2rem}.queue-solitaire-message{border-radius:var(--radius-md);color:#22c55e;text-align:center;cursor:pointer;background:#22c55e33;border:1px solid #22c55e;margin-top:.5rem;padding:.5rem 1rem;display:none}.queue-game-hint{color:var(--subtle);text-align:center;margin-top:.25rem;font-size:.7rem}@media (width<=480px){.queue-pong-field{max-height:150px}.queue-memory-grid{grid-template-columns:repeat(4,1fr);gap:.35rem;max-width:220px}.queue-memory-card{min-width:40px;min-height:40px;font-size:1.2rem}.queue-game-card{padding:.5rem .3rem}.queue-game-card-icon{font-size:1.4rem}.queue-game-card-name{font-size:.6rem}.queue-2048-grid{grid-template-rows:repeat(4,38px);grid-template-columns:repeat(4,38px)}.queue-2048-tile{width:38px;height:38px;font-size:.85rem}div.queue-mine-grid{grid-template-columns:36px 36px 36px 36px 36px!important;width:200px!important}button.queue-mine-cell{font-size:.9rem;width:36px!important;height:36px!important}.queue-simon-buttons{max-width:180px}.queue-simon-btn{min-width:70px}.queue-solitaire-grid{max-width:200px}.queue-solitaire-card{min-width:42px;font-size:1.3rem}.queue-solitaire-card.face-up{font-size:1.5rem}}@media (width<=600px){body.waiting .chat-card{border-left:none;border-right:none;border-radius:0;margin:0 -1rem;padding:1rem}body.waiting .waiting-card{border-radius:var(--radius-md);background:0 0;border:none;margin:0;padding:1rem}body.waiting .waiting-state{padding:.5rem 0}body.waiting .waiting-state h2{font-size:1.1rem}body.waiting .spinner{width:28px;height:28px}body.waiting .queue-minigame-wrapper{margin:0 -.5rem}body.waiting .queue-minigame-toggle{border-radius:var(--radius-md);padding:.75rem;font-size:.9rem}body.waiting .queue-minigame-wrapper.expanded .queue-minigame-toggle{border-radius:var(--radius-md)var(--radius-md)0 0}body.waiting .queue-game-picker{border-radius:0 0 var(--radius-md)var(--radius-md);grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:.5rem;padding:.75rem}body.waiting .queue-game-card{padding:.6rem .4rem}body.waiting .queue-game-card-icon{font-size:1.5rem}body.waiting .queue-game-playing{border-radius:0 0 var(--radius-md)var(--radius-md)}body.waiting .queue-game-container{padding:.5rem}body.waiting .queue-game-back{margin:.5rem .5rem 0;padding:.4rem .6rem;font-size:.75rem}.queue-snake-canvas,.queue-breakout-canvas,.queue-runner-canvas,.queue-tetris-canvas,.queue-flappy-canvas{max-width:100%;height:auto}}.gift-modal{z-index:1250;background:#04070ea6;justify-content:center;align-items:flex-end;padding:1rem;display:flex;position:fixed;inset:0}.gift-modal-content{background:var(--panel-bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(560px,100%);box-shadow:var(--shadow-soft);gap:.8rem;padding:1rem 1rem .85rem;display:grid}.gift-list{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.7rem;display:grid}[data-theme=light] .gift-modal-content{box-shadow:var(--shadow-1)}[data-theme=light] .gift-item{background:#f9fafb;border-color:#0000000f}[data-theme=light] button.gift-item{background:#f9fafb!important}[data-theme=light] .gift-item:hover:not(.disabled){background:#6ff5c414;border-color:#6ff5c44d}[data-theme=light] .shop-section{background:#fff;border-color:#0000000f}[data-theme=light] .avatar-item{background:#f9fafb;border-color:#0000000f}[data-theme=light] .avatar-item:hover:not(.disabled){border-color:#6ff5c44d}[data-theme=light] .avatar-item.selected{border-color:#6ff5c4;box-shadow:0 0 0 2px #6ff5c433}.gift-item{border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:center;box-shadow:none;background:#ffffff0a;border-radius:14px;justify-items:center;gap:.25rem;padding:.7rem .6rem;font-weight:700;display:grid}button.gift-item{color:var(--text)!important;background:#ffffff0a!important}.gift-item:hover:not(.disabled){border-color:var(--border-strong);background:#6ff5c414}.gift-item:active:not(.disabled){filter:none;transform:translateY(0)}.gift-item .gift-emoji{font-size:1.9rem}.gift-item .gift-cost{color:var(--text-muted);font-size:.8rem;font-weight:600}.gift-item.disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.gift-animation-overlay{z-index:1400;pointer-events:none;opacity:0;background:#070d1ceb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gift-animation-overlay.active{animation:2.4s ease-out forwards gift-overlay-fade}.gift-animation{font-size:clamp(4rem,12vw,8rem);animation:2.4s ease-out forwards gift-pop}.gift-animation-overlay.gift-sparkle{background:radial-gradient(circle,#60c0ff40,#070d1cf2)}.gift-animation-overlay.gift-flower{background:radial-gradient(circle,#ff95d840,#070d1cf2)}.gift-animation-overlay.gift-heart{background:radial-gradient(circle,#ff667d47,#070d1cf2)}.gift-animation-overlay.gift-crown{background:radial-gradient(circle,#ffd76e47,#070d1cf2)}.gift-animation-overlay.gift-clover{background:radial-gradient(circle,#4ade804d,#070d1cf2)}.gift-animation-overlay.gift-clover .gift-animation{filter:drop-shadow(0 0 20px #4ade80b3);animation:2.4s ease-out forwards gift-pop,.6s ease-in-out infinite gift-clover-shimmer}@keyframes gift-clover-shimmer{0%,to{filter:drop-shadow(0 0 20px #4ade80b3)}50%{filter:drop-shadow(0 0 35px #86eface6)}}.gift-animation-overlay.gift-fire{background:radial-gradient(circle,#fb923c59,#070d1cf2)}.gift-animation-overlay.gift-fire .gift-animation{filter:drop-shadow(0 0 25px #fb923ccc);animation:2.4s ease-out forwards gift-fire-blaze}@keyframes gift-fire-blaze{0%{opacity:0;filter:drop-shadow(0 0 10px #fb923c80);transform:scale(.4)}10%{opacity:1;transform:scale(1.1)}20%{filter:drop-shadow(0 0 40px #ef4444e6);transform:scale(1.15)rotate(-3deg)}30%{filter:drop-shadow(0 0 30px #fb923ccc);transform:scale(1.12)rotate(3deg)}40%{filter:drop-shadow(0 0 45px #ef4444e6);transform:scale(1.18)rotate(-2deg)}50%{transform:scale(1.14)rotate(2deg)}to{opacity:0;transform:scale(1.5)rotate(0)}}.gift-animation-overlay.gift-kiss{background:radial-gradient(circle,#f472b652,#070d1cf2)}.gift-animation-overlay.gift-kiss .gift-animation{filter:drop-shadow(0 0 25px #f472b6cc);animation:2.4s ease-out forwards gift-kiss-pulse}@keyframes gift-kiss-pulse{0%{opacity:0;transform:scale(.4)}15%{opacity:1;filter:drop-shadow(0 0 35px #f472b6e6);transform:scale(1.2)}30%{filter:drop-shadow(0 0 25px #f472b6b3);transform:scale(1.05)}45%{filter:drop-shadow(0 0 40px #fb7185e6);transform:scale(1.15)}to{opacity:0;transform:scale(1.45)}}.gift-animation-overlay.gift-diamond{background:radial-gradient(circle,#b9f2ff73 0%,#64c8ff40 35%,#070d1cf2 100%)}.gift-animation-overlay.gift-diamond.active{animation:3.2s ease-out forwards gift-overlay-fade}.gift-animation-overlay.gift-diamond .gift-animation{filter:drop-shadow(0 0 30px #b9f2ffe6)drop-shadow(0 0 60px #64c8ff99)drop-shadow(0 0 90px #fff6);animation:3.2s ease-out forwards gift-diamond-majestic}.gift-animation-overlay.gift-diamond:before{content:"";pointer-events:none;background:radial-gradient(2px 2px at 20% 30%,#ffffffe6,#0000),radial-gradient(2px 2px at 40% 70%,#fffc,#0000),radial-gradient(2px 2px at 80% 40%,#ffffffd9,#0000),radial-gradient(3px 3px at 60% 20%,#b9f2ffe6,#0000),radial-gradient(2px 2px at 90% 80%,#ffffffbf,#0000),radial-gradient(3px 3px at 10% 80%,#b9f2ffcc,#0000),radial-gradient(2px 2px at 70% 60%,#ffffffb3,#0000),radial-gradient(2px 2px at 30% 90%,#b9f2ffd9,#0000);animation:3.2s ease-out forwards gift-diamond-sparkles;position:absolute;inset:0}@keyframes gift-diamond-majestic{0%{opacity:0;transform:scale(.2)rotate(-30deg)}15%{opacity:1;transform:scale(1.3)rotate(10deg)}25%{transform:scale(1.1)rotate(-5deg)}40%{transform:scale(1.2)rotate(3deg)}60%{opacity:1;transform:scale(1.15)rotate(0)}to{opacity:0;transform:scale(1.8)rotate(15deg)}}@keyframes gift-diamond-sparkles{0%{opacity:0;transform:scale(.5)}20%{opacity:1;transform:scale(1)}80%{opacity:1;transform:scale(1.3)}to{opacity:0;transform:scale(1.5)}}@keyframes gift-overlay-fade{0%{opacity:0}10%{opacity:1}90%{opacity:1}to{opacity:0}}@keyframes gift-pop{0%{opacity:0;transform:scale(.4)}15%{opacity:1;transform:scale(1.15)}to{opacity:0;transform:scale(1.45)}}.game-board-backgammon{--bgm-point-width:clamp(1.75rem,2.2vw,2.5rem);--bgm-point-height:clamp(5rem,7vh,7.5rem);--bgm-piece-size:clamp(1.4rem,1.9vw,2.1rem);--bgm-piece-font:clamp(1.2rem,1.6vw,1.8rem);--bgm-bar-spacer:clamp(1.5rem,2.2vw,2.25rem);flex-direction:column;gap:.5rem;padding:.5rem;display:flex;position:relative}.backgammon-status{text-align:center;background:var(--muted-bg);border-radius:var(--radius-sm);padding:.5rem;font-size:.9rem;font-weight:600}.backgammon-score{justify-content:space-around;gap:1rem;padding:.25rem .5rem;font-size:.8rem;display:flex}.score-item{align-items:center;gap:.25rem;display:flex}.score-label{color:var(--subtle)}.score-value{font-weight:600}.backgammon-dice{background:var(--muted-bg);border-radius:var(--radius-sm);box-sizing:border-box;flex-direction:column;align-items:center;gap:.25rem;width:100%;min-height:4.25rem;padding:.5rem;display:flex}.dice-display{justify-content:center;align-items:center;gap:.5rem;min-height:2.25rem;font-size:2rem;display:flex}.dice-display-rolling{color:var(--subtle);letter-spacing:.2px;font-size:1rem;font-weight:700}.backgammon-dice.rolling .dice-remaining{opacity:.7}.hidden{display:none!important}.die{text-shadow:0 1px 2px #0000004d}.dice-remaining{color:var(--subtle);font-size:.75rem}.backgammon-board-wrapper{justify-content:center;align-items:stretch;gap:.5rem;display:flex}.backgammon-grid{border-radius:var(--radius-sm);background:#5d4037;border:3px solid #3e2723;flex-direction:column;gap:.25rem;padding:.25rem;display:flex}.backgammon-row{flex:1;gap:1px;display:flex}.backgammon-row.top{align-items:flex-start}.backgammon-row.bottom{align-items:flex-end}.bar-spacer{width:var(--bgm-bar-spacer);flex-shrink:0}.backgammon-point{width:var(--bgm-point-width);min-height:var(--bgm-point-height);cursor:default;flex-direction:column;align-items:center;padding:2px;transition:filter .15s;display:flex;position:relative}.backgammon-point:before{content:"";clip-path:polygon(0 0,100% 0,50% 100%);background:inherit;z-index:0;position:absolute;inset:0}.backgammon-point.bottom{flex-direction:column-reverse}.backgammon-point.bottom:before{clip-path:polygon(50% 0,100% 100%,0 100%)}.backgammon-point.light:before{background:#d4a574}.backgammon-point.dark:before{background:#8b4513}.backgammon-point.selectable{cursor:pointer}.backgammon-point.selectable:hover{filter:brightness(1.2)}.point-label{color:#fff9;pointer-events:none;font-size:.5rem;position:absolute}.backgammon-row.top .point-label{bottom:-.75rem}.backgammon-row.bottom .point-label{top:-.75rem}.backgammon-piece{z-index:1;width:var(--bgm-piece-size);height:var(--bgm-piece-size);font-size:var(--bgm-piece-font);text-shadow:0 1px 3px #0006;user-select:none;background:radial-gradient(circle at 30% 30%,#ffffff4d,#0000 60%);border-radius:50%;justify-content:center;align-items:center;line-height:1;transition:transform .15s;display:flex;position:relative}.backgammon-point.selectable:hover .backgammon-piece{transform:scale(1.1)}.piece-count{color:#fff;z-index:2;background:#000c;border-radius:3px;margin-top:-.25rem;padding:1px 4px;font-size:.6rem;position:relative}.backgammon-bar{background:#3e2723;flex-direction:column;justify-content:space-between;align-items:center;gap:.25rem;min-width:clamp(2.5rem,3.2vw,3.25rem);padding:.5rem .25rem;display:flex}.bar-label{color:#ffffff80;writing-mode:vertical-rl;text-orientation:mixed;font-size:.6rem}.bar-section{flex-direction:column;align-items:center;gap:2px;min-height:2rem;padding:.25rem;font-size:.9rem;display:flex}.bar-section.selectable{cursor:pointer;border-radius:var(--radius-sm);background:#ffffff1a}.bar-section.selectable:hover{background:#fff3}.backgammon-home{border-radius:var(--radius-sm);background:#2e7d32;border:2px solid #1b5e20;flex-direction:column;justify-content:center;align-items:center;min-width:2rem;padding:.5rem;display:flex}.home-label{color:#ffffffb3;margin-bottom:.25rem;font-size:.5rem}.home-pieces{letter-spacing:-2px;word-break:break-all;max-width:1.5rem;font-size:.6rem;line-height:1}.home-pieces.mine{color:#333}.home-pieces.opponent{color:#fff}.dice-selector-popup{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);z-index:100;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 20px #0000004d}.dice-selector-label{color:var(--subtle);font-size:.85rem}.dice-selector-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;min-width:2.5rem;padding:.5rem 1rem;font-size:1.25rem;font-weight:600;transition:background .15s}.dice-selector-btn:hover{background:var(--accent-hover)}.dice-selector-btn.cancel{background:var(--muted-bg);color:var(--text);font-size:1rem}.dice-selector-btn.cancel:hover{background:var(--border)}.backgammon-no-moves{text-align:center;border-radius:var(--radius-sm);background:#fbbf241a;border:1px solid #fbbf244d;padding:.75rem}.backgammon-no-moves p{color:var(--warning);margin:0 0 .5rem;font-size:.85rem}.end-turn-btn{background:var(--warning);color:#000}.backgammon-hint{text-align:center;color:var(--subtle);background:var(--muted-bg);border-radius:var(--radius-sm);padding:.5rem;font-size:.8rem}.backgammon-roll-section{justify-content:center;padding:1rem;display:flex}.roll-dice-btn{color:#fff;border-radius:var(--radius-md);cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;align-items:center;gap:.5rem;padding:1rem 2rem;font-size:1.25rem;font-weight:700;transition:all .2s;animation:2s ease-in-out infinite rollBtnPulse;display:flex;box-shadow:0 4px 15px #f59e0b66}.roll-dice-btn:hover:not(:disabled){transform:translateY(-2px)scale(1.05);box-shadow:0 6px 20px #f59e0b80}.roll-dice-btn:active:not(:disabled){transform:translateY(0)scale(.98)}.roll-dice-btn:disabled{opacity:.7;cursor:not-allowed;animation:none}.roll-dice-icon{font-size:1.5rem;animation:.5s ease-in-out infinite diceShake}@keyframes rollBtnPulse{0%,to{box-shadow:0 4px 15px #f59e0b66}50%{box-shadow:0 4px 25px #f59e0b99}}@keyframes diceShake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.backgammon-wait-section{justify-content:center;padding:1rem;display:flex}.wait-text{color:var(--subtle);background:var(--muted-bg);border-radius:var(--radius-md);padding:.75rem 1.5rem;font-size:.9rem;animation:1.5s ease-in-out infinite waitPulse}@keyframes waitPulse{0%,to{opacity:.7}50%{opacity:1}}.dice-roll-overlay{z-index:50;pointer-events:none;border-radius:var(--radius-md);background:#000000d9;flex-direction:column;justify-content:center;align-items:center;animation:2.5s ease-out forwards diceOverlayFade;display:flex;position:absolute;inset:0}.dice-roll-title{color:#fffc;margin-bottom:.5rem;font-size:1rem;animation:2.5s ease-out forwards diceTextFade}.dice-roll-container{perspective:500px;gap:1.5rem;display:flex}.dice-roll-die{filter:drop-shadow(0 0 20px #ffc864cc);text-shadow:0 0 30px #ffc86499;font-size:5rem;animation:.8s cubic-bezier(.25,.46,.45,.94) forwards diceRoll}.dice-roll-die:first-child{animation-delay:.1s}.dice-roll-die:nth-child(2){animation-delay:.25s}.dice-roll-result{color:#fbbf24;opacity:0;text-shadow:0 0 15px #fbbf24cc;margin-top:1rem;font-size:1.5rem;font-weight:700;animation:.4s ease-out .9s forwards diceResultPop}.dice-roll-doubles{color:#34d399;opacity:0;text-shadow:0 0 15px #34d399cc;margin-top:.25rem;font-size:1.2rem;animation:.4s ease-out 1.1s forwards diceResultPop}@keyframes diceOverlayFade{0%{opacity:0}10%{opacity:1}70%{opacity:1}to{opacity:0}}@keyframes diceTextFade{0%{opacity:0;transform:translateY(-10px)}15%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0}}@keyframes diceRoll{0%{opacity:0;transform:rotateX(720deg)rotateY(360deg)scale(.2)}30%{opacity:1}60%{transform:rotateX(0)rotateY(0)scale(1.2)}80%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes diceResultPop{0%{opacity:0;transform:scale(.5)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@media (width<=480px){.game-board-backgammon{--bgm-point-width:clamp(1.6rem,6.3vw,2rem);--bgm-point-height:clamp(4.7rem,8.2vh,5.8rem);--bgm-piece-size:clamp(1.35rem,5.2vw,1.65rem);--bgm-piece-font:clamp(1.1rem,4.3vw,1.35rem);--bgm-bar-spacer:clamp(1rem,3.9vw,1.3rem)}.backgammon-bar{min-width:clamp(1.95rem,5vw,2.35rem)}.dice-display{font-size:clamp(1.45rem,5vw,1.95rem)}}@media (width<=360px){.game-board-backgammon{--bgm-point-width:clamp(1.5rem,6vw,1.85rem);--bgm-point-height:clamp(4.4rem,8vh,5.4rem);--bgm-piece-size:clamp(1.25rem,5vw,1.55rem);--bgm-piece-font:clamp(1.05rem,4.2vw,1.25rem);--bgm-bar-spacer:clamp(.95rem,3.7vw,1.2rem)}.backgammon-bar{min-width:clamp(1.85rem,4.8vw,2.2rem)}}@keyframes slideInFromRight{0%{opacity:.8;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutToRight{0%{opacity:1;transform:translate(0)}to{opacity:.8;transform:translate(100%)}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDownSheet{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes mobileScaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media (width>=769px){.mobile-tab-bar{display:none!important}}@media (width<=768px){.mobile-tab-bar{z-index:1100;height:calc(56px + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0);background:var(--glass-bg);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px)saturate(150%);justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}[data-theme=dark] .mobile-tab-bar{-webkit-backdrop-filter:none;background:#090e1a;box-shadow:0 -10px 24px #00000059}[data-theme=light] .mobile-tab-bar{-webkit-backdrop-filter:none;background:#fff;box-shadow:0 -10px 24px #00000014}.tab-item{box-shadow:none;color:var(--subtle);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 0;transition:color .15s;display:flex;position:relative}[data-theme=light] .tab-item{box-shadow:none}.tab-item:active{opacity:.7;box-shadow:none;filter:none;transform:none}.tab-item:hover:not(:disabled){box-shadow:none;filter:none;transform:none}.tab-item.active{color:var(--accent)}.tab-item:disabled{opacity:.35;cursor:not-allowed}.tab-icon{background-color:currentColor;width:24px;height:24px;display:block;mask-position:50%;mask-size:contain;mask-repeat:no-repeat}.tab-icon-shop{mask-image:url(icon-tab-shop.bbe351d7.svg)}.tab-icon-messages{mask-image:url(icon-tab-messages.b1033d02.svg)}.tab-icon-profile{mask-image:url(icon-tab-profile.834a4ffc.svg)}@supports not (mask-image:url("")){.tab-icon{background:0 0}.tab-icon-shop{background:url(icon-tab-shop.bbe351d7.svg) 50%/contain no-repeat}.tab-icon-messages{background:url(icon-tab-messages.b1033d02.svg) 50%/contain no-repeat}.tab-icon-profile{background:url(icon-tab-profile.834a4ffc.svg) 50%/contain no-repeat}}.tab-icon svg,.tab-icon img{width:24px;height:24px;display:block}.tab-label{text-transform:capitalize;font-size:10px;font-weight:600}.tab-badge{background:var(--danger);border-radius:50%;width:8px;height:8px;margin-left:10px;position:absolute;top:6px;left:50%}.tab-badge.hidden{display:none}body{padding-bottom:calc(var(--page-padding) + 56px + env(safe-area-inset-bottom,0) + var(--ios-banner-height,0px))}body:not(.waiting) #daily-picks-card{margin-bottom:calc(56px + env(safe-area-inset-bottom,0) + .75rem)}body.waiting #daily-picks-card{margin-bottom:1rem}body.chatting .mobile-tab-bar{display:none}body.chatting{padding-bottom:0}body.modal-open .mobile-tab-bar,body:not(.signed-in) #tab-messages,body:not(.chatting) .hero-shop-btn,body:not(.chatting) .hero-pm-btn,body:not(.chatting) .hero-profile-btn{display:none}.coins-pill{padding:.35rem .5rem;font-size:.75rem}.account-modal:not(.hidden){background:var(--bg);z-index:1200;border-radius:0;padding:0;animation:.3s cubic-bezier(.16,1,.3,1) slideInFromRight;position:fixed;inset:0}.account-modal.closing{animation:.25s cubic-bezier(.16,1,.3,1) forwards slideOutToRight}.account-modal-content{width:100%;max-width:none;height:100%;max-height:none;padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top,0));padding-bottom:calc(2rem + env(safe-area-inset-bottom,0));-webkit-overflow-scrolling:touch;background:var(--bg);border:none;border-radius:0;overflow-y:auto}.account-modal .sheet-handle{display:none}.account-modal-content .account-card-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.pm-modal:not(.hidden){background:var(--bg);z-index:1200;border-radius:0;padding:0;animation:.3s cubic-bezier(.16,1,.3,1) slideInFromRight;position:fixed;inset:0}.pm-modal.closing{animation:.25s cubic-bezier(.16,1,.3,1) forwards slideOutToRight}.pm-modal-content{width:100%;max-width:none;height:100%;max-height:none;padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top,0));padding-bottom:calc(2rem + env(safe-area-inset-bottom,0));-webkit-overflow-scrolling:touch;background:var(--card-bg);border:none;border-radius:0;overflow-y:auto}.pm-modal .sheet-handle{display:none}.gift-modal:not(.hidden){background:#050912d9;align-items:flex-end;padding:0}.gift-modal-content{width:100%;max-width:none;padding:0 1rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0));-webkit-overflow-scrolling:touch;border-radius:24px 24px 0 0;max-height:75vh;animation:.35s cubic-bezier(.16,1,.3,1) slideUpSheet;overflow-y:auto}.gift-modal.closing .gift-modal-content{animation:.25s cubic-bezier(.16,1,.3,1) forwards slideDownSheet}.gift-modal-content:before{content:"";background:#ffffff40;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:.75rem auto .5rem;display:block}[data-theme=light] .gift-modal-content:before{background:#0000002e}.gift-modal-header{padding-top:.5rem}.camera-overlay:not(.hidden){background:#050912d9;align-items:flex-end;padding:0}.camera-overlay-panel{width:100%;max-width:none;padding:0 1rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0));-webkit-overflow-scrolling:touch;border-radius:24px 24px 0 0;max-height:85vh;animation:.35s cubic-bezier(.16,1,.3,1) slideUpSheet;overflow-y:auto}.camera-overlay.closing .camera-overlay-panel{animation:.25s cubic-bezier(.16,1,.3,1) forwards slideDownSheet}.camera-overlay-panel:before{content:"";background:#ffffff40;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:.75rem auto .5rem;display:block}.camera-overlay-header{padding-top:.5rem}.coins-help-popover:not(.hidden){width:100%;max-width:none;padding:0 1rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0));z-index:1300;border-radius:24px 24px 0 0;animation:.3s cubic-bezier(.16,1,.3,1) slideUpSheet;position:fixed;inset:auto 0 0}.coins-help-popover.closing{animation:.25s cubic-bezier(.16,1,.3,1) forwards slideDownSheet}.coins-help-popover:before{content:"";background:#ffffff40;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:.75rem auto .5rem;display:block}.shop-page:not(.hidden){z-index:1250;background:var(--bg);padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top,0));padding-bottom:calc(2rem + env(safe-area-inset-bottom,0));-webkit-overflow-scrolling:touch;animation:.3s cubic-bezier(.16,1,.3,1) slideInFromRight;position:fixed;inset:0;overflow-y:auto}.shop-page.closing{animation:.25s cubic-bezier(.16,1,.3,1) forwards slideOutToRight}.entry-card{margin-bottom:0}.entry-contact{margin-bottom:.75rem}.hero-top{padding:.75rem 0}.brand-lockup{gap:.5rem}.brand-mark{width:2rem;height:2rem}.eyebrow{font-size:1rem}.mobile-view-enter{animation:.2s ease-out mobileScaleIn}.maintenance-overlay,.blocked-overlay{padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0)}}.welcome-screen{z-index:2000;background:var(--bg);justify-content:center;align-items:center;padding:1.5rem;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.welcome-screen.hidden{display:none}.welcome-card{background:var(--card-bg);border:1px solid var(--border);width:min(420px,100%);box-shadow:var(--shadow-1);border-radius:24px;flex-direction:column;gap:2rem;padding:2.5rem 2rem;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;display:flex}.welcome-brand{text-align:center;flex-direction:column;align-items:center;gap:.75rem;display:flex}.welcome-logo{border-radius:18px;width:72px;height:72px;box-shadow:0 12px 32px #22c55e40}.welcome-title{letter-spacing:-.02em;color:var(--text);margin:0;font-size:1.75rem;font-weight:700}.welcome-subtitle{color:var(--subtle);margin:0;font-size:1rem;line-height:1.5}.welcome-theme-picker{flex-direction:column;gap:.75rem;display:flex}.welcome-theme-label{color:var(--subtle);text-align:center;margin:0;font-size:.875rem;font-weight:600}.theme-options{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.theme-option{border:2px solid var(--border);background:var(--muted-bg);color:var(--text);cursor:pointer;border-radius:16px;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.theme-option:hover{border-color:var(--border-strong);background:#22c55e14}.theme-option.selected{border-color:var(--accent);background:#22c55e1f;box-shadow:0 0 0 3px #22c55e26}.theme-option-icon{width:28px;height:28px;color:var(--accent)}.welcome-actions{flex-direction:column;gap:.75rem;display:flex}.welcome-btn{cursor:pointer;border:none;border-radius:14px;width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:700;transition:all .2s}.welcome-btn.primary{color:#fff;background:linear-gradient(135deg,#22c55e,#10b981);box-shadow:0 8px 24px #22c55e4d}.welcome-btn.primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #22c55e66}.welcome-btn.secondary{background:var(--muted-bg);color:var(--text);border:1px solid var(--border)}.welcome-btn.secondary:hover{border-color:var(--border-strong);background:#22c55e14}[data-theme=light] .welcome-card{background:#fff;box-shadow:0 20px 60px #0000001a}[data-theme=light] .welcome-logo{box-shadow:0 12px 32px #6ff5c433}[data-theme=light] .theme-option{background:#f9fafb}[data-theme=light] .theme-option:hover{background:#6ff5c40f}[data-theme=light] .welcome-btn.secondary{background:#f9fafb}[data-theme=light] .welcome-btn.secondary:hover{background:#6ff5c40f}@media (width<=480px){.welcome-screen{align-items:flex-end;padding:1rem}.welcome-card{padding:2rem 1.5rem calc(2rem + env(safe-area-inset-bottom,0));border-radius:24px 24px 0 0;width:100%;max-width:none}.welcome-title{font-size:1.5rem}.welcome-logo{width:56px;height:56px}}.hero-theme-btn{background:var(--muted-bg);border:1px solid var(--border);width:40px;height:40px;color:var(--text);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;transition:all .2s;display:flex}.hero-theme-btn:hover{border-color:var(--border-strong);background:#22c55e1a}.hero-theme-btn .theme-icon{width:20px;height:20px;transition:transform .3s}.hero-theme-btn .theme-icon.hidden,[data-theme=light] #theme-icon-sun{display:none}[data-theme=light] #theme-icon-moon.hidden{display:block}.hero-theme-btn:hover .theme-icon{transform:rotate(15deg)}[data-theme=light] .hero-theme-btn{background:#f9fafb}[data-theme=light] .hero-theme-btn:hover{background:#6ff5c414}