@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #FAFAFA;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-elevated: #F5F5F5;--bg-input: #F0F0F0;--bg-overlay: rgba(0, 0, 0, .4);--accent-primary: #2D5A3D;--accent-primary-light: #3D7A54;--accent-primary-bg: rgba(45, 90, 61, .08);--accent-secondary: #D4A574;--accent-tertiary: #5B8C6E;--accent-warm: #E8B87A;--color-success: #22C55E;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--color-success-bg: rgba(34, 197, 94, .1);--color-warning-bg: rgba(245, 158, 11, .1);--color-error-bg: rgba(239, 68, 68, .1);--color-info-bg: rgba(59, 130, 246, .1);--text-primary: #1A1A2E;--text-secondary: #4A4A5A;--text-muted: #94A3B8;--text-inverse: #FFFFFF;--text-accent: var(--accent-primary);--border-color: #E8E8E8;--border-light: #F0F0F0;--border-focus: var(--accent-primary);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12);--shadow-card: 0 2px 12px rgba(0, 0, 0, .06);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .1);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--font-display: "Nunito", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--topbar-height: 4rem;--bottomnav-height: 4.5rem;--max-width: 1200px;--app-text-scale: 1;--focus-ring: 0 0 0 3px rgba(45, 90, 61, .2);--state-positive: #0F766E;--state-positive-bg: rgba(15, 118, 110, .12);--state-negative: #C2410C;--state-negative-bg: rgba(194, 65, 12, .12)}[data-theme=dark]{--bg-primary: #1E1E24;--bg-secondary: #26262E;--bg-card: #2A2A34;--bg-elevated: #32323C;--bg-input: #2E2E38;--bg-overlay: rgba(0, 0, 0, .6);--accent-primary: #5B9E76;--accent-primary-light: #6DB888;--accent-primary-bg: rgba(91, 158, 118, .12);--accent-secondary: #C49B6A;--accent-tertiary: #7AB893;--accent-warm: #D4A872;--color-success-bg: rgba(34, 197, 94, .15);--color-warning-bg: rgba(245, 158, 11, .15);--color-error-bg: rgba(239, 68, 68, .15);--color-info-bg: rgba(59, 130, 246, .15);--text-primary: #F0EDE8;--text-secondary: #B0ADA8;--text-muted: #787470;--text-inverse: #1E1E24;--border-color: #3A3A44;--border-light: #32323C;--border-focus: var(--accent-primary);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .4);--shadow-card: 0 2px 12px rgba(0, 0, 0, .2);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .3);--focus-ring: 0 0 0 3px rgba(91, 158, 118, .25)}[data-theme=dark] body:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.03;background-image:repeating-linear-gradient(90deg,transparent,transparent 3px,rgba(200,180,160,.5) 3px,rgba(200,180,160,.5) 4px)}html{font-size:calc(16px * var(--app-text-scale));-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;transition:background-color var(--transition-slow),color var(--transition-slow);line-height:1.6}#root{min-height:100vh;position:relative;z-index:1}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;padding-bottom:calc(var(--bottomnav-height) + env(safe-area-inset-bottom,0px) + 16px)}.skip-link{position:fixed;top:var(--spacing-sm);left:var(--spacing-sm);z-index:2000;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-md);transform:translateY(-150%);transition:transform var(--transition-fast)}.skip-link:focus-visible{transform:translateY(0)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(min-width:769px){.app-main{padding-bottom:0}}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.25;color:var(--text-primary)}h1{font-size:clamp(1.75rem,5vw,2.5rem);font-weight:800;letter-spacing:-.02em}h2{font-size:clamp(1.35rem,3.5vw,1.75rem);font-weight:700}h3{font-size:clamp(1.1rem,2.5vw,1.35rem);font-weight:700}p{line-height:1.65;color:var(--text-secondary)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary-light)}small{font-size:.8rem;color:var(--text-muted)}:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:12px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--accent-primary);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent-primary-light);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--accent-primary)}.btn-outline{background:transparent;color:var(--accent-primary);border:1.5px solid var(--accent-primary)}.btn-outline:hover{background:var(--accent-primary-bg)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.btn-danger{background:var(--color-error-bg);color:var(--color-error);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444426}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-full)}.btn-sm{padding:6px 12px;font-size:.8rem;border-radius:var(--radius-sm)}.btn-lg{padding:14px 28px;font-size:1rem;border-radius:var(--radius-lg)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);transition:all var(--transition-base);box-shadow:var(--shadow-card)}.card:hover{box-shadow:var(--shadow-card-hover)}.card-flat{box-shadow:none;border:1px solid var(--border-color)}.card-flat:hover{box-shadow:none}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px)}.card-interactive:active{transform:translateY(0) scale(.99)}.input-group{display:flex;flex-direction:column;gap:6px}.input-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);font-family:var(--font-display)}.input{width:100%;padding:12px 16px;background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;transition:all var(--transition-fast);-webkit-appearance:none}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--focus-ring);background:var(--bg-card)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:100px}select.input{cursor:pointer}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-md)}@media(min-width:769px){.container{padding:0 var(--spacing-lg)}}.page{min-height:calc(100vh - var(--topbar-height));padding:var(--spacing-lg) 0}.page-header{margin-bottom:var(--spacing-xl)}.page-title{font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2rem);font-weight:800}.page-subtitle{color:var(--text-muted);font-size:.9rem;margin-top:var(--spacing-xs)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.section-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text-primary)}.section-action{font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:none;border:none;font-family:var(--font-body)}.section-action:hover{color:var(--accent-primary)}.grid{display:grid;gap:var(--spacing-lg)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.02em}.badge-primary{background:var(--accent-primary-bg);color:var(--accent-primary)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-count{min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--color-error);color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-tertiary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:#fff;flex-shrink:0;overflow:hidden}.avatar-lg{width:56px;height:56px;font-size:1.25rem}.avatar-xl{width:72px;height:72px;font-size:1.5rem}.avatar-stack{display:flex}.avatar-stack .avatar{border:2px solid var(--bg-card);margin-left:-8px}.avatar-stack .avatar:first-child{margin-left:0}.divider{height:1px;background:var(--border-color);width:100%}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md);display:block;opacity:.6}.empty-state h3{color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-size:1.1rem}.empty-state p{color:var(--text-muted);font-size:.9rem;max-width:300px;margin:0 auto}.spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.loading-center{display:flex;align-items:center;justify-content:center;min-height:200px}.skeleton{background:var(--bg-elevated);border-radius:var(--radius-md);position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);animation:skeleton-shimmer 1.5s infinite}[data-theme=dark] .skeleton:after{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.05) 50%,transparent 100%)}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:0;-webkit-tap-highlight-color:transparent}.modal-content{background:var(--bg-card);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;padding:var(--spacing-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}@media(min-width:769px){.modal-content{border-radius:var(--radius-2xl)}}.modal-handle{width:36px;height:4px;border-radius:2px;background:var(--border-color);margin:0 auto var(--spacing-lg)}.toast{position:fixed;bottom:calc(var(--bottomnav-height) + 16px);left:50%;transform:translate(-50%);background:var(--text-primary);color:var(--bg-primary);padding:12px 20px;border-radius:var(--radius-lg);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-lg);z-index:2000;max-width:calc(100vw - 32px)}@media(min-width:769px){.toast{bottom:32px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.animate-fadeIn{animation:fadeIn .4s ease-out}.avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-weight:700;font-size:.9rem;font-family:var(--font-display);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:48px;height:48px;font-size:1.1rem}.avatar-xl{width:64px;height:64px;font-size:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.88rem;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all var(--transition-fast);text-decoration:none;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-primary:hover:not(:disabled){background:var(--accent-primary-light);border-color:var(--accent-primary-light)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card);border-color:var(--accent-primary);color:var(--accent-primary)}.btn-outline{background:transparent;color:var(--accent-primary);border-color:var(--accent-primary)}.btn-outline:hover:not(:disabled){background:var(--accent-primary-bg)}.btn-danger{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover:not(:disabled){opacity:.9}.btn-info{background:var(--color-info);color:#fff;border-color:var(--color-info)}.btn-ghost{background:none;color:var(--accent-primary);border:none;padding:6px 12px}.btn-ghost:hover{background:var(--accent-primary-bg)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{padding:10px;border-radius:var(--radius-full)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.02em;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-light)}.badge-primary{background:var(--accent-primary-bg);color:var(--accent-primary);border-color:transparent}.badge-success{background:var(--color-success-bg);color:var(--color-success);border-color:transparent}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning);border-color:transparent}.badge-error{background:var(--color-error-bg);color:var(--color-error);border-color:transparent}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0}@media(min-width:769px){.modal-overlay{align-items:center;padding:var(--spacing-lg)}}.modal-overlay .modal-content{width:100%;max-width:560px;max-height:92vh;overflow-y:auto}.modal-handle{width:36px;height:4px;border-radius:2px;background:var(--border-color);margin:0 auto var(--spacing-md)}@media(min-width:769px){.modal-handle{display:none}}.spinner{width:28px;height:28px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:var(--spacing-3xl) 0}.empty-state{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg)}.empty-state-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md);opacity:.6}.empty-state h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state p{font-size:.88rem;color:var(--text-muted);line-height:1.5;max-width:320px;margin:0 auto}.toast{position:fixed;bottom:calc(var(--bottomnav-height) + var(--spacing-md));left:50%;transform:translate(-50%);padding:12px 24px;border-radius:var(--radius-full);background:var(--text-primary);color:var(--text-inverse);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-lg);z-index:2000;white-space:nowrap}@media(min-width:769px){.toast{bottom:var(--spacing-xl)}}@keyframes badge-pop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.site-footer{margin-top:var(--spacing-xl);padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-2xl);text-align:center;font-size:.75rem;line-height:1.5;color:var(--text-muted)}.site-footer p{margin:0;color:inherit;font-size:inherit}.site-footer p+p{margin-top:4px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.scroll-hidden::-webkit-scrollbar{display:none}.scroll-hidden{scrollbar-width:none}@media(max-width:768px){.hide-mobile{display:none!important}}@media(min-width:769px){.hide-desktop{display:none!important}}body[data-color-palette=ocean],body.colorblind-mode{--accent-primary: #2D5A8D;--accent-secondary: #F59E0B;--accent-tertiary: #0EA5E9;--color-success: #0EA5E9;--color-warning: #EAB308;--color-error: #FB7185;--state-positive: #0369A1;--state-positive-bg: rgba(3, 105, 161, .14);--state-negative: #BE123C;--state-negative-bg: rgba(190, 18, 60, .14)}body[data-color-palette=sunrise]{--accent-primary: #9A3412;--accent-secondary: #1D4ED8;--accent-tertiary: #EA580C;--accent-primary-light: #C2410C;--accent-primary-bg: rgba(154, 52, 18, .12);--color-success: #1D4ED8;--color-warning: #D97706;--color-error: #B91C1C;--state-positive: #1D4ED8;--state-positive-bg: rgba(29, 78, 216, .12);--state-negative: #B91C1C;--state-negative-bg: rgba(185, 28, 28, .12)}body[data-contrast=high]{--bg-primary: #FFFFFF;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-elevated: #F3F4F6;--bg-input: #FFFFFF;--bg-overlay: rgba(0, 0, 0, .72);--text-primary: #111111;--text-secondary: #202020;--text-muted: #3B3B3B;--border-color: #111111;--border-light: #4B5563;--focus-ring: 0 0 0 4px rgba(0, 95, 204, .35);--shadow-card: 0 0 0 2px rgba(17, 17, 17, .04)}[data-theme=dark] body[data-contrast=high]{--bg-primary: #050505;--bg-secondary: #111111;--bg-card: #111111;--bg-elevated: #1C1C1C;--bg-input: #121212;--text-primary: #FFFFFF;--text-secondary: #F5F5F5;--text-muted: #E5E7EB;--border-color: #FFFFFF;--border-light: #D1D5DB;--focus-ring: 0 0 0 4px rgba(255, 255, 255, .45)}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}}body[data-reduced-motion=reduce] *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@supports (padding-bottom: env(safe-area-inset-bottom)){.app-main{padding-bottom:calc(var(--bottomnav-height) + env(safe-area-inset-bottom) + 16px)}}@media print{.topbar,.bottom-nav,.toast{display:none!important}.app-main{padding-bottom:0}body{background:#fff;color:#000}}.topbar{position:sticky;top:0;z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);height:var(--topbar-height);transition:background-color var(--transition-slow)}.topbar-inner{max-width:var(--max-width);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);gap:var(--spacing-md)}@media(min-width:769px){.topbar-inner{padding:0 var(--spacing-lg)}}.topbar-brand{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:var(--text-primary);font-family:var(--font-display);font-weight:800;font-size:1.15rem;flex-shrink:0}.topbar-brand:hover{color:var(--text-primary)}.topbar-logo{font-size:1.5rem}.topbar-title{color:var(--accent-primary);font-size:clamp(.9rem,4vw,1.15rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}@media(min-width:480px){.topbar-title{max-width:none}}.topbar-nav{display:flex;align-items:center;gap:var(--spacing-xs)}.topbar-nav-link{font-size:.88rem;font-weight:600;color:var(--text-muted);padding:8px 14px;border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast)}.topbar-nav-link:hover,.topbar-nav-link.active,.topbar-nav-link[aria-current=page]{color:var(--accent-primary);background:var(--accent-primary-bg)}.topbar-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.topbar-action-btn{position:relative;width:40px;height:40px;border-radius:var(--radius-full);border:none;background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.topbar-action-btn:hover{background:var(--accent-primary-bg);color:var(--accent-primary)}.topbar-action-btn:active{transform:scale(.93)}.topbar-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-error);color:#fff;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-secondary);animation:badge-pop .3s ease-out}@keyframes badge-pop{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.topbar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-tertiary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;text-decoration:none;overflow:hidden;flex-shrink:0;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.topbar-avatar:hover{transform:scale(1.08);box-shadow:0 0 0 3px var(--accent-primary-bg)}.topbar-avatar img{width:100%;height:100%;object-fit:cover}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg-secondary);border-top:1px solid var(--border-light);display:flex;align-items:stretch;height:var(--bottomnav-height);padding-bottom:env(safe-area-inset-bottom,0px);transition:background-color var(--transition-slow)}[data-theme=light] .bottom-nav{background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}[data-theme=dark] .bottom-nav{background:#1e1e24f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--text-muted);font-size:.65rem;font-weight:600;font-family:var(--font-body);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;position:relative}.bottom-nav-tab:active{transform:scale(.92)}.bottom-nav-tab.active{color:var(--accent-primary)}.bottom-nav-tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2.5px;border-radius:0 0 2px 2px;background:var(--accent-primary);animation:tab-indicator .3s ease-out}@keyframes tab-indicator{0%{width:0;opacity:0}to{width:24px;opacity:1}}.bottom-nav-icon{position:relative;display:flex;align-items:center;justify-content:center;width:26px;height:26px}.bottom-nav-label{letter-spacing:.01em}.bottom-nav-badge{position:absolute;top:-4px;right:-8px;min-width:16px;height:16px;padding:0 4px;border-radius:var(--radius-full);background:var(--color-error);color:#fff;font-size:.55rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-secondary);animation:badge-pop .3s ease-out}.game-card{appearance:none;width:100%;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;overflow:hidden;transition:all var(--transition-base);position:relative;box-shadow:var(--shadow-card);text-align:left}.game-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--accent-primary)}.game-card-header{height:140px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.game-card-icon{font-size:3.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15));position:relative;z-index:1}.game-card-body{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);position:relative;z-index:1}.game-card-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:6px;color:var(--text-primary);line-height:1.3}.game-card-description{font-size:.82rem;color:var(--text-muted);line-height:1.5;margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.game-card-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.game-card-tag{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:var(--radius-sm);background:var(--accent-primary-bg);color:var(--accent-primary);font-weight:700}.game-card-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);font-size:.78rem;color:var(--text-muted);padding-top:var(--spacing-sm);border-top:1px solid var(--border-light);align-items:center}.game-meta-item{display:flex;align-items:center;gap:3px}.game-rating{margin-left:auto;display:inline-flex;align-items:center;padding:3px 8px;background:var(--accent-primary-bg);border-radius:var(--radius-sm);font-weight:700;font-size:.78rem;color:var(--accent-primary)}.game-rating.high{background:var(--color-success-bg);color:var(--color-success)}@media(max-width:768px){.game-card-header{height:120px}.game-card-icon{font-size:3rem}}.log-play-header{position:relative;margin-bottom:var(--spacing-lg)}.log-play-header h2{font-family:var(--font-display);font-size:1.35rem;font-weight:800;margin-bottom:var(--spacing-xs)}.log-play-game-title{font-size:.9rem;color:var(--text-muted);font-weight:500}.log-play-section{margin-bottom:var(--spacing-lg)}.log-play-section .input-label{display:block;margin-bottom:var(--spacing-sm)}.log-play-player-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.9rem;font-family:var(--font-body);color:var(--text-primary);transition:all var(--transition-fast)}.log-play-player-check{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);font-size:.75rem;font-weight:700;color:transparent;background:var(--bg-input);flex-shrink:0;transition:all var(--transition-fast)}.log-play-player-name{flex:1;font-weight:500}.log-play-player-you{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-elevated);padding:2px 8px;border-radius:var(--radius-full)}.log-play-player-locked{background:var(--accent-primary-bg);cursor:default}.log-play-player-locked .log-play-player-check{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.log-play-player-toggle{width:100%;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.log-play-player-toggle:hover{background:var(--bg-elevated)}.log-play-player-toggle.selected{background:var(--accent-primary-bg)}.log-play-player-toggle.selected .log-play-player-check{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.log-play-friends-list{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--spacing-xs)}.log-play-guest-item{background:var(--bg-elevated)}.log-play-guest-item .log-play-player-check{background:var(--accent-secondary);border-color:var(--accent-secondary);color:#fff}.log-play-guest-remove{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast);flex-shrink:0}.log-play-guest-remove:hover{background:var(--color-error-bg);color:var(--color-error)}.log-play-add-guest{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.log-play-add-guest .input{flex:1;padding:8px 12px;font-size:.85rem}.log-play-winners-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.log-play-winner-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full);border:1.5px solid var(--border-color);background:var(--bg-input);color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.log-play-winner-pill:hover{border-color:var(--color-warning);background:var(--color-warning-bg)}.log-play-winner-pill.active{border-color:var(--color-warning);background:var(--color-warning-bg);color:var(--color-warning);font-weight:600}.log-play-winner-trophy{font-size:.9rem;line-height:1}.log-play-empty{font-size:.85rem;color:var(--text-muted);padding:var(--spacing-sm) var(--spacing-md)}.log-play-error{font-size:.85rem;color:var(--color-error);background:var(--color-error-bg);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.log-play-loading{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-muted);font-size:.85rem}.log-play-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.log-play-actions .btn{flex:1}@media(max-width:400px){.log-play-actions{flex-direction:column}.log-play-actions .btn-primary{order:-1}}.game-modal .modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;padding:var(--spacing-lg);box-shadow:var(--shadow-xl)}@media(min-width:769px){.game-modal .modal-content{border-radius:var(--radius-2xl);padding:var(--spacing-xl)}}.modal-header{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.modal-icon{width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.modal-title-group{flex:1}.modal-title-group h2{font-family:var(--font-display);font-size:1.35rem;font-weight:800;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.modal-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.modal-badges .badge{background:var(--bg-elevated);color:var(--text-secondary);text-transform:capitalize;border:1px solid var(--border-light)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:8px;border-radius:var(--radius-full);transition:all var(--transition-fast);line-height:1}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary);transform:rotate(90deg)}.modal-description{font-size:.95rem;line-height:1.65;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.modal-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.modal-info-item{background:var(--bg-elevated);padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center;border:1px solid var(--border-light)}.modal-info-icon{font-size:1.3rem;display:block;margin-bottom:var(--spacing-xs)}.modal-info-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);display:block;margin-bottom:3px;font-weight:600}.modal-info-value{font-size:.95rem;font-weight:700;color:var(--text-primary);font-family:var(--font-display)}.modal-community-section{margin-bottom:var(--spacing-lg);display:grid;gap:var(--spacing-sm)}.modal-community-block{padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border-light);background:var(--bg-elevated)}.modal-community-label{display:block;margin-bottom:6px;color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.modal-community-value{color:var(--text-primary);font-weight:600}.modal-community-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.modal-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.modal-actions .btn{flex:1;min-width:140px}.modal-auth-prompt{text-align:center;width:100%;padding:var(--spacing-md);background:var(--accent-primary-bg);border-radius:var(--radius-md);color:var(--text-muted);font-size:.85rem}.modal-auth-prompt a{color:var(--accent-primary);font-weight:600}@media(max-width:480px){.game-modal .modal-content{padding:var(--spacing-md) var(--spacing-md) var(--spacing-lg)}.modal-icon{width:48px;height:48px;font-size:1.5rem}.modal-title-group h2{font-size:1.15rem}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.home-page{padding:var(--spacing-md) 0 var(--spacing-2xl)}.home-greeting{margin-bottom:var(--spacing-lg)}.greeting-content{display:flex;align-items:center;gap:var(--spacing-md)}.greeting-avatar{text-decoration:none;flex-shrink:0;transition:transform var(--transition-fast)}.greeting-avatar:hover{transform:scale(1.05)}.greeting-text{min-width:0}.greeting-title{font-family:var(--font-display);font-size:clamp(1.25rem,4vw,1.75rem);font-weight:800;color:var(--text-primary);line-height:1.2;letter-spacing:-.01em}.greeting-name{color:var(--accent-primary)}.greeting-sub{font-size:.82rem;color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-search-section{position:relative;margin-bottom:var(--spacing-xl);z-index:50}.home-search-box{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-elevated);border:1.5px solid var(--border-color);border-radius:var(--radius-xl);padding:0 var(--spacing-md);transition:all var(--transition-fast);height:50px}.home-search-box.focused{border-color:var(--accent-primary);box-shadow:var(--focus-ring);background:var(--bg-card)}.home-search-icon{flex-shrink:0;color:var(--text-muted)}.home-search-input{flex:1;border:none;background:none;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;padding:0;outline:none;min-width:0}.home-search-input::placeholder{color:var(--text-muted)}.home-search-clear{flex-shrink:0;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.home-search-clear:hover{color:var(--text-primary)}.home-search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--spacing-sm);max-height:380px;overflow-y:auto;z-index:60}.search-results-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-xs)}.search-result-item{display:flex;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);width:100%;border:none;background:none;text-align:left;font-family:var(--font-body);color:var(--text-primary)}.search-result-item:hover{background:var(--bg-elevated)}.search-result-icon{font-size:1.5rem;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius-md)}.search-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.search-result-title{font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-meta{font-size:.75rem;color:var(--text-muted)}.search-result-rating{font-size:.78rem;color:var(--accent-secondary);font-weight:600;flex-shrink:0}.search-results-empty{text-align:center;padding:var(--spacing-xl) var(--spacing-md);color:var(--text-muted)}.search-results-empty span{font-size:2rem;display:block;margin-bottom:var(--spacing-sm);opacity:.5}.search-results-empty p{font-size:.85rem;color:var(--text-muted)}.home-featured{margin-bottom:var(--spacing-xl)}.featured-carousel{display:flex;gap:var(--spacing-md);overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:var(--spacing-xs) 0 var(--spacing-sm);-webkit-overflow-scrolling:touch}.featured-card{flex:0 0 280px;scroll-snap-align:center;border-radius:var(--radius-xl);overflow:hidden;position:relative;cursor:pointer;border:none;text-align:left;font-family:var(--font-body);color:#fff;transition:transform var(--transition-fast);height:160px;display:flex;flex-direction:column;-webkit-tap-highlight-color:transparent}.featured-card:hover{transform:translateY(-2px)}@media(max-width:768px){.featured-card{flex:0 0 calc(100vw - 48px)}}.featured-card-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--card-color, var(--accent-primary)) 0%,color-mix(in srgb,var(--card-color, var(--accent-primary)),black 30%) 100%);display:flex;align-items:center;justify-content:flex-end;padding-right:var(--spacing-lg)}@supports not (color: color-mix(in srgb,red,blue)){.featured-card-bg{background:var(--card-color, var(--accent-primary))}}.featured-card-icon{font-size:4rem;opacity:.25}.featured-card-content{position:relative;z-index:1;padding:var(--spacing-lg);margin-top:auto}.featured-card-title{font-family:var(--font-display);font-size:1.15rem;font-weight:800;color:#fff;margin-bottom:4px;text-shadow:0 1px 3px rgba(0,0,0,.3)}.featured-card-meta{font-size:.78rem;color:#fffc}.featured-card-arrow{position:absolute;bottom:var(--spacing-lg);right:var(--spacing-lg);width:32px;height:32px;border-radius:var(--radius-full);background:#fff3;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;z-index:1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.featured-dots{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:var(--spacing-md)}.featured-dot{width:6px;height:6px;border-radius:var(--radius-full);background:var(--border-color);border:none;cursor:pointer;padding:0;transition:all var(--transition-fast)}.featured-dot.active{width:20px;background:var(--accent-primary)}.home-dashboard{margin-bottom:var(--spacing-xl)}.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}@media(max-width:400px){.dashboard-grid{gap:var(--spacing-sm)}}.dashboard-action{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);text-decoration:none;padding:var(--spacing-md) var(--spacing-sm);border-radius:var(--radius-xl);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.dashboard-action:hover{background:var(--bg-elevated)}.dashboard-action:active{transform:scale(.93)}.dashboard-action-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:all var(--transition-fast);box-shadow:var(--shadow-xs);border:1px solid var(--border-light)}.dashboard-action:hover .dashboard-action-icon{background:var(--accent-primary-bg);border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.dashboard-action-label{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-align:center;font-family:var(--font-display);letter-spacing:.01em}.home-events{margin-bottom:var(--spacing-lg)}.events-preview-scroll{display:flex;gap:var(--spacing-md);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:var(--spacing-xs) 0}.event-preview-card{flex:0 0 170px;scroll-snap-align:start;border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;border:1px solid var(--border-color);background:var(--bg-card);transition:all var(--transition-fast);text-align:left;font-family:var(--font-body);display:flex;flex-direction:column;-webkit-tap-highlight-color:transparent}.event-preview-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.event-preview-card:active{transform:scale(.98)}.event-preview-top{height:90px;background:linear-gradient(135deg,var(--event-color, var(--accent-primary)),color-mix(in srgb,var(--event-color, var(--accent-primary)),black 20%));display:flex;align-items:center;justify-content:center;font-size:2.5rem;position:relative}@supports not (color: color-mix(in srgb,red,blue)){.event-preview-top{background:var(--event-color, var(--accent-primary))}}.event-preview-emoji{opacity:.5}.event-preview-bottom{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md)}.event-preview-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--accent-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-preview-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:4px}.event-preview-attendees,.event-preview-date{font-size:.72rem;color:var(--text-muted);font-weight:600}@media(min-width:769px){.home-page{padding:var(--spacing-xl) 0 var(--spacing-3xl)}.greeting-content{gap:var(--spacing-lg)}.greeting-title{font-size:2rem}.featured-card{flex:0 0 320px;height:180px}.dashboard-grid{max-width:480px}.event-preview-card{flex:0 0 200px}}@media(min-width:1024px){.home-page .container{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.home-greeting,.home-search-section,.home-featured{grid-column:1 / -1}.home-dashboard{grid-column:1}.home-events{grid-column:2}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.auth-container{width:100%;max-width:420px;background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-logo{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.auth-header h1{font-size:1.75rem;margin-bottom:var(--spacing-sm);background:none;-webkit-text-fill-color:currentColor;color:var(--text-primary)}.auth-header p{color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-error{padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--accent-error);font-size:.9rem;text-align:center}.auth-btn{width:100%;height:50px;margin-top:var(--spacing-sm)}.auth-google,.auth-social{gap:var(--spacing-sm)}.auth-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--text-muted);font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-footer{text-align:center;margin-top:var(--spacing-lg);color:var(--text-muted);font-size:.9rem}.auth-footer a{color:var(--accent-primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:480px){.auth-container{padding:var(--spacing-xl);border-radius:var(--radius-lg)}.auth-page{padding:var(--spacing-md)}}.report-modal{width:100%;max-width:560px;max-height:90vh;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-xl)}.report-modal h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.report-modal-context{color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.5}.report-modal-section{margin-bottom:var(--spacing-lg)}.report-modal-section label{display:block;margin-bottom:var(--spacing-sm);font-size:.82rem;font-weight:600;color:var(--text-secondary)}.report-reason-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.report-reason-btn{border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);border-radius:var(--radius-full);padding:10px 14px;cursor:pointer;transition:all var(--transition-fast)}.report-reason-btn.active{border-color:var(--accent-primary);background:var(--accent-primary-bg);color:var(--accent-primary)}.report-modal-note{border:1px solid var(--border-color);background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-md);color:var(--text-muted);font-size:.82rem;line-height:1.5}.report-modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}@media(max-width:640px){.report-modal{padding:var(--spacing-lg)}.report-modal-actions{flex-direction:column}}.profile-page{padding:var(--spacing-xl) 0 100px}.profile-loading{min-height:80vh;display:flex;align-items:center;justify-content:center}.profile-container{max-width:700px;margin:0 auto}.profile-setup-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--accent-primary-bg);border:1px solid var(--accent-primary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl)}.profile-setup-banner span{font-size:2rem}.profile-setup-banner h3{color:var(--text-primary);margin-bottom:4px}.profile-setup-banner p{font-size:.9rem}.profile-header{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg)}.profile-avatar-large{width:100px;height:100px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff;flex-shrink:0}.profile-avatar-stack{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.profile-meeps-link{font-size:.82rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--accent-primary);padding:4px 12px;border-radius:var(--radius-full);border:1px solid var(--accent-primary);background:var(--accent-primary-bg);transition:all var(--transition-fast)}.profile-meeps-link:hover{color:#fff;border-color:var(--accent-primary);background:var(--accent-primary)}.profile-avatar-large img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.profile-info{flex:1}.profile-info h2{font-size:1.75rem;margin-bottom:var(--spacing-xs);display:inline-flex;align-items:center;gap:var(--spacing-sm)}.profile-admin-trigger{border:none;background:transparent;cursor:pointer;font-size:1rem;line-height:1;padding:2px 6px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.profile-admin-trigger:hover{background:var(--accent-primary-bg)}.profile-name-input{font-size:1.5rem;font-weight:700;padding:var(--spacing-sm) var(--spacing-md)}.profile-email{color:var(--text-muted);font-size:.9rem}.profile-platform-id{color:var(--text-muted);font-size:.75rem;margin-top:2px}.profile-identity-line{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.profile-chip{display:inline-flex;align-items:center;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);padding:5px 10px;font-size:.76rem;font-weight:600}.profile-view-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.profile-viewing-tag{cursor:default}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.profile-stat{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center}.profile-stat-value{display:block;font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-stat-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.profile-section{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.profile-section h3{font-size:1.25rem;margin-bottom:var(--spacing-lg);color:var(--accent-primary)}.profile-section-spaced{margin-top:var(--spacing-lg)}.profile-section-intro{margin-top:calc(var(--spacing-lg) * -1 + 4px);margin-bottom:var(--spacing-lg);color:var(--text-secondary);line-height:1.5}.profile-identity-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md)}.profile-inline-input{margin-top:var(--spacing-sm)}.profile-detail-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md)}.profile-detail-value{display:block;color:var(--text-primary);font-weight:700;margin-bottom:4px}.profile-detail-label{display:block;color:var(--text-muted);font-size:.78rem}.preference-group{margin-bottom:var(--spacing-xl)}.preference-group:last-child{margin-bottom:0}.preference-label{display:block;font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.preference-options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.preference-option{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.preference-option:hover:not(.disabled){border-color:var(--accent-primary);background:var(--accent-primary-bg)}.preference-option.active{border-color:var(--accent-primary);background:var(--accent-primary-bg)}.preference-option.disabled{cursor:default;opacity:.7}.preference-option-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:4px}.preference-option-desc{display:block;font-size:.75rem;color:var(--text-muted)}@media(max-width:640px){.profile-header{flex-direction:column;align-items:flex-start}.profile-stats,.profile-identity-grid,.preference-options{grid-template-columns:1fr}.settings-chip-group{flex-direction:column}}.style-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.style-tag{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.style-tag:hover:not(.disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.style-tag.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.style-tag.disabled{cursor:default}.profile-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl)}@media(max-width:768px){.profile-header{flex-direction:column;text-align:center}.profile-info{width:100%}.profile-view-actions{justify-content:center}.preference-options{grid-template-columns:1fr}.settings-row{align-items:flex-start;flex-direction:column}.profile-stats{grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.profile-stat{padding:var(--spacing-md)}.profile-stat-value{font-size:1.5rem}}.profile-settings-section{margin-top:var(--spacing-lg)}.profile-settings-section h3{margin-bottom:var(--spacing-lg)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-light);gap:var(--spacing-md)}.settings-row:last-child{border-bottom:none}.settings-row-stack{align-items:flex-start;flex-direction:column}.settings-row-info{display:flex;align-items:center;gap:var(--spacing-md)}.settings-row-icon{font-size:1.4rem;width:36px;text-align:center}.settings-row-label{display:block;font-weight:600;font-size:.92rem;color:var(--text-primary)}.settings-row-desc{display:block;font-size:.78rem;color:var(--text-muted);margin-top:2px}.settings-chip-group{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);width:100%}.settings-chip{display:inline-flex;flex-direction:column;gap:4px;min-width:140px;padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);color:var(--text-secondary);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.settings-chip:hover{border-color:var(--accent-primary);color:var(--text-primary)}.settings-chip.active{border-color:var(--accent-primary);background:var(--accent-primary-bg);color:var(--accent-primary)}.settings-chip small{color:inherit;font-size:.72rem}.settings-chip-inline{min-width:0;justify-content:center;text-align:center}.theme-toggle-switch{position:relative;width:52px;height:28px;border-radius:14px;border:none;cursor:pointer;transition:background var(--transition-base);padding:0;flex-shrink:0;-webkit-tap-highlight-color:transparent}.theme-toggle-switch.light{background:var(--border-color)}.theme-toggle-switch.dark{background:var(--accent-primary)}.theme-toggle-knob{position:absolute;top:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0003;transition:transform var(--transition-base)}.theme-toggle-switch.light .theme-toggle-knob{transform:translate(3px)}.theme-toggle-switch.dark .theme-toggle-knob{transform:translate(27px)}.events-page{padding:var(--spacing-lg) 0 100px}.events-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.events-invite-context{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);margin-bottom:var(--spacing-lg)}.events-invite-context p{color:var(--text-primary);line-height:1.4}.events-invite-context small{color:var(--text-muted)}.events-auth-prompt{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--accent-primary-bg);border:1px solid var(--accent-primary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl)}.events-auth-prompt span{font-size:1.5rem}.events-auth-prompt a{color:var(--accent-primary);font-weight:600}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--spacing-lg)}.event-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);transition:all var(--transition-base)}.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover);border-color:var(--accent-primary)}.event-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.event-date{font-size:.85rem;color:var(--accent-primary);font-weight:600}.event-visibility{font-size:.72rem;padding:3px 10px;border-radius:var(--radius-full);background:var(--accent-primary-bg);border:1px solid var(--border-light);color:var(--text-secondary);font-weight:600}.event-visibility.private{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.event-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.event-description{font-size:.88rem;color:var(--text-muted);margin-bottom:var(--spacing-md);line-height:1.5}.event-meta{display:flex;flex-direction:column;gap:4px;font-size:.82rem;color:var(--text-secondary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.event-safety-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.event-safety-badge,.event-safety-status{font-size:.72rem;padding:5px 10px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);font-weight:600}.event-safety-status.verified{border-color:var(--color-success);background:var(--color-success-bg);color:var(--color-success)}.event-safety-status.pending{border-color:var(--color-warning);background:var(--color-warning-bg);color:var(--color-warning)}.event-attendees{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.attendees-label{font-size:.88rem;font-weight:600;color:var(--text-secondary)}.attendees-avatars{display:flex}.attendee-avatar{width:30px;height:30px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-tertiary));display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;border:2px solid var(--bg-card);margin-left:-8px}.attendee-avatar:first-child{margin-left:0}.attendee-avatar.more{background:var(--bg-elevated);color:var(--text-muted);font-size:.65rem}.event-moods{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.mood-tag{font-size:.72rem;padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--border-color);color:var(--text-secondary);background:var(--bg-elevated);font-weight:500}.mood-tag-competitive{background:var(--color-info-bg);border-color:var(--color-info);color:var(--color-info)}.mood-tag-casual{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.mood-tag-social{background:#a855f71a;border-color:#a855f766;color:#a855f7}.mood-tag-tryNewGames{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.event-card-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.event-rsvp-btn{width:100%}.event-host-actions{display:flex;justify-content:flex-end;gap:var(--spacing-xs)}.event-form-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-2xl);width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-xl)}@media(min-width:769px){.event-form-modal{border-radius:var(--radius-xl);padding:var(--spacing-xl)}}.event-form-modal h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700;text-align:center;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.form-row{display:flex;gap:var(--spacing-md)}.form-group-half{flex:1}.input{width:100%;padding:10px 14px;border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;transition:border-color var(--transition-fast);outline:none}.input:focus{border-color:var(--accent-primary);box-shadow:var(--focus-ring)}.textarea{resize:vertical;min-height:72px}.visibility-picker{display:flex;gap:var(--spacing-sm)}.visibility-option{flex:1;padding:10px;border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-input);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;text-align:center;transition:all var(--transition-fast);font-family:var(--font-body)}.visibility-option.active{border-color:var(--accent-primary);background:var(--accent-primary-bg);color:var(--accent-primary);font-weight:600}.event-form-help{font-size:.78rem;color:var(--text-muted);margin-top:-4px;margin-bottom:var(--spacing-sm)}.event-badge-picker{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.event-badge-option{border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-secondary);border-radius:var(--radius-full);padding:10px 14px;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.event-badge-option.active{border-color:var(--accent-primary);background:var(--accent-primary-bg);color:var(--accent-primary)}.event-form-badge-status{margin-top:var(--spacing-sm);font-size:.78rem;color:var(--text-muted)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.form-actions .btn{flex:1}.rsvp-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-2xl);width:100%;max-width:450px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-xl)}@media(min-width:769px){.rsvp-modal{border-radius:var(--radius-xl);padding:var(--spacing-xl)}}.rsvp-modal h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center;color:var(--text-primary)}.rsvp-section{margin-bottom:var(--spacing-lg)}.rsvp-section label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.rsvp-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.rsvp-options.mood-options{display:grid;grid-template-columns:repeat(2,1fr)}.rsvp-option{flex:1;min-width:80px;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast);text-align:center;font-family:var(--font-body)}.rsvp-option:hover{border-color:var(--accent-primary)}.rsvp-option.active{background:var(--accent-primary-bg);border-color:var(--accent-primary);color:var(--accent-primary);font-weight:700}.status-option.status-going.active{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.status-option.status-maybe.active{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.status-option.status-declined.active{background:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.mood-option.mood-competitive{border-left:3px solid var(--color-info)}.mood-option.mood-casual{border-left:3px solid var(--color-warning)}.mood-option.mood-social{border-left:3px solid #a855f7}.mood-option.mood-tryNewGames{border-left:3px solid var(--color-success)}.rsvp-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.rsvp-actions .btn{flex:1}.confirm-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:380px;text-align:center;box-shadow:var(--shadow-xl)}.confirm-icon{font-size:2.5rem;display:block;margin-bottom:var(--spacing-md)}.confirm-modal h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.confirm-modal p{font-size:.88rem;color:var(--text-muted);line-height:1.5;margin-bottom:var(--spacing-lg)}.confirm-actions{display:flex;gap:var(--spacing-md)}.confirm-actions .btn{flex:1}@media(max-width:768px){.events-header,.events-invite-context{flex-direction:column;align-items:flex-start}.events-grid,.rsvp-options.mood-options{grid-template-columns:1fr}.form-row{flex-direction:column}}.match-page{padding:var(--spacing-xl) 0 100px;min-height:100vh}.match-header{text-align:center;margin-bottom:var(--spacing-lg)}.match-header p{color:var(--text-muted);margin-top:var(--spacing-sm)}.match-auth-prompt{text-align:center;padding:var(--spacing-2xl);background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:400px;margin:var(--spacing-2xl) auto}.match-auth-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-md)}.match-progress{width:100%;max-width:400px;height:4px;background:var(--border-color);border-radius:var(--radius-full);margin:0 auto var(--spacing-xl);overflow:hidden}.match-friend-banner{margin:0 auto var(--spacing-lg);max-width:760px;padding:var(--spacing-md);border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.match-friend-banner h3{font-size:1rem;margin-bottom:2px}.match-friend-banner p{font-size:.85rem;color:var(--text-muted)}.match-friend-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.match-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-full);transition:width .3s ease}.swipe-container{display:flex;justify-content:center;align-items:center;min-height:450px;perspective:1000px}.swipe-card{width:100%;max-width:340px;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;cursor:grab;position:relative;touch-action:pan-y}.swipe-card:active{cursor:grabbing}.swipe-indicator{position:absolute;top:20px;padding:8px 16px;border-radius:var(--radius-md);font-size:1.25rem;font-weight:800;z-index:10;border:3px solid}.swipe-indicator.like{right:20px;color:var(--state-positive);border-color:var(--state-positive);border-style:double;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.2) 0 2px,transparent 2px),var(--state-positive-bg)}.swipe-indicator.nope{left:20px;color:var(--state-negative);border-color:var(--state-negative);border-style:dashed;background:repeating-linear-gradient(135deg,var(--state-negative-bg) 0 8px,rgba(255,255,255,.06) 8px 16px)}.swipe-card-image{height:200px;display:flex;align-items:center;justify-content:center;position:relative}.swipe-card-icon{font-size:5rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.swipe-card-content{padding:var(--spacing-lg)}.swipe-card-content h3{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.swipe-card-description{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.swipe-card-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.swipe-tag{font-size:.75rem;text-transform:capitalize;padding:4px 10px;border-radius:var(--radius-full);background:#6366f126;color:var(--accent-primary);font-weight:600}.swipe-card-meta{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-secondary);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.swipe-buttons{display:flex;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-xl);flex-wrap:wrap}.swipe-btn{width:110px;min-height:84px;border-radius:var(--radius-lg);border:none;font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-weight:700}.swipe-btn:hover{transform:scale(1.1)}.swipe-btn:active{transform:scale(.95)}.swipe-btn-symbol{font-size:1.8rem;line-height:1}.swipe-btn-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em}.swipe-btn-no{background:repeating-linear-gradient(135deg,var(--state-negative-bg) 0 8px,rgba(255,255,255,.06) 8px 16px);color:var(--state-negative);border:2px dashed var(--state-negative)}.swipe-btn-yes{background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.2) 0 2px,transparent 2px),var(--state-positive-bg);color:var(--state-positive);border:3px double var(--state-positive)}.swipe-instructions{text-align:center;margin-top:var(--spacing-md);color:var(--text-secondary);font-size:.9rem}.match-counter{text-align:center;margin-top:var(--spacing-lg);color:var(--text-muted);font-size:.9rem}.match-results,.match-completion{text-align:center;max-width:600px;margin:0 auto;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-glow)}.completion-icon{font-size:5rem;display:block;margin-bottom:var(--spacing-lg)}.funny-message{font-size:1.25rem;font-weight:700;color:var(--accent-primary);margin-bottom:var(--spacing-xl);font-style:italic}.match-stats-summary{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.matches-preview-completion{background:#6366f11a;padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl)}.social-matches-container{margin-top:var(--spacing-2xl);padding-bottom:var(--spacing-2xl)}.social-matches-subtitle{color:var(--text-muted);margin-bottom:var(--spacing-lg)}.matches-table-wrapper{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.matches-table{width:100%;border-collapse:collapse}.matches-table th{text-align:left;padding:var(--spacing-md);background:#0003;color:var(--text-muted);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.matches-table td{padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.match-row-highlight td{background:#6366f124}.match-user-cell{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600}.match-avatar{width:32px;height:32px;background:var(--accent-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem}.compatibility-badge{display:inline-block;padding:4px 12px;background:var(--state-positive-bg);border:1px solid var(--state-positive);color:var(--text-primary);border-radius:var(--radius-full);font-size:.85rem;font-weight:700}.shared-icons{display:flex;gap:var(--spacing-xs);font-size:1.25rem}.match-actions{display:flex;gap:var(--spacing-sm)}.btn-icon-text{background:var(--bg-body);border:1px solid var(--accent-primary);color:var(--accent-primary);padding:6px 12px;border-radius:var(--radius-md);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.btn-icon-text:hover{background:var(--accent-primary);color:#fff}.btn-icon-text.secondary{border-color:var(--border-color);color:var(--text-secondary)}.btn-icon-text.secondary:hover{background:var(--bg-secondary);border-color:var(--text-muted)}@media(max-width:768px){.match-friend-banner{flex-direction:column;align-items:flex-start}.matches-table th:nth-child(3),.matches-table td:nth-child(3){display:none}}@media(max-width:480px){.swipe-card{max-width:100%}}.connections-page{padding:var(--spacing-xl) 0 100px}.connections-header{margin-bottom:var(--spacing-lg)}.connections-subtitle{color:var(--text-muted);margin-top:var(--spacing-sm)}.connections-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:var(--spacing-lg);align-items:start}.connections-main,.connections-sidebar{min-width:0}.friend-id-card{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.friend-id-label{margin-bottom:4px;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.friend-id-value{display:inline-block;font-size:.85rem;color:var(--text-primary);word-break:break-all}.connections-auth-prompt{text-align:center;padding:var(--spacing-2xl);background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:400px;margin:var(--spacing-2xl) auto}.connections-auth-prompt span{font-size:4rem;display:block;margin-bottom:var(--spacing-md)}.connections-search{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.connections-search .input{flex:1}.connections-feedback{color:var(--text-muted);margin-bottom:var(--spacing-md);font-size:.88rem}.search-results{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.search-results h3{font-size:.9rem;color:var(--text-muted);margin-bottom:var(--spacing-md)}.search-results-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.search-result-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-md)}.search-result-item:hover{background:#6366f11a}.search-result-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff}.search-result-info{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-name{font-weight:600}.search-result-id{font-size:.75rem;color:var(--text-muted)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:.85rem}.connections-section-title{font-size:1rem;color:var(--text-muted);margin-bottom:var(--spacing-lg)}.connections-loading{display:flex;justify-content:center;padding:var(--spacing-2xl)}.connections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.connection-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);transition:all var(--transition-slow)}.connection-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-glow),var(--shadow-lg);border-color:var(--border-hover)}.connection-avatar{width:60px;height:60px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:var(--spacing-md)}.connection-avatar img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.connection-info h4{font-size:1.1rem;margin-bottom:var(--spacing-xs)}.connection-platform-id{font-size:.75rem;color:var(--text-muted);margin-bottom:2px}.connection-stats-summary{font-size:.85rem;color:var(--text-muted);margin-bottom:var(--spacing-md)}.connection-head-to-head{margin-bottom:var(--spacing-md)}.h2h-bar{height:8px;background:#ef44444d;border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-xs)}.h2h-you{height:100%;background:linear-gradient(90deg,var(--accent-success),var(--accent-primary));border-radius:var(--radius-full)}.h2h-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}.connection-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.connection-action-link{flex:1;text-align:center}.connections-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted)}.connections-empty span{font-size:4rem;display:block;margin-bottom:var(--spacing-md);opacity:.5}.invites-panel{position:sticky;top:100px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg)}.invites-panel h3{font-size:1rem;margin-bottom:var(--spacing-xs)}.invites-subtitle{color:var(--text-muted);font-size:.85rem;margin-bottom:var(--spacing-md)}.invites-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.invite-item{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm);background:#ffffff05}.invite-user{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.invite-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff}.invite-name{color:var(--text-primary);font-weight:600;line-height:1.2}.invite-id{font-size:.74rem;color:var(--text-muted)}.invite-links{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:.78rem}.invite-actions{display:flex;gap:var(--spacing-sm)}.invite-actions .btn{flex:1}.invites-empty{text-align:center;color:var(--text-muted);padding:var(--spacing-xl) var(--spacing-sm)}.invites-empty span{display:block;font-size:2rem;margin-bottom:var(--spacing-sm)}@media(max-width:1024px){.connections-layout{grid-template-columns:1fr}.invites-panel{position:static}}@media(max-width:768px){.friend-id-card{flex-direction:column;align-items:flex-start}.connections-search,.connections-grid{grid-template-columns:1fr}.connection-actions{flex-direction:column}}.wrapped-showcase{margin-top:var(--spacing-xl);padding:var(--spacing-xl);border-radius:var(--radius-xl);border:1px solid rgba(251,113,133,.25);background:radial-gradient(circle at 10% 10%,rgba(249,115,22,.14),transparent 48%),radial-gradient(circle at 88% 8%,rgba(34,211,238,.16),transparent 40%),linear-gradient(145deg,#090c1cf5,#11162be6);box-shadow:0 28px 70px #00000059;overflow:hidden}.wrapped-showcase-header{margin-bottom:var(--spacing-lg)}.wrapped-overline{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:#fda4af;font-weight:700;margin-bottom:6px}.wrapped-showcase h3{margin-bottom:var(--spacing-sm);font-size:clamp(1.4rem,2.6vw,2rem);color:#f8fafc;background:linear-gradient(120deg,#fb7185,#f97316,#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.wrapped-showcase-header p{color:#dbeafe;max-width:760px}.wrapped-player-picker{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.wrapped-player-chip{border:1px solid rgba(148,163,184,.35);background:#0f172aa6;color:#e2e8f0;border-radius:var(--radius-full);padding:8px 14px;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.wrapped-player-chip.is-active{background:linear-gradient(120deg,#f973163d,#3b82f63d);border-color:#fbbf2480;color:#fff}.wrapped-stage{position:relative;border-radius:24px;padding:18px;border:1px solid rgba(148,163,184,.2);background:#060a18d6;overflow:hidden}.wrapped-stage-glow{position:absolute;width:360px;height:360px;border-radius:50%;filter:blur(60px);pointer-events:none}.wrapped-stage-glow-a{top:-180px;left:-120px;background:#f973163d}.wrapped-stage-glow-b{right:-140px;bottom:-220px;background:#22d3ee38}.wrapped-progress{position:relative;z-index:2;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:var(--spacing-md)}.wrapped-progress-segment{height:8px;border-radius:999px;border:none;padding:0;background:#64748b52;overflow:hidden;cursor:pointer}.wrapped-progress-segment.is-current{box-shadow:0 0 0 1px #f8fafc59}.wrapped-progress-fill{display:block;width:100%;height:100%;transform-origin:left center;background:linear-gradient(90deg,#fb7185,#f97316,#22d3ee)}.wrapped-stage-meta{position:relative;z-index:2;display:flex;justify-content:space-between;gap:var(--spacing-sm);color:#cbd5e1;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600;margin-bottom:var(--spacing-md)}.wrapped-scene-shell{position:relative;z-index:2;min-height:330px;border-radius:20px;border:1px solid rgba(148,163,184,.2);background:linear-gradient(160deg,#020617db,#0f172abf),radial-gradient(circle at 8% 25%,rgba(56,189,248,.18),transparent 42%);padding:20px;overflow:hidden}.wrapped-scene{height:100%}.wrapped-scene-title,.wrapped-scene-heading,.wrapped-signature-moment{color:#f8fafc}.wrapped-scene-title{font-size:clamp(2rem,4.6vw,3.4rem);letter-spacing:-.02em;margin-bottom:var(--spacing-sm);line-height:1.05}.wrapped-year-pill{display:inline-block;margin:0 10px;padding:2px 10px;border-radius:999px;color:#020617;background:linear-gradient(120deg,#f59e0b,#fde68a);transform-origin:left center}.wrapped-avatar-badge{width:62px;height:62px;border-radius:50%;border:1px solid rgba(248,250,252,.25);display:flex;align-items:center;justify-content:center;font-size:1.85rem;margin-bottom:var(--spacing-md);background:#0f172a8c}.wrapped-kicker{text-transform:uppercase;letter-spacing:.16em;color:#fb7185;font-size:.72rem;font-weight:700;margin-bottom:var(--spacing-sm)}.wrapped-handle{color:#93c5fd;font-weight:600;margin-bottom:6px}.wrapped-typewriter{font-size:1.05rem;color:#e2e8f0;min-height:1.8rem;margin-bottom:var(--spacing-md);font-weight:500}.wrapped-intro-chips{display:flex;flex-wrap:wrap;gap:8px}.wrapped-intro-chips span{border:1px solid rgba(148,163,184,.3);background:#0f172a85;border-radius:999px;padding:6px 12px;color:#e2e8f0;font-size:.82rem}.wrapped-scene-heading{font-size:1.45rem;margin-bottom:var(--spacing-md)}.wrapped-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-sm)}.wrapped-stat-tile{background:#0f172a94;border:1px solid rgba(148,163,184,.22);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:4px}.wrapped-stat-icon{font-size:1.2rem}.wrapped-stat-value{font-size:1.75rem;font-weight:800;color:#fff;line-height:1.1}.wrapped-stat-label{color:#cbd5e1;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.wrapped-scene-footnote{margin-top:var(--spacing-md);color:#fdba74;font-size:.9rem;font-weight:600}.wrapped-bars{display:flex;flex-direction:column;gap:10px}.wrapped-bar-row{display:grid;grid-template-columns:minmax(130px,1fr) minmax(120px,2fr) auto;gap:10px;align-items:center}.wrapped-bar-label{display:flex;align-items:center;gap:8px;color:#f8fafc;font-weight:600}.wrapped-bar-icon{font-size:1.1rem}.wrapped-bar-track{height:10px;border-radius:999px;background:#94a3b838;overflow:hidden}.wrapped-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#f97316,#fb7185,#22d3ee)}.wrapped-bar-value{font-size:.82rem;color:#cbd5e1;min-width:64px;text-align:right}.wrapped-genre-layout{display:grid;grid-template-columns:210px 1fr;gap:var(--spacing-lg);align-items:center}.wrapped-genre-ring{width:200px;height:200px;border-radius:50%;margin:0 auto;display:grid;place-items:center;box-shadow:0 16px 30px #02061773}.wrapped-genre-core{width:122px;height:122px;border-radius:50%;display:grid;place-items:center;background:#020617eb;border:1px solid rgba(148,163,184,.2);color:#e2e8f0;font-size:.76rem;text-transform:uppercase;letter-spacing:.09em;text-align:center;font-weight:700}.wrapped-genre-legend{display:flex;flex-direction:column;gap:10px}.wrapped-genre-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;background:#0f172a7a;border:1px solid rgba(148,163,184,.2);border-radius:10px;padding:9px 10px}.wrapped-genre-dot{width:10px;height:10px;border-radius:50%}.wrapped-genre-name{color:#e2e8f0;font-weight:500}.wrapped-genre-percent{color:#f8fafc;font-weight:700}.wrapped-signature-moment{font-size:1.05rem;line-height:1.4;margin-bottom:var(--spacing-md);max-width:720px}.wrapped-highlights{display:flex;flex-direction:column;gap:10px}.wrapped-highlight{display:inline-flex;gap:8px;align-items:flex-start;background:#0f172a8f;border:1px solid rgba(148,163,184,.2);border-radius:10px;padding:10px 12px;color:#e2e8f0}.wrapped-finale-tag{margin-top:var(--spacing-md);display:inline-flex;border-radius:999px;padding:8px 14px;font-size:.8rem;font-weight:600;color:#fde68a;border:1px solid rgba(251,191,36,.35);background:#78350f3d}.wrapped-controls{position:relative;z-index:2;margin-top:var(--spacing-md);display:flex;justify-content:flex-end;gap:8px}.wrapped-controls button{border-radius:999px;border:1px solid rgba(148,163,184,.3);background:#0f172a9e;color:#e2e8f0;padding:8px 14px;font-size:.82rem;font-weight:600;cursor:pointer}.wrapped-controls button:hover{border-color:#fbbf2473;color:#fff}.wrapped-template-note{margin-top:var(--spacing-md);color:#cbd5e1;font-size:.85rem}@media(max-width:900px){.wrapped-showcase{padding:var(--spacing-lg)}.wrapped-genre-layout{grid-template-columns:1fr}.wrapped-genre-ring{width:180px;height:180px}.wrapped-genre-core{width:108px;height:108px}.wrapped-bar-row{grid-template-columns:1fr;gap:6px}.wrapped-bar-value{text-align:left}}@media(max-width:640px){.wrapped-scene-shell{min-height:390px;padding:14px}.wrapped-stat-grid{grid-template-columns:1fr}.wrapped-controls{justify-content:stretch}.wrapped-controls button{flex:1;text-align:center}}.stats-page{padding:var(--spacing-xl) 0 100px}.stats-header{margin-bottom:var(--spacing-xl)}.stats-subtitle{color:var(--text-muted);margin-top:var(--spacing-sm)}.stats-auth-prompt{text-align:center;padding:var(--spacing-2xl);background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:400px;margin:var(--spacing-2xl) auto}.stats-auth-prompt span{font-size:4rem;display:block;margin-bottom:var(--spacing-md)}.stats-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);text-align:center;transition:all var(--transition-slow)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-glow),var(--shadow-lg)}.stat-icon{font-size:2rem;display:block;margin-bottom:var(--spacing-sm)}.stat-value{display:block;font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stats-section{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.stats-section h3{font-size:1.1rem;margin-bottom:var(--spacing-lg);color:var(--accent-primary)}.stats-fun-facts{grid-column:1 / -1}.top-games-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.top-game-item{display:flex;align-items:center;gap:var(--spacing-md)}.top-game-rank{width:28px;height:28px;border-radius:var(--radius-full);background:#6366f133;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--accent-primary)}.top-game-icon{font-size:1.5rem}.top-game-info{flex:1}.top-game-name{display:block;font-weight:600;font-size:.95rem}.top-game-stats{font-size:.8rem;color:var(--text-muted)}.top-game-bar{width:60px;height:6px;background:#94a3b859;border:1px solid rgba(148,163,184,.45);border-radius:var(--radius-full);overflow:hidden}.top-game-bar-fill{height:100%;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.2) 0 2px,transparent 2px),var(--state-positive-bg);border-right:1px solid var(--state-positive);border-radius:var(--radius-full)}.style-breakdown{display:flex;flex-direction:column;gap:var(--spacing-md)}.style-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.style-header{display:flex;justify-content:space-between;font-size:.9rem}.style-name{font-weight:500}.style-percentage{color:var(--accent-primary);font-weight:600}.style-bar{height:8px;background:var(--bg-secondary);border:1px solid rgba(148,163,184,.28);border-radius:var(--radius-full);overflow:hidden}.style-bar-fill{height:100%;background:repeating-linear-gradient(45deg,#ffffff14 0 6px,#fff0 6px 12px),linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-full)}.recent-sessions-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.recent-session-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background:#6366f10d;border-radius:var(--radius-md);border:1px solid var(--border-color)}.session-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-sm)}.session-info{display:flex;flex-direction:column;flex:1}.session-name{font-weight:600;color:var(--text-primary);font-size:.95rem}.session-date{font-size:.8rem;color:var(--text-muted)}.win-badge{background:var(--state-positive-bg);color:var(--state-positive);padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600;border:1px double var(--state-positive)}.table-container{overflow-x:auto}.stats-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-sm)}.stats-table th{text-align:left;padding:var(--spacing-sm);border-bottom:1px solid var(--border-color);color:var(--text-muted);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.stats-table td{padding:var(--spacing-md) var(--spacing-sm);border-bottom:1px solid var(--border-color);color:var(--text-primary)}.table-game-info{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500}.table-icon{font-size:1.2rem}.btn-text{background:none;border:none;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .2s;font-size:.85rem}.btn-remove{color:var(--state-negative)}.btn-remove:hover{background:var(--state-negative-bg)}.empty-table-cell,.empty-text{text-align:center;padding:var(--spacing-xl)!important;color:var(--text-muted);font-style:italic;font-size:.9rem}.fun-facts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.fun-fact{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#6366f114;border-radius:var(--radius-md)}.fun-fact-icon{font-size:1.75rem}.fun-fact-value{display:block;font-weight:600;color:var(--text-primary)}.fun-fact-label{font-size:.8rem;color:var(--text-muted)}.stats-header-main{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.persona-badge{background:linear-gradient(135deg,#6366f11a,#a855f71a);border:1px solid var(--border-color);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);display:flex;flex-direction:column;align-items:center;min-width:140px}.persona-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600}.persona-value{font-size:1.1rem;font-weight:700;color:var(--accent-primary)}.style-meta{font-size:.8rem;color:var(--text-muted);margin-top:var(--spacing-xs)}.milestones-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.milestone-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#94a3b80d;border-radius:var(--radius-lg);border:1px solid var(--border-color);transition:all var(--transition-fast)}.milestone-item.achieved{background:radial-gradient(circle at 12% 18%,rgba(255,255,255,.1) 0 2px,transparent 2px),#0ea5e914;border-color:#0ea5e959}.milestone-item.locked{opacity:.6;filter:grayscale(1)}.milestone-icon{font-size:1.5rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-md)}.milestone-info{flex:1;display:flex;flex-direction:column}.milestone-label{font-weight:600;font-size:.95rem;color:var(--text-primary)}.milestone-desc{font-size:.8rem;color:var(--text-muted)}.milestone-check{color:var(--state-positive);font-weight:700;font-size:1.2rem}@media(max-width:768px){.stats-header-main{flex-direction:column;align-items:center;text-align:center}.stats-overview{grid-template-columns:repeat(2,1fr)}.stats-grid,.fun-facts-grid{grid-template-columns:1fr}}.about-page{padding:var(--spacing-xl) 0 100px}.about-hero{text-align:center;padding:var(--spacing-2xl) 0;margin-bottom:var(--spacing-xl)}.about-hero-content{max-width:700px;margin:0 auto}.about-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-md);animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.about-title{font-size:2.5rem;margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-tagline{font-size:1.2rem;color:var(--text-secondary);font-style:italic}.about-grid{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:900px;margin:0 auto}.about-section{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);transition:all var(--transition-slow)}.about-section:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.about-section h2{font-size:1.75rem;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.about-section h3{font-size:1.5rem;margin-bottom:var(--spacing-md);color:var(--accent-primary)}.about-section p{line-height:1.8;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.about-section p:last-child{margin-bottom:0}.about-dm-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#6366f133,#a855f733);border:1px solid rgba(99,102,241,.4);border-radius:var(--radius-full);margin-bottom:var(--spacing-lg);font-weight:600;font-size:.9rem}.dm-die{font-size:1.2rem;animation:spin 4s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.about-quote{background:#a855f71a;border-left:4px solid var(--accent-secondary);padding:var(--spacing-lg);border-radius:var(--radius-md);margin:var(--spacing-lg) 0;position:relative}.quote-icon{font-size:2rem;position:absolute;top:-10px;left:var(--spacing-md);opacity:.3}.about-quote p{font-size:1.1rem;font-style:italic;color:var(--text-primary);margin:var(--spacing-md) 0 var(--spacing-sm)}.quote-attribution{font-size:.9rem;color:var(--text-muted);font-style:italic}.shelf-subtitle{color:var(--text-muted)!important;margin-bottom:var(--spacing-lg)!important}.evil-grin{font-size:1.2rem}.shelf-image-container{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.shelf-image{width:100%;height:auto;display:block;transition:transform .3s ease}.shelf-image-container:hover .shelf-image{transform:scale(1.05)}.shelf-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(10,14,39,.9),transparent);padding:var(--spacing-lg);color:#fff;font-weight:600;text-align:center}.dnd-features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-top:var(--spacing-lg)}.feature-badge{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);text-align:center;transition:all var(--transition-fast)}.feature-badge:hover{background:#6366f126;border-color:var(--accent-primary);transform:translateY(-2px)}.feature-icon{font-size:1.5rem}.feature-badge span:last-child{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.dice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-top:var(--spacing-lg)}.dice-stat{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background:#a855f71a;border:1px solid rgba(168,85,247,.2);border-radius:var(--radius-md)}.dice-value{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dice-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--spacing-xs)}.about-cta{background:linear-gradient(135deg,#6366f133,#a855f733);border:1px solid rgba(99,102,241,.3);text-align:center}.cta-content h3{font-size:1.75rem;color:var(--text-primary)}.cta-content p{font-size:1.1rem;margin-bottom:var(--spacing-lg)}.cta-buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}@media(max-width:768px){.about-title{font-size:2rem}.dnd-features,.dice-grid{grid-template-columns:1fr}.cta-buttons{flex-direction:column}.cta-buttons .btn{width:100%}.about-section{padding:var(--spacing-lg)}}.admin-page{padding-bottom:110px}.admin-header{margin-bottom:var(--spacing-xl);text-align:center}.admin-header p{margin-top:var(--spacing-sm);color:var(--text-muted)}.admin-controls{display:flex;gap:var(--spacing-md);align-items:center;margin-bottom:var(--spacing-md)}.admin-status{margin-bottom:var(--spacing-md);color:var(--text-secondary)}.admin-review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.admin-review-card{padding:var(--spacing-lg)}.admin-review-header{display:flex;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.admin-review-header h2{margin-bottom:4px}.admin-review-header p,.admin-review-empty{color:var(--text-muted)}.admin-review-count{min-width:36px;height:36px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;background:var(--accent-primary-bg);color:var(--accent-primary);font-weight:700}.admin-review-list{display:grid;gap:var(--spacing-sm)}.admin-review-item{display:flex;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-elevated)}.admin-review-item p,.admin-review-item small{color:var(--text-muted);display:block}.admin-review-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:flex-end;align-items:flex-start}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;min-width:1400px}.admin-table th,.admin-table td{padding:var(--spacing-sm);border-bottom:1px solid var(--border-color);text-align:left;vertical-align:middle}.admin-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem}.admin-title-cell{color:var(--text-primary);font-weight:600}.admin-icon-cell{font-size:1.2rem}.admin-description-cell{display:-webkit-box;max-width:320px;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.admin-inline-description{min-width:280px;min-height:72px;resize:vertical}.admin-inline-color{min-width:54px;height:40px;padding:0}.admin-color-cell{display:inline-block;width:18px;height:18px;border-radius:999px;border:1px solid var(--border-color)}.admin-row-actions{display:flex;gap:var(--spacing-sm)}.admin-row-actions .btn{padding:8px 12px;font-size:.85rem}.admin-tag-edit{display:grid;gap:var(--spacing-xs);min-width:220px}.admin-tag-stack{display:grid;gap:4px}.admin-delete-btn{color:var(--accent-error)}.admin-loading{min-height:70vh;display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;inset:0;background:#0a0e27d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-content{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:550px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg),var(--shadow-glow);padding:var(--spacing-xl)}.admin-modal{max-width:760px}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer}.admin-modal-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,minmax(0,1fr))}.admin-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-field span{font-size:.82rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.admin-fetch-row{display:flex;gap:var(--spacing-sm)}.admin-candidate-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.admin-candidate-btn{font-size:.78rem;padding:6px 10px}.admin-inline-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:var(--text-primary);border-radius:50%;animation:adminSpin .8s linear infinite}.admin-span-2{grid-column:span 2}.admin-color-input{padding:0;height:44px}.admin-textarea{min-height:120px;resize:vertical}.admin-modal-status{margin-top:var(--spacing-md);color:var(--text-secondary);font-size:.92rem}.admin-modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg)}.admin-scan-modal{max-width:640px}.admin-scan-preview{width:100%;min-height:200px;max-height:46vh;border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;background:#0000006b}.admin-scan-preview video{width:100%;height:100%;object-fit:cover;display:block}.admin-scan-native-preview{min-height:200px;display:grid;place-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);text-align:center;color:var(--text-secondary)}.admin-scan-status{margin-top:var(--spacing-sm);color:var(--text-secondary);font-size:.9rem}.admin-scan-warning{color:var(--color-warning)}.admin-scan-controls{margin-top:var(--spacing-md);display:grid;grid-template-columns:1fr auto;gap:var(--spacing-sm)}.admin-scan-upload{margin-top:var(--spacing-md);display:flex;gap:var(--spacing-sm);justify-content:flex-end}.admin-scan-upload input[type=file]{display:none}.admin-confirm-grid{margin-top:var(--spacing-md);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-sm)}.admin-confirm-modal p{margin-top:var(--spacing-sm)}@keyframes adminSpin{to{transform:rotate(360deg)}}@media(max-width:900px){.admin-review-grid{grid-template-columns:1fr}.admin-review-item{flex-direction:column}.admin-controls{flex-direction:column;align-items:stretch}.admin-modal-grid{grid-template-columns:1fr}.admin-span-2{grid-column:span 1}.admin-modal-actions{flex-direction:column}.admin-scan-controls{grid-template-columns:1fr}.admin-scan-upload{flex-direction:column;align-items:stretch}.admin-confirm-grid{grid-template-columns:1fr}}.my-meeps-page{padding:var(--spacing-xl) 0 100px}.my-meeps-shell{display:flex;flex-direction:column;gap:var(--spacing-lg)}.my-meeps-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.my-meeps-header p{max-width:65ch;margin-top:var(--spacing-sm)}.my-meeps-layout{display:grid;grid-template-columns:minmax(290px,420px) minmax(0,1fr);gap:var(--spacing-lg);align-items:start}.my-meeps-preview{position:sticky;top:90px;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-xl);border-radius:var(--radius-xl);background:linear-gradient(145deg,#1e2340d9,#0f172af2)}.my-meeps-preview-frame{width:min(100%,320px);margin:0 auto;border-radius:28px;padding:var(--spacing-md);background:#0f172acc;border:1px solid rgba(148,163,184,.28);box-shadow:var(--shadow-lg)}.my-meeps-avatar-image{display:block;width:100%;height:auto;border-radius:20px}.my-meeps-reference-row{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.meep-reference-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--radius-full);background:#94a3b829;border:1px solid rgba(148,163,184,.3);color:var(--text-secondary);font-size:.78rem;font-weight:600}.meep-reference-tag.muted{opacity:.8}.my-meeps-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-sm)}.my-meeps-actions .btn{width:100%;min-height:42px}.my-meeps-status{font-size:.9rem;color:var(--text-secondary);margin-top:2px}.my-meeps-customizer{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-xl);border-radius:var(--radius-xl)}.my-meeps-presets h3{font-size:1rem;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.my-meeps-preset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(154px,1fr));gap:var(--spacing-sm)}.my-meeps-preset-chip{display:flex;align-items:center;gap:var(--spacing-sm);background:#1e293bc7;border:1px solid rgba(99,102,241,.28);color:var(--text-primary);padding:10px 12px;border-radius:var(--radius-md);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.my-meeps-preset-thumb{width:40px;height:40px;border-radius:var(--radius-md);flex-shrink:0}.my-meeps-preset-info{display:flex;flex-direction:column;gap:2px}.my-meeps-preset-info small{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.my-meeps-preset-chip:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.my-meeps-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--spacing-sm)}.my-meeps-tab{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);padding:10px;border-radius:var(--radius-md);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.my-meeps-tab:hover{border-color:var(--accent-primary)}.my-meeps-tab.active{background:#6366f138;border-color:var(--accent-primary);color:var(--text-primary)}.my-meeps-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:var(--spacing-sm)}.my-meeps-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);text-align:center;border-radius:var(--radius-lg);padding:var(--spacing-sm);background:#0f172ab3;border:2px solid rgba(148,163,184,.18);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);min-height:110px}.my-meeps-option:hover{border-color:#6366f180;transform:translateY(-2px);background:#1e293bd9}.my-meeps-option.selected{background:#6366f12e;border-color:var(--accent-primary);color:var(--text-primary);box-shadow:0 0 0 3px #6366f140,0 8px 24px #6366f133;animation:meep-select-pulse .4s ease-out}@keyframes meep-select-pulse{0%{transform:scale(1.05);box-shadow:0 0 0 6px #6366f166}to{transform:scale(1);box-shadow:0 0 0 3px #6366f140,0 8px 24px #6366f133}}.my-meeps-option-preview-wrap{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#0003;overflow:hidden}.my-meeps-option-preview{width:56px;height:56px;object-fit:contain;transition:transform var(--transition-fast)}.my-meeps-option:hover .my-meeps-option-preview{transform:scale(1.08)}.my-meeps-option-meta{display:flex;flex-direction:column;gap:2px;align-items:center}.my-meeps-option-game{color:var(--text-muted);font-size:.62rem;text-transform:uppercase;letter-spacing:.05em}.my-meeps-option-label{color:currentColor;font-size:.8rem;font-weight:600;line-height:1.2}@media(max-width:1080px){.my-meeps-layout{grid-template-columns:1fr}.my-meeps-preview{position:static}}@media(max-width:768px){.my-meeps-header{flex-direction:column}.my-meeps-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.my-meeps-actions,.my-meeps-options-grid{grid-template-columns:1fr}.my-meeps-customizer,.my-meeps-preview{padding:var(--spacing-lg)}}.notifications-page{padding:var(--spacing-lg) 0 100px}.notif-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.notif-header h1{display:inline}.notif-unread-count{font-size:.78rem;font-weight:600;color:var(--accent-primary);background:var(--accent-primary-bg);padding:3px 10px;border-radius:var(--radius-full);margin-left:var(--spacing-sm);vertical-align:middle}.notif-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.notif-item{appearance:none;width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;position:relative;transition:all var(--transition-fast);text-align:left;font-family:var(--font-body)}.notif-item:hover{background:var(--bg-elevated)}.notif-item.unread{background:var(--accent-primary-bg);border-color:var(--accent-primary)}.notif-dot{position:absolute;top:50%;left:5px;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--accent-primary)}.notif-icon{width:38px;height:38px;border-radius:var(--radius-md);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}.notif-item.unread .notif-icon{background:var(--bg-card)}.notif-content{flex:1;min-width:0}.notif-title{display:block;font-weight:700;font-size:.88rem;color:var(--text-primary);margin-bottom:2px}.notif-body{display:block;font-size:.82rem;color:var(--text-secondary);line-height:1.4}.notif-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs);flex-shrink:0}.notif-time{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.notif-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.72rem;padding:4px 6px;border-radius:var(--radius-sm);opacity:0;transition:all var(--transition-fast)}.notif-item:hover .notif-dismiss{opacity:1}.notif-dismiss:hover{color:var(--color-error);background:var(--color-error-bg)}@media(max-width:768px){.notif-dismiss{opacity:.5}}.chat-page{padding:var(--spacing-lg) 0}.chat-list{display:flex;flex-direction:column}.chat-list-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast);border:none;background:none;text-align:left;font-family:var(--font-body);width:100%;-webkit-tap-highlight-color:transparent;border-bottom:1px solid var(--border-light)}.chat-list-item:last-child{border-bottom:none}.chat-list-item:hover{background:var(--bg-elevated)}.chat-list-item:active,.chat-list-item.unread{background:var(--accent-primary-bg)}.chat-list-avatar{position:relative;flex-shrink:0}.chat-online-dot{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;background:var(--color-success);border:2.5px solid var(--bg-card)}.chat-list-item.unread .chat-online-dot{border-color:var(--accent-primary-bg)}.chat-list-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.chat-list-top{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.chat-list-name{font-size:.92rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-list-item.unread .chat-list-name{font-weight:700}.chat-list-time{font-size:.72rem;color:var(--text-muted);flex-shrink:0}.chat-list-bottom{display:flex;align-items:center;gap:var(--spacing-sm)}.chat-list-preview{font-size:.82rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.chat-list-item.unread .chat-list-preview{color:var(--text-secondary);font-weight:500}.chat-list-badge{min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-conversation-page{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-height));height:calc(100dvh - var(--topbar-height))}@media(max-width:768px){.chat-conversation-page{height:calc(100vh - var(--topbar-height) - var(--bottomnav-height));height:calc(100dvh - var(--topbar-height) - var(--bottomnav-height))}}.chat-conv-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--border-light);background:var(--bg-card)}.chat-conv-back{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;font-size:1.2rem;display:flex;align-items:center;transition:color var(--transition-fast)}.chat-conv-back:hover{color:var(--accent-primary)}.chat-conv-info{flex:1;min-width:0}.chat-conv-name{font-size:1rem;font-weight:700;font-family:var(--font-display)}.chat-conv-status{font-size:.72rem;color:var(--color-success);font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.chat-message{max-width:80%;display:flex;flex-direction:column}.chat-message.sent{align-self:flex-end}.chat-message.received{align-self:flex-start}.chat-bubble{padding:10px 14px;border-radius:var(--radius-lg);font-size:.9rem;line-height:1.45;word-wrap:break-word}.chat-message.sent .chat-bubble{background:var(--accent-primary);color:#fff;border-bottom-right-radius:4px}.chat-message.received .chat-bubble{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:4px}.chat-message-time{font-size:.65rem;color:var(--text-muted);margin-top:3px;padding:0 4px}.chat-message.sent .chat-message-time{text-align:right}.chat-input-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border-light);background:var(--bg-card)}.chat-input{flex:1;padding:10px 16px;border:1.5px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-input);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;outline:none;transition:border-color var(--transition-fast)}.chat-input:focus{border-color:var(--accent-primary)}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.chat-send-btn:hover{background:var(--accent-primary-light);transform:scale(1.05)}.chat-send-btn:active{transform:scale(.95)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.chat-date-separator{text-align:center;padding:var(--spacing-md) 0}.chat-date-separator span{background:var(--bg-elevated);color:var(--text-muted);font-size:.7rem;font-weight:600;padding:4px 12px;border-radius:var(--radius-full)}.chat-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md)}.new-chat-modal{max-height:70vh;display:flex;flex-direction:column}.new-chat-modal h2{margin:0;font-family:var(--font-display);font-size:1.2rem}.new-chat-subtitle{color:var(--text-muted);font-size:.82rem;margin:4px 0 var(--spacing-md)}.new-chat-friend-list{display:flex;flex-direction:column;overflow-y:auto;max-height:45vh}.new-chat-friend-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-sm);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast);border:none;background:none;text-align:left;font-family:var(--font-body);width:100%;-webkit-tap-highlight-color:transparent}.new-chat-friend-item:hover{background:var(--bg-elevated)}.new-chat-friend-item:active{background:var(--accent-primary-bg)}.new-chat-friend-item:disabled{opacity:.5;cursor:wait}.new-chat-friend-info{flex:1;min-width:0;display:flex;flex-direction:column}.new-chat-friend-name{font-size:.92rem;font-weight:600;color:var(--text-primary)}.new-chat-friend-id{font-size:.72rem;color:var(--text-muted)}.new-chat-friend-arrow{color:var(--text-muted);font-size:1rem;flex-shrink:0}.new-chat-empty{text-align:center;padding:var(--spacing-xl) 0;color:var(--text-muted)}.new-chat-empty span{font-size:2rem;display:block;margin-bottom:var(--spacing-sm)}.new-chat-empty p{font-size:.88rem;margin-bottom:var(--spacing-md)}.new-chat-close{margin-top:var(--spacing-md);align-self:center}.chat-empty-convo{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-muted);gap:var(--spacing-sm)}.chat-empty-convo span{font-size:2.5rem}.chat-empty-convo p{font-size:.92rem}.collection-page{padding:var(--spacing-lg) 0 100px}.collection-header{margin-bottom:var(--spacing-lg)}.collection-title-row{display:flex;align-items:baseline;gap:var(--spacing-md);flex-wrap:wrap}.collection-title-row h1{margin:0}.collection-count{font-size:.82rem;font-weight:600;color:var(--accent-primary);background:var(--accent-primary-bg);padding:3px 12px;border-radius:var(--radius-full)}.collection-subtitle{color:var(--text-secondary);font-size:.92rem;margin-top:6px}.collection-spotlight{display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);border-radius:var(--radius-xl);border:1px solid var(--border-color);background:radial-gradient(circle at top left,rgba(20,184,166,.18),transparent 38%),linear-gradient(135deg,var(--bg-card),var(--bg-secondary))}.collection-spotlight-kicker{display:inline-flex;margin-bottom:var(--spacing-sm);padding:4px 10px;border-radius:var(--radius-full);background:var(--accent-primary-bg);color:var(--accent-primary);font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.collection-spotlight-copy h2{margin-bottom:var(--spacing-sm)}.collection-spotlight-copy p{color:var(--text-secondary);line-height:1.6}.collection-spotlight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}.collection-spotlight-card{text-align:left;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md);background:#ffffff0a;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.collection-spotlight-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.collection-spotlight-icon,.collection-spotlight-title,.collection-spotlight-meta{display:block}.collection-spotlight-icon{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.collection-spotlight-title{font-weight:700;margin-bottom:4px}.collection-spotlight-meta,.collection-spotlight-empty{color:var(--text-secondary);font-size:.82rem;line-height:1.5}.collection-filters{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap;margin-bottom:var(--spacing-xl)}.collection-search-box{flex:1;min-width:200px;display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:0 var(--spacing-md);transition:all var(--transition-fast)}.collection-search-box:focus-within{border-color:var(--accent-primary);box-shadow:var(--focus-ring)}.collection-search-icon{color:var(--text-muted);flex-shrink:0}.collection-search-input{flex:1;border:none;background:transparent;padding:10px 0;font-size:.88rem;color:var(--text-primary);outline:none;font-family:var(--font-body)}.collection-search-input::placeholder{color:var(--text-muted)}.collection-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;font-size:.78rem;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.collection-search-clear:hover{color:var(--text-primary)}.collection-filter-pills{display:flex;gap:var(--spacing-sm)}.collection-select{appearance:none;-webkit-appearance:none;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px 32px 8px 12px;font-size:.82rem;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239CA3AF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.collection-select:focus{border-color:var(--accent-primary);outline:none;box-shadow:var(--focus-ring)}.collection-player-stepper{display:flex;align-items:center;gap:2px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2px}.stepper-btn{appearance:none;border:none;background:transparent;width:32px;height:32px;font-size:1rem;font-weight:600;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.stepper-btn:hover:not(:disabled){background:var(--accent-primary-bg)}.stepper-btn:disabled{opacity:.3;cursor:not-allowed}.stepper-value{min-width:36px;text-align:center;font-size:.82rem;font-weight:600;color:var(--text-primary);font-family:var(--font-body);-webkit-user-select:none;user-select:none}.stepper-reset{appearance:none;border:none;background:transparent;color:var(--text-muted);cursor:pointer;padding:0 6px;font-size:.72rem;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.stepper-reset:hover{color:var(--text-primary)}.collection-clear-filters{appearance:none;border:none;background:none;color:var(--accent-primary);font-size:.8rem;font-weight:600;font-family:var(--font-body);cursor:pointer;padding:4px 0;transition:opacity var(--transition-fast)}.collection-clear-filters:hover{opacity:.7}.collection-results-count{font-size:.82rem;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}@media(max-width:640px){.collection-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}.collection-card{border-radius:var(--radius-xl);overflow:hidden;position:relative;cursor:pointer;border:none;text-align:left;font-family:var(--font-body);color:#fff;transition:all var(--transition-base);height:160px;display:flex;flex-direction:column;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-card)}.collection-card:hover{box-shadow:var(--shadow-card-hover)}.collection-card-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--card-color, var(--accent-primary)) 0%,color-mix(in srgb,var(--card-color, var(--accent-primary)),black 30%) 100%);display:flex;align-items:center;justify-content:flex-end;padding-right:var(--spacing-lg)}@supports not (color: color-mix(in srgb,red,blue)){.collection-card-bg{background:var(--card-color, var(--accent-primary))}}.collection-card-icon{font-size:4rem;opacity:.25}.collection-card-content{position:relative;z-index:1;padding:var(--spacing-lg);margin-top:auto}.collection-card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:4px;text-shadow:0 1px 3px rgba(0,0,0,.3)}.collection-card-meta{font-size:.78rem;color:#fffc}.collection-card-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--spacing-sm)}.collection-card-badge{display:inline-flex;border-radius:var(--radius-full);padding:4px 8px;background:#ffffff24;color:#fff;font-size:.68rem;font-weight:700;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.collection-card-arrow{position:absolute;bottom:var(--spacing-lg);right:var(--spacing-lg);width:32px;height:32px;border-radius:var(--radius-full);background:#fff3;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;z-index:1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform var(--transition-fast)}.collection-card:hover .collection-card-arrow{transform:translate(3px)}.collection-empty{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);color:var(--text-muted)}.collection-empty-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.collection-empty h3{font-family:var(--font-display);font-weight:700;color:var(--text-primary);margin-bottom:6px}.collection-empty p{font-size:.88rem}.collection-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-md);color:var(--text-muted);font-size:.88rem}@media(max-width:768px){.collection-spotlight{grid-template-columns:1fr}.collection-filters{flex-direction:column;gap:var(--spacing-sm)}.collection-search-box{width:100%;min-width:unset}.collection-filter-pills{width:100%;flex-wrap:wrap}.collection-select{flex:1;min-width:0}.collection-player-stepper{flex:1;justify-content:center}}.addgame-page{min-height:60vh}.addgame-loading{display:flex;align-items:center;justify-content:center;min-height:50vh}.addgame-overlay{z-index:999}.addgame-denied-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--spacing-2xl) var(--spacing-xl);max-width:420px;width:calc(100% - 32px);text-align:center;box-shadow:var(--shadow-xl);position:relative}.addgame-denied-emoji{font-size:4rem;margin-bottom:var(--spacing-md);line-height:1;animation:denied-bounce .6s ease-out}@keyframes denied-bounce{0%{transform:scale(.3) rotate(-10deg);opacity:0}50%{transform:scale(1.15) rotate(3deg)}to{transform:scale(1) rotate(0);opacity:1}}.addgame-denied-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.addgame-denied-quote{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin:0 0 var(--spacing-xl);border-left:3px solid var(--accent-primary)}.addgame-denied-quote p{font-size:1.05rem;font-style:italic;color:var(--text-primary);line-height:1.5;margin-bottom:var(--spacing-sm)}.addgame-denied-quote cite{font-size:.78rem;color:var(--text-muted);font-style:normal;display:block}.addgame-denied-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.addgame-denied-hint{font-size:.78rem;color:var(--text-muted)}
