:root{--clr-primary: #b6141f;--clr-primary-dark: #91111a;--clr-accent: #4f9cbc;--clr-accent-hover: #3f88a8;--clr-white: #fcfcfc;--clr-gray-50: #fafafa;--clr-gray-100: #f5f5f5;--clr-gray-200: #e5e5e5;--clr-gray-300: #ddd;--clr-gray-400: #bbb;--clr-gray-500: #aaa;--clr-gray-600: #888;--clr-gray-700: #666;--clr-gray-800: #444;--clr-gray-900: #333;--clr-gray-950: #222;--clr-black: #111;--clr-dark-bg: #222831;--clr-dark-surface: #1f242c;--clr-dark-card: #2a3039;--clr-dark-border: #353e4a;--clr-dark-border-subtle: rgba(255,255,255,.06);--clr-dark-text: #e9edf3;--clr-dark-text-muted: #c5c5c5;--clr-dark-deep: #0b0f12;--clr-dark-deep-alt: #0f1214;--clr-dark-input: #393E46;--clr-link: var(--clr-accent);--clr-link-hover: var(--clr-accent-hover);--clr-visited: var(--clr-accent);--clr-error: #ff6b6b;--clr-warning: #fbbf24;--clr-checkin: var(--clr-accent);--clr-warning-text: var(--clr-gray-950);--clr-not-visited: var(--clr-gray-500);--clr-footer-text: #fff;--clr-footer-muted: var(--clr-gray-700);--clr-footer-hover: var(--clr-gray-950);--clr-page-close: var(--clr-gray-700);--clr-surface-soft: var(--clr-gray-100);--clr-surface-soft-2: var(--clr-gray-50);--clr-highlight-bg: #fcebd0;--clr-sidebar-hover: var(--clr-gray-100);--clr-sidebar-active: var(--clr-gray-200);--clr-sidebar-expanded: var(--clr-gray-200);--clr-dark-avatar-bg: var(--clr-dark-bg);--clr-dark-panel: var(--clr-dark-bg);--clr-dark-panel-2: var(--clr-dark-surface);--clr-dark-border-2: var(--clr-dark-border);--clr-dark-soft-text: var(--clr-dark-text);--clr-dark-soft-label: var(--clr-dark-text-muted);--clr-modal-text: var(--clr-gray-300);--clr-modal-heading: var(--clr-gray-200);--clr-nav-active-bg: var(--clr-accent);--clr-white-95: rgba(255,255,255,.95);--clr-white-80: rgba(255,255,255,.8);--clr-white-50: rgba(255,255,255,.5);--clr-white-08: rgba(255,255,255,.08);--clr-white-06: rgba(255,255,255,.06);--clr-white-04: rgba(255,255,255,.04);--clr-white-02: rgba(255,255,255,.02);--clr-dark-shadow-12: rgba(0,0,0,.12);--clr-dark-shadow-15: rgba(0,0,0,.15);--clr-dark-shadow-16: rgba(0,0,0,.16);--clr-black-11: rgba(0,0,0,.11);--clr-black-12: rgba(0,0,0,.12);--clr-black-20: rgba(0,0,0,.2);--clr-black-25: rgba(0,0,0,.25);--clr-error-bg: rgba(255,0,0,.1);--clr-banner-yellow: var(--clr-warning);--clr-banner-shadow: var(--clr-gray-950);--clr-profile-icon-bg: rgba(79,2,2,.442);--clr-seat-default: #606060;--clr-seat-stroke: #2f2f2f;--clr-map-bg: #0c0c0c;--overlay-light: rgba(0,0,0,.15);--overlay-medium: rgba(0,0,0,.18);--overlay-heavy: rgba(0,0,0,.8);--shadow-sm: 0 -2px 8px rgba(133,133,133,.07);--shadow-md: 0 8px 24px rgba(0,0,0,.18);--shadow-lg: 0 8px 30px rgba(0,0,0,.2);--shadow-xl: 0 10px 25px rgba(0,0,0,.5);--glass-bg: rgba(255,255,255,.06);--glass-blur: blur(6px);--font-stack: system-ui, -apple-system, Avenir, Helvetica, Arial, sans-serif;--font-mono: monospace;--fs-base: 18px;--fs-xs: .7rem;--fs-sm: .8rem;--fs-md: .9rem;--fs-lg: 1rem;--fs-xl: 1.4rem;--fs-2xl: 2em;--lh-base: 1.5;--lh-tight: 1.2;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 50%;--app-max-width: 480px;--footer-height: 60px;--header-height: 120px;--dev-banner-height: 0px;--touch-target: 44px;--sidebar-width: 260px;--ease-default: .25s ease;--ease-smooth: .35s cubic-bezier(.22,1,.36,1);--ease-spring: .38s cubic-bezier(.2,.9,.2,1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:var(--fs-base);font-family:var(--font-stack);line-height:var(--lh-base);font-weight:var(--fw-normal);color:var(--clr-gray-950);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%}body{margin:0;min-width:0;height:100%;background-color:var(--clr-dark-bg);font-family:inherit}a{font-weight:var(--fw-medium);color:var(--clr-link);text-decoration:inherit}a:hover{color:var(--clr-link-hover)}h1,h2,h3{font-weight:var(--fw-bold);line-height:var(--lh-tight);color:inherit}h1{font-size:var(--fs-2xl);margin:.2em 0 .25em}h2{font-size:var(--fs-xl);margin:.15em 0 .35em}h3{font-size:var(--fs-lg);margin:.15em 0 .3em}button,.btn,.action-btn,.login-btn,.logout-btn,.tool-btn,.nav-btn,.refresh-btn,.edit-btn,.search-btn,.cancel-btn,.accept-btn{font-family:inherit;font-size:var(--fs-lg);font-weight:var(--fw-medium);line-height:1;border:1px solid var(--clr-gray-300);border-radius:var(--radius-lg);padding:.5rem 1rem;background-color:var(--clr-gray-100);color:var(--clr-gray-900);cursor:pointer;transition:border-color var(--ease-default),background var(--ease-default),color var(--ease-default);min-width:var(--touch-target);min-height:var(--touch-target)}button:hover,.btn:hover:not(:disabled){border-color:var(--clr-gray-500);background:var(--clr-gray-200)}button:focus,button:focus-visible{outline:1px solid var(--clr-black-11)}button:disabled{opacity:.5;cursor:not-allowed}.action-btn{background-color:var(--clr-accent);color:var(--clr-white);border:none;padding:.8rem 1rem;border-radius:var(--radius-md);font-weight:var(--fw-bold)}.action-btn:hover{background-color:var(--clr-accent-hover)}.btn{padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-size:var(--fs-md);font-weight:var(--fw-bold);min-height:auto}.btn-checkin{background:var(--clr-checkin);color:var(--clr-white)}.btn-undo{background:var(--clr-warning);color:var(--clr-warning-text)}.btn-close{background:var(--clr-gray-200);color:var(--clr-gray-900)}.login-btn{background-color:var(--clr-white);color:var(--clr-dark-input);border:none;padding:.5rem 1.5rem;border-radius:var(--radius-md);font-weight:var(--fw-bold);min-height:auto}.login-btn:hover{background-color:var(--clr-accent);color:var(--clr-white)}.logout-btn{background-color:var(--clr-white);color:var(--clr-primary);border:1px solid var(--clr-white)}.logout-btn:hover{background-color:var(--clr-highlight-bg)}.tool-btn{width:3rem;min-width:3rem;height:100%;min-height:100%;padding:0;display:inline-flex;align-items:center;justify-content:center;background:var(--clr-dark-card);color:var(--clr-dark-text);border:none;border-radius:0;font-size:.95rem;font-weight:var(--fw-bold);transition:background-color .18s ease,color .18s ease}.tool-btn+.tool-btn{border-left:1px solid var(--clr-dark-border)}.tool-btn:hover{background:var(--clr-dark-border)}.tool-btn.is-active{background:var(--clr-primary);color:var(--clr-white)}.nav-btn{background:transparent;border:none;color:var(--clr-white);font-size:1.1rem;width:var(--touch-target);height:var(--touch-target);display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-lg)}.nav-btn:hover{background:var(--glass-bg)}.nav-btn:active{transform:translateY(1px)}.nav-btn.is-active{background:var(--clr-nav-active-bg);color:var(--clr-white)}.refresh-btn{background:var(--clr-white-50);border:1px solid var(--clr-black-20);border-radius:var(--radius-sm);padding:0 .8rem;font-size:var(--fs-xs);min-height:auto}.refresh-btn:hover{background:var(--clr-white-80)}.reset-btn{cursor:pointer;white-space:nowrap;border-left:1px solid var(--clr-dark-border);margin-left:auto}.edit-btn{background:var(--clr-white);border:1px solid var(--clr-gray-300);width:100%;display:block;padding:8px 12px;font-weight:var(--fw-normal);font-size:.95rem;line-height:var(--lh-tight)}.page-close-btn{position:absolute;top:.6rem;right:1rem;background:none;border:none;font-size:1.4rem;line-height:1;color:var(--clr-page-close);padding:.25rem .3rem;border-radius:var(--radius-sm);min-width:auto;min-height:auto}.page-close-btn:hover{background:var(--clr-surface-soft);color:var(--clr-black)}#app{max-width:var(--app-max-width);margin:0 auto;padding:0;text-align:left;display:flex;flex-direction:column;height:100%}.db-status{display:flex;justify-content:space-between;align-items:center;padding:.2rem 1rem;color:var(--clr-warning-text);font-size:var(--fs-xs);font-family:var(--font-mono);transition:background-color .5s ease}header{position:sticky;top:var(--dev-banner-height);width:100%;max-width:var(--app-max-width);z-index:110;background-color:var(--clr-primary);color:var(--clr-white);padding:.1rem 0 0}.dev-banner{position:sticky;top:0;z-index:120;width:100%;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,var(--clr-banner-yellow) 0,var(--clr-banner-yellow) 8px,var(--clr-black) 8px,var(--clr-black) 16px);color:var(--clr-white);text-shadow:var(--clr-banner-shadow) 1px 0 2px,var(--clr-black) -1px 0 2px,var(--clr-black) 0 1px 2px,var(--clr-black) 0 -1px 2px;text-align:center;font-size:.75rem;font-weight:var(--fw-semibold);padding:.1rem 0;letter-spacing:.02em}.dev-banner-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:inherit;font-size:1rem;cursor:pointer;opacity:.7;padding:2px 6px;line-height:1}.dev-banner-close:hover{opacity:1}.header-content{display:flex;justify-content:space-around;align-items:center;width:100%;padding-bottom:.1rem}.header-strip{height:1.6rem;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:var(--fs-sm);color:var(--clr-white-95);background:linear-gradient(180deg,var(--clr-primary-dark) 0%,var(--clr-primary) 100%)}.strip-divider{opacity:.5}.user-area{display:flex;align-items:center;gap:10px}.welcome-text{font-size:var(--fs-md);color:var(--clr-white);font-weight:var(--fw-bold)}.profile-toggle{display:flex;flex-direction:row;align-items:center;gap:.5rem;background:transparent;border:none;cursor:pointer;padding:.125rem .25rem}.profile-toggle:hover{background:inherit}.profile-toggle:hover .profile-icon,.profile-toggle:hover .profile-nick{transform:none}.profile-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--clr-profile-icon-bg);color:var(--clr-white);border-radius:var(--radius-full);font-size:1.05rem}.profile-nick{font-size:var(--fs-sm);color:var(--clr-white-95);line-height:1;font-weight:var(--fw-semibold);white-space:nowrap}main{width:100%;margin:0;padding:0;padding-bottom:var(--footer-height);flex:1 1 0;min-height:0;display:flex;flex-direction:column;overflow:visible}footer{position:fixed;left:0;right:0;bottom:0;z-index:99;max-width:var(--app-max-width);margin:0 auto;background:var(--clr-primary);padding:.15rem 1.5rem;text-align:center;color:var(--clr-dark-text);font-size:var(--fs-md)}.footer-link,.footer-copy{font-family:inherit;line-height:1;font-weight:var(--fw-normal)}.footer-line{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem;color:inherit;font-size:var(--fs-md);width:100%}.footer-left{justify-self:start}.footer-center{justify-self:center}.footer-right{justify-self:end}.footer-copy{color:inherit}.footer-sep{color:var(--clr-gray-400);margin:0 .25rem}.footer-link{color:inherit;text-decoration:none;cursor:pointer}.footer-link:hover{color:var(--clr-footer-hover);text-decoration:none}.footer-link--small{font-size:inherit}.map-wrapper{flex:1 1 0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.map-wrapper.friends-mode{flex:1 1 0;min-height:0;background:var(--clr-dark-card);overflow:hidden}.room-map{background:var(--clr-map-bg);padding:0;margin-top:0;flex:1 1 0;min-height:0;width:100%;display:flex;flex-direction:column;overflow:hidden}.room-map.friends-page{flex:1 1 0;min-height:0;overflow:hidden;padding-bottom:0}.friends-page .profile-body{padding-bottom:120px}.friends-page .friends-inner{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;background:var(--clr-dark-surface)}.friends-page .friends-tab-card{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;background:var(--clr-dark-panel);color:var(--clr-dark-text);border:none;overflow:auto}.controls-row{display:flex;justify-content:space-between;align-items:stretch;flex-wrap:nowrap;gap:0;height:3rem;padding:0;background-color:var(--clr-dark-surface)}.map-toolbar{display:flex;flex:1 1 auto;align-items:stretch;gap:0;min-width:0;height:100%}.toolbar-panel{background:var(--clr-dark-surface);padding:0 .75rem .55rem}.legend{display:flex;gap:.85rem;padding:.3rem .5rem;background:var(--clr-dark-card);border:1px solid var(--clr-dark-border);border-radius:var(--radius-lg);font-size:.85rem;color:var(--clr-dark-text)}.legend-item{display:flex;align-items:center;gap:.4rem}.dot{width:14px;height:14px;border-radius:var(--radius-full)}.map-container{position:relative;overflow:hidden;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;flex:1 1 0;min-height:0}.map-container.is-panning{cursor:grabbing}.svg-inner{width:100%;height:100%}.map-container svg{width:100%;height:100%;display:block}.ring-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:85}.ring-pulse{fill:none;stroke:var(--clr-accent);stroke-width:.3rem;opacity:.9;animation:ring-pulse 4s ease-out forwards;animation-fill-mode:forwards}@keyframes ring-pulse{0%{r:1rem;opacity:.95;stroke-width:.1rem}to{r:20rem;opacity:0;stroke-width:.1rem}}.map-container .seat{fill:var(--clr-seat-default);stroke:var(--clr-seat-stroke);stroke-width:3px;cursor:pointer;transition:all .3s ease}.map-container .seat:hover{stroke:var(--clr-black);stroke-width:1.5px;filter:brightness(1.15)}.map-container .area{cursor:pointer;transition:all var(--ease-default)}.map-container .area:hover{filter:brightness(1.1);stroke:var(--clr-primary);stroke-width:2px}.map-floating-label{position:absolute;top:8px;left:50%;transform:translate(-50%);pointer-events:none;z-index:90;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:var(--clr-dark-text);font-size:var(--fs-sm);padding:.28rem .6rem;border-radius:10px;font-weight:var(--fw-semibold);box-shadow:0 8px 20px var(--clr-dark-shadow-16);max-width:520px;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.map-container .border,.map-container #border{fill:none!important;stroke:var(--clr-seat-default)!important;stroke-opacity:1!important;fill-opacity:1!important;pointer-events:none}.popup-overlay{position:fixed;inset:0;background:var(--overlay-medium);z-index:100;display:flex;align-items:flex-end;justify-content:center}.seat-popup{position:relative;bottom:3rem;animation:slideup-popup var(--ease-smooth);max-width:var(--app-max-width);width:100%;padding:1rem}@keyframes slideup-popup{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.popup-content{background:var(--clr-white);border-radius:var(--radius-sm);padding:1.5rem;box-shadow:var(--shadow-lg);text-align:center;min-width:280px;width:100%;max-width:var(--app-max-width)}.status-visited{color:var(--clr-visited);font-weight:var(--fw-bold)}.status-not-visited{color:var(--clr-not-visited)}.popup-actions{display:flex;gap:.5rem;margin-top:1rem;justify-content:center}.seat-history{margin:15px 0;font-size:.95rem;text-align:left;background:var(--clr-surface-soft-2);padding:10px;border-radius:var(--radius-lg);color:var(--clr-gray-800);max-height:180px;overflow-y:auto;box-shadow:inset 0 1px 0 var(--clr-white-06)}.seat-history strong{display:block;margin-bottom:5px;color:var(--clr-gray-950);font-weight:var(--fw-semibold)}.seat-history p{color:var(--clr-gray-700);margin:0}.seat-history ul{margin:0;padding-left:20px;color:var(--clr-gray-800)}.seat-history li{margin-bottom:6px}.seat-history::-webkit-scrollbar{height:8px;width:8px}.seat-history::-webkit-scrollbar-thumb{background:var(--clr-black-12);border-radius:var(--radius-lg)}.seat-history::-webkit-scrollbar-track{background:transparent}.floating-bar{position:fixed;left:0;right:0;bottom:calc(var(--footer-height) + 10px);z-index:98;display:flex;justify-content:center;pointer-events:none}.floating-nav{pointer-events:auto;display:flex;gap:.4rem;align-items:center;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);padding:.35rem .5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);max-width:var(--app-max-width);margin:0 1rem}.left-sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);z-index:300;background:var(--clr-white);color:var(--clr-black);box-shadow:2px 0 18px var(--clr-dark-shadow-12);padding:.8rem;display:flex;flex-direction:column}.left-sidebar .sidebar-header{display:flex;align-items:center;font-weight:var(--fw-bold);gap:.5rem;margin-bottom:.6rem}.map-list{list-style:none;padding:0;margin:0;overflow:auto}.map-list li{padding:.6rem .5rem;border-radius:var(--radius-lg);cursor:pointer}.map-list li:hover{background:var(--clr-sidebar-hover)}.map-list li.active{background:var(--clr-sidebar-active);font-weight:var(--fw-bold)}.area-list{list-style:none;padding:0;margin:0}.area-item{margin-bottom:.25rem}.area-header{display:flex;align-items:center;gap:.5rem;padding:.6rem .5rem;border-radius:var(--radius-lg);cursor:pointer;font-weight:var(--fw-medium);color:var(--clr-gray-900)}.area-header:hover{background:var(--clr-sidebar-hover)}.area-header.expanded{background:var(--clr-sidebar-expanded)}.area-arrow{font-size:var(--fs-xs);color:var(--clr-gray-600);width:1rem;text-align:center}.map-list--nested{margin-left:1.2rem;border-left:2px solid var(--clr-gray-300);padding-left:.5rem}.login-overlay,.modal-overlay{position:fixed;inset:0;background:var(--overlay-heavy);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.login-box,.modal-box{background:var(--clr-dark-bg);color:var(--clr-modal-heading);padding:2rem;border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-xl);border:1px solid var(--clr-dark-input)}.login-box h2,.modal-box h2{margin-top:0;color:var(--clr-accent);text-align:center;margin-bottom:1.25rem}.input-group{margin-bottom:1.2rem}.input-group label{display:block;font-size:var(--fs-md);margin-bottom:.4rem;color:var(--clr-gray-400)}.input-group input{width:100%;padding:.8rem;background:var(--clr-dark-input);border:1px solid var(--clr-gray-950);color:var(--clr-white);border-radius:var(--radius-sm);font-size:var(--fs-lg)}.input-group input:focus{outline:2px solid var(--clr-accent)}.btn-row{margin-top:1.5rem}.btn-row .action-btn{width:100%}.error-msg{color:var(--clr-error);background:var(--clr-error-bg);padding:.5rem;border-radius:var(--radius-sm);font-size:var(--fs-md);margin-bottom:1rem;text-align:center}.success-msg{color:var(--clr-accent);background:var(--clr-white-04);padding:.5rem;border-radius:var(--radius-sm);font-size:var(--fs-md);margin-bottom:1rem;text-align:center}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:2.8rem}.password-toggle{position:absolute;top:50%;right:.4rem;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;min-width:2rem;min-height:2rem;border:none;background:transparent;color:var(--clr-dark-text-muted);padding:0;line-height:1}.password-toggle:hover{background:transparent;color:var(--clr-dark-text)}.password-toggle .icon-eye{width:18px;height:18px;display:block}.password-modal-overlay{background:#000000b8;z-index:260}.footer-actions{margin-top:1.25rem;display:flex;justify-content:space-between;font-size:var(--fs-md)}.modal-actions{margin-top:1rem;display:flex;gap:12px;justify-content:flex-end}.modal-actions--center{justify-content:center}.login-box ul,.modal-box ul,.login-box .modal-list{margin:.25rem 0 0;padding-left:1.05rem}.login-box ul li,.modal-box ul li,.login-box .modal-list li{margin-bottom:.35rem}.login-box p,.modal-box p{color:var(--clr-modal-text)}.link-text{cursor:pointer;color:var(--clr-gray-400);text-decoration:underline}.link-text:hover{color:var(--clr-white)}.link-text.cancel{color:var(--clr-error);text-decoration:none}.page-container{position:relative;width:100%;min-height:100%;display:flex;justify-content:center;align-items:flex-start;padding:3rem 1rem 6rem;box-sizing:border-box;background:var(--clr-white);overflow-y:auto}.page-box{width:100%;max-width:780px;background:var(--clr-white);color:var(--clr-black);padding:2rem;border-radius:var(--radius-lg);box-shadow:0 8px 15px var(--clr-dark-shadow-12)}.page-box h2{margin:0;text-align:left;color:inherit;line-height:var(--lh-tight)}.page-box h3{margin:.4rem 0 .2rem;color:inherit;line-height:var(--lh-tight)}.page-box p{color:var(--clr-gray-900);line-height:var(--lh-base);text-align:justify}.page-box ul{list-style:disc;margin-left:1.5rem}.page-box li{margin-bottom:.5rem}.profile-container{background:inherit;color:inherit}.page-shell{width:100%;padding:16px;box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:0}.page-shell--dark{background:linear-gradient(180deg,var(--clr-dark-deep) 0%,var(--clr-dark-deep-alt) 100%);color:var(--clr-dark-text)}.friends-page .page-shell{padding-bottom:16px}.friends-page .page-shell.feed-container{padding-bottom:0}.profile-header{display:flex;justify-content:space-between;align-items:flex-start}.profile-meta{display:flex;gap:12px;align-items:flex-start}.profile-container .avatar{flex:0 0 25%;width:25%;max-width:25%;min-width:80px;aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;background-size:cover;background-position:center;background-color:var(--clr-dark-avatar-bg)}.name-block{display:flex;flex-direction:column;flex:1 1 auto}.profile-container .name{margin:0;font-size:var(--fs-xl);color:var(--clr-white)}.close-btn{background:transparent;border:none;font-size:20px;cursor:pointer;color:var(--clr-dark-text)}.profile-body{flex:1 1 auto;overflow:auto;margin-top:.5rem;background:transparent}.bio-label{display:none}.bio-text{font-size:.85rem;background:var(--clr-dark-deep-alt);border-radius:0;padding:12px;color:var(--clr-dark-text);margin:6px 0}.bio-text.muted{color:var(--clr-dark-text-muted);font-style:italic}.level-row{display:flex;gap:0;align-items:center;width:100%}.level-col{flex:0 0 50%;width:50%;display:flex;align-items:center;justify-content:center}.level-indicator{display:flex;flex-direction:row;align-items:center;gap:10px}.level-label{font-size:.95rem;color:var(--clr-dark-text-muted)}.level-row--meta{justify-content:center}.level-meta-text{width:100%;text-align:left;margin-top:8px}.level-circle{width:48px;height:48px;border-radius:var(--radius-full);background:transparent;border:3px solid var(--clr-dark-border-subtle);color:var(--clr-dark-text);display:flex;align-items:center;justify-content:center;font-weight:var(--fw-semibold);box-sizing:border-box}.badges-col{flex:0 0 50%;display:flex;justify-content:center;align-items:center}.badges-placeholder{background:transparent;padding:8px 12px;border-radius:0;color:var(--clr-dark-soft-label);font-size:var(--fs-md);display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.badges-img-placeholder{width:40px;height:40px;flex-shrink:0;background:var(--clr-dark-panel);border-radius:0;border:1px solid var(--clr-dark-border-subtle)}.level-box{background:var(--clr-dark-deep-alt);padding:12px;margin-top:12px;border-radius:0;color:var(--clr-dark-text);border:1px solid var(--clr-dark-border-subtle)}.profile-divider{height:1px;width:100%;margin:1.5rem 0;background:var(--clr-dark-border-subtle);border-radius:1px;opacity:.95}.map-container{position:relative}.dashboard-page{gap:12px}.dashboard-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.dashboard-card{background:var(--clr-dark-panel);border:1px solid var(--clr-dark-border-subtle);border-radius:var(--radius-lg);padding:12px;color:var(--clr-dark-text);box-shadow:var(--shadow-sm)}.dashboard-card .muted{color:var(--clr-dark-text-muted)}.level-card__head{display:flex;justify-content:space-between;gap:12px;align-items:center}.level-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin:10px 0 6px}.metric{display:flex;flex-direction:column;gap:4px}.progress-row{display:flex;flex-direction:column;gap:6px;margin-top:6px}.progress-meta{display:flex;justify-content:space-between}.progress-bar{position:relative;width:100%;height:10px;border-radius:999px;background:var(--clr-dark-border-subtle);overflow:hidden}.progress-fill{position:absolute;inset:0;background:linear-gradient(90deg,#22d3ee,#3b82f6);transform-origin:left;transition:width .18s ease}.progress-numbers{display:flex;justify-content:space-between;font-size:.9rem}.progress-remaining__xp{color:var(--clr-accent);font-weight:var(--fw-semibold)}.ghost-btn{background:transparent;color:var(--clr-dark-text);border:1px solid var(--clr-dark-border-subtle);border-radius:var(--radius-md);padding:6px 10px;cursor:pointer}.ghost-btn:disabled{opacity:.6;cursor:not-allowed}.error-text{color:#f97316;margin:4px 0 0}.edit-row{margin-top:10px;width:100%}.profile-container .menu{margin-top:.5rem}.menu-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.menu-item{display:flex}.profile-container .menu .menu-item{background:transparent;color:var(--clr-dark-soft-text)}.profile-container .menu .menu-item:hover{background:var(--clr-white-02)}.friends-page .friends-topbar{display:flex;margin-bottom:0;gap:0;height:3rem;min-height:3rem;max-height:3rem;background:var(--clr-dark-surface)}.friends-page .friends-tab-btn{flex:1;border-radius:0;text-align:center;background:var(--clr-dark-card);color:var(--clr-dark-text-muted);border:none;min-height:100%}.friends-page .friends-tab-btn:hover{background:var(--clr-dark-border);color:var(--clr-dark-text)}.friends-page .friends-tab-btn.active-tab{background:var(--clr-dark-panel-2);color:var(--clr-dark-text);box-shadow:inset 0 -2px 0 var(--clr-accent)}.friends-page .add-row{display:flex;flex-direction:column;align-items:stretch;gap:8px}.friends-page .search-input{width:100%;padding:10px 12px;border:1px solid var(--clr-dark-border-subtle);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--clr-dark-deep-alt) 0%,#121212 100%);color:var(--clr-dark-text);box-shadow:0 0 #00adb500;transition:box-shadow .16s ease,border-color .16s ease,transform .12s ease;font-weight:var(--fw-semibold)}.friends-page .search-input::placeholder{color:#e9edf38c;font-weight:var(--fw-medium)}.friends-page .search-input:focus{outline:none;border-color:#00adb559;box-shadow:0 6px 20px -10px #00adb540,0 0 0 4px #00adb50f;transform:translateY(-1px)}.friends-page .search-btn{width:100%}.friends-page .cancel-btn{width:100%;background:var(--clr-white-02);border:1px solid var(--clr-white-08)}.friends-page .accept-btn{background:#00adb514;color:var(--clr-accent);border:none;padding:6px 8px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.friends-page .accept-btn:hover{background:#00adb52e}.friends-page .result-actions .login-btn,.friends-page .result-actions .accept-btn,.friends-page .result-actions .cancel-btn{min-width:var(--touch-target);padding:6px 10px;height:36px;display:inline-flex;align-items:center;justify-content:center;gap:6px;box-sizing:border-box}.friends-page .result-actions .login-btn{white-space:nowrap}.friends-page .result-actions{display:flex;gap:8px}.friends-page .result-actions.is-pending{align-items:center;gap:10px}.friends-page .request-status{font-size:.8rem;color:var(--clr-dark-text-muted)}.friends-page .menu-list{margin:.5rem 0 0;gap:8px}.friends-page .menu .menu-item{background:var(--clr-accent);color:var(--clr-white)}.friends-page .menu .menu-item:hover{background:var(--clr-accent-hover);color:var(--clr-white)}.friends-page .menu-item{display:flex;color:var(--clr-white);align-items:center;justify-content:space-between;padding:8px;background:var(--clr-accent);border-radius:var(--radius-md)}.friends-page .menu-item:hover{background:var(--clr-accent-hover);color:var(--clr-white)}.friends-page .menu-item.section-title,.friends-page .menu-item.day-heading{background:transparent}.friends-page .menu-item.section-title{font-weight:var(--fw-bold);padding-top:.5rem}.friends-page .menu-item.section-title:hover{background:transparent;color:inherit;cursor:default}.friends-page .menu-item.section-title.is-spaced{margin-top:15px}.friends-page .friends-list-title{margin:0 0 8px}.friends-page .menu-item.day-heading{color:var(--clr-dark-text-muted);font-size:.85rem;margin-top:8px;padding:6px 0;font-weight:var(--fw-semibold)}.friends-page .menu-item.friend .friend-left,.friends-page .menu-item.result .result-left{display:flex;align-items:center;gap:10px}.friends-page .menu-item.feed-item{align-items:flex-start;flex-direction:column;gap:6px}.friends-page .feed-item-top{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}.friends-page .feed-item-left{display:flex;align-items:center;gap:10px}.friends-page .feed-item-time{margin-left:auto}.friends-page .feed-item-name{font-weight:var(--fw-semibold);color:var(--clr-dark-text)}.friends-page .preview-right{display:flex;align-items:center;gap:12px;margin-left:auto;margin-right:12px}.friends-page .avatar-small{width:40px;height:40px;border-radius:var(--radius-md);background-size:cover;background-position:center;background-color:var(--clr-gray-950)}.friends-page .result-meta .result-name,.friends-page .friend-name{font-weight:var(--fw-semibold);color:var(--clr-dark-text)}.friends-page .friends-title{color:var(--clr-dark-text)}.friends-page .login-btn.edit-btn{background:var(--clr-dark-card);color:var(--clr-dark-text);border:1px solid var(--clr-white-04)}.friends-page .level-indicator.compact{gap:8px}.friends-page .level-label{font-size:var(--fs-sm);color:var(--clr-dark-text-muted)}.friends-page .level-circle{width:34px;height:34px;color:var(--clr-primary);font-size:.85rem;font-weight:var(--fw-bold)}.friends-page .badges-placeholder.compact{display:flex;align-items:center;gap:6px;color:var(--clr-dark-text-muted);font-size:var(--fs-sm)}.friends-page .badges-img-placeholder{width:28px;height:28px;background:var(--clr-dark-card);border:1px solid var(--clr-white-08);border-radius:var(--radius-sm)}@media(max-width:760px){.friends-page .menu-item{flex-direction:column;align-items:flex-start;gap:8px}.friends-page .preview-right{margin:0}.friends-page .result-actions,.friends-page .result-actions .login-btn{width:100%}}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.slide-right-enter-active,.slide-right-leave-active{transition:transform .3s}.slide-right-enter-from{transform:translate(100%)}.slide-right-enter-to,.slide-right-leave-from{transform:translate(0)}.slide-right-leave-to{transform:translate(100%)}.slide-left-enter-active,.slide-left-leave-active{transition:transform var(--ease-spring)}.slide-left-enter-from{transform:translate(100%)}.slide-left-enter-to,.slide-left-leave-from{transform:translate(0)}.slide-left-leave-to{transform:translate(100%)}.slide-up-enter-active,.slide-up-leave-active{transition:transform var(--ease-spring)}.slide-up-enter-from,.slide-up-leave-to{transform:translateY(110%)}.slide-up-enter-to,.slide-up-leave-from{transform:translateY(0)}.logout-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--overlay-light);z-index:200;display:flex;justify-content:flex-end;align-items:flex-start}.logout-menu{background:var(--clr-white);border-radius:var(--radius-lg) 0 0 var(--radius-lg);box-shadow:-2px 0 8px var(--clr-black-12);padding:24px 32px;margin-top:32px;margin-right:0;z-index:201;transition:transform .3s}.logout-sidebar{position:fixed;top:0;right:0;width:30vw;min-width:220px;height:100vh;background:var(--clr-white);box-shadow:-2px 0 16px var(--clr-dark-shadow-15);z-index:200;display:flex;flex-direction:column;align-items:flex-end;padding:32px 24px}.profile-overlay{position:fixed;inset:0;background:var(--overlay-light);z-index:200;display:flex;justify-content:center;align-items:flex-end;overflow:hidden}.profile-sheet{width:100%;max-width:var(--app-max-width);height:calc(100vh - var(--header-height) - 16px);max-height:calc(100vh - var(--header-height) - 16px);background:linear-gradient(180deg,var(--clr-dark-deep) 0%,var(--clr-dark-deep-alt) 100%);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:0 -6px 24px var(--clr-dark-shadow-15);padding:18px;z-index:201;overflow:auto;margin:0 auto;will-change:transform}.friends-overlay{position:fixed;inset:0;background:var(--clr-black-25);display:flex;justify-content:center;align-items:center;z-index:220}.friends-panel{background:var(--clr-white);padding:18px;border-radius:var(--radius-lg);width:min(520px,92%);max-height:80vh;overflow:auto}@media(min-width:600px){html{font-size:var(--fs-base)}#app{max-width:var(--app-max-width);margin:0 auto}}.avatar-preview{display:flex;justify-content:center;margin-bottom:8px}.avatar-img{width:64px;height:64px;border-radius:0;background:var(--clr-surface-soft)}.public-profile-page .public-placeholder{visibility:hidden;pointer-events:none}.profile-edit-page .profile-edit-title{margin:0;font-size:1.1rem;color:var(--clr-black)}.profile-edit-page textarea{width:100%;padding:.6rem;box-sizing:border-box;border-radius:4px;border:1px solid var(--clr-gray-300);min-height:120px;font-family:inherit;font-size:.95rem}.profile-edit-page .btn-row{display:flex;gap:.6rem;margin-top:1rem}@media(prefers-color-scheme:dark){.profile-edit-page{color:var(--clr-dark-text)}.profile-edit-page .profile-edit-title{color:var(--clr-white)}.profile-edit-page .close-btn{color:var(--clr-dark-text)}.profile-edit-page .input-group label{color:var(--clr-dark-soft-label)}.profile-edit-page textarea{background:var(--clr-dark-panel-2);color:var(--clr-dark-text);border-color:var(--clr-dark-border-2)}.profile-edit-page .action-btn{background:var(--clr-dark-card);color:var(--clr-white);border:1px solid var(--clr-dark-border)}}@keyframes feedBlinkPulse{0%{fill:var(--blink-fill-a, #facc15)}50%{fill:var(--blink-fill-b, #fde047)}to{fill:var(--blink-fill-a, #facc15)}}.feed-blink{animation:feedBlinkPulse .8s step-end infinite}
