@import"https://fonts.googleapis.com/css2?family=Quicksand:wght@400;500;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;width:100%;height:100vh;height:100dvh;overflow:hidden}#root{width:100%;height:100%;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.google-signin-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:#fff;color:#1f1f1f;border:2px solid rgba(255,255,255,.2);border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--spacing-lg)}.google-signin-btn:hover{background:#f8f8f8;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #fff3}.google-signin-btn:active{transform:translateY(0)}.google-icon{width:20px;height:20px;flex-shrink:0}.code-input-container{display:flex;gap:var(--spacing-sm);justify-content:center;margin:var(--spacing-lg) 0}.code-digit{width:48px;height:56px;background:var(--color-bg-elevated);border:2px solid var(--color-border-primary);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl);text-align:center;outline:none;transition:all var(--transition-base);caret-color:var(--color-primary)}.code-digit:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);background:var(--color-bg-secondary)}.code-digit.filled{border-color:var(--color-success);background:var(--color-bg-secondary)}.code-digit.filled:not(:focus){box-shadow:0 0 0 1px var(--color-success-glow)}.code-digit:disabled{opacity:.5;cursor:not-allowed;background:var(--color-bg-secondary)}.code-digit{animation:fade-in-scale .3s ease-out backwards}.code-digit:nth-child(1){animation-delay:.05s}.code-digit:nth-child(2){animation-delay:.1s}.code-digit:nth-child(3){animation-delay:.15s}.code-digit:nth-child(4){animation-delay:.2s}.code-digit:nth-child(5){animation-delay:.25s}.code-digit:nth-child(6){animation-delay:.3s}@keyframes fade-in-scale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(max-width:400px){.code-digit{width:40px;height:48px;font-size:var(--font-size-xl)}.code-input-container{gap:6px}}.email-login-form{width:100%}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.5px}.form-input{width:100%;padding:var(--spacing-md);background:var(--color-bg-elevated);border:2px solid var(--color-border-primary);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);outline:none;transition:all var(--transition-base)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-input::placeholder{color:var(--color-text-muted)}.error-message{padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:var(--color-danger);color:var(--color-text-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;border:1px solid var(--color-danger-dark);box-shadow:var(--glow-danger)}.captcha-container{margin-bottom:var(--spacing-lg);display:flex;justify-content:center}.submit-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-primary);color:var(--color-text-on-primary);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);text-transform:uppercase;letter-spacing:.5px}.submit-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--glow-primary);transform:translateY(-2px)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn.loading{position:relative}.submit-btn.loading:after{content:"";position:absolute;width:16px;height:16px;border:2px solid var(--color-text-on-primary);border-top-color:transparent;border-radius:var(--radius-full);animation:spin .6s linear infinite;margin-left:var(--spacing-sm)}.code-step{text-align:center}.code-info{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg);line-height:1.6}.code-email{color:var(--color-primary);font-weight:var(--font-weight-bold);text-shadow:var(--text-shadow-neon)}.back-btn{width:100%;padding:var(--spacing-sm);background:transparent;color:var(--color-text-muted);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--spacing-md)}.back-btn:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-elevated)}.back-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn.rate-limited{background:var(--color-text-muted);cursor:not-allowed}.submit-btn.rate-limited:hover{background:var(--color-text-muted);box-shadow:none;transform:none}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-primary);padding:var(--spacing-lg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 50% 50%,var(--color-primary-glow) 0%,transparent 50%);opacity:.1;animation:rotate-gradient 20s linear infinite}@keyframes rotate-gradient{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-container{width:100%;max-width:400px;position:relative;z-index:1;animation:slide-in-up .6s ease-out}.login-logo{text-align:center;margin-bottom:var(--spacing-2xl)}.login-logo-icon{width:100px;border-radius:10000px;height:100px;object-fit:contain;margin-bottom:var(--spacing-md);filter:drop-shadow(var(--glow-primary));animation:pulse-neon 2s ease-in-out infinite}.login-title{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-3xl);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0;text-shadow:var(--text-shadow-neon)}.login-subtitle{font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.login-card{background:var(--color-bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-xl)}.login-divider{display:flex;align-items:center;text-align:center;margin:var(--spacing-lg) 0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border-primary)}.login-divider span{padding:0 var(--spacing-md)}.google-signin-btn{width:100%;padding:var(--spacing-md);background:var(--color-bg-elevated);border:2px solid var(--color-border-primary);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.google-signin-btn:hover{border-color:var(--color-primary);background:var(--color-bg-elevated);box-shadow:0 0 0 3px var(--color-primary-glow);transform:translateY(-2px)}.google-signin-btn img{width:20px;height:20px}.error-message{padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:var(--color-danger);color:var(--color-text-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;animation:slide-in-up .3s ease-out;box-shadow:var(--glow-danger)}.login-footer{margin-top:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-xs)}.login-footer a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}.login-footer a:hover{color:var(--color-primary-dark);text-shadow:var(--text-shadow-neon)}.network-banner{position:fixed;top:0;left:0;right:0;z-index:9999;padding:8px 16px;text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);animation:networkSlideDown .3s ease-out}@keyframes networkSlideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.network-banner.offline{background:var(--color-danger);color:#fff}.network-banner.reconnected{background:var(--color-success);color:#000}.bottom-nav{bottom:0;left:0;right:0;padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--color-bg-glass, rgba(10, 10, 15, .85));border-top:1px solid var(--color-border-primary);display:flex;justify-content:space-around;align-items:center;gap:var(--spacing-sm);z-index:50;flex-shrink:0}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);flex:1;max-width:80px;background:transparent;border:1px solid transparent}.nav-item:hover{background:var(--color-bg-elevated)}.nav-item.active{background:var(--color-bg-elevated);border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-glow)}.nav-icon{position:relative;font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs);filter:grayscale(.5);transition:filter var(--transition-fast)}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{filter:grayscale(0) drop-shadow(var(--glow-primary))}.nav-label{font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);color:var(--color-text-muted);transition:color var(--transition-fast)}.nav-item:hover .nav-label,.nav-item.active .nav-label{color:var(--color-primary)}.nav-badge{position:absolute;top:-4px;right:-20px;background:var(--color-secondary);color:var(--color-text-on-primary);border-radius:var(--radius-full);padding:2px 6px;font-size:10px;font-weight:var(--font-weight-bold);animation:pulse-neon 2s ease-in-out infinite}.nav-item.nav-admin .nav-icon{color:var(--color-secondary);filter:none}.nav-item.nav-admin .nav-label{color:var(--color-secondary)}.nav-item.nav-admin.active{border-color:var(--color-secondary);box-shadow:0 0 0 1px #ff00554d}@media(max-width:768px){.bottom-nav{padding:var(--spacing-sm);padding-bottom:calc(var(--spacing-xl) + env(safe-area-inset-bottom,0px))}.nav-icon{font-size:var(--font-size-xl)}.nav-label{font-size:10px}}.image-modal-overlay{position:fixed;inset:0;background-color:#000000f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;user-select:none;-webkit-user-select:none;padding:var(--spacing-xl)}.image-modal-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);max-width:100%;max-height:100%}.image-modal-img{max-width:90vw;max-height:70vh;box-shadow:0 0 50px var(--color-primary-glow);border:3px solid var(--color-primary);border-radius:var(--radius-md);transition:transform var(--transition-base);object-fit:contain;touch-action:none;-webkit-user-drag:none;user-drag:none}.image-modal-img.dragging{transition:none;cursor:grabbing}.image-modal-img.zoomable{cursor:grab}.image-modal-img.zoomable:active{cursor:grabbing}.image-modal-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);z-index:10001}.image-modal-btn{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:2px solid var(--color-primary);background:#000c;color:var(--color-primary);font-family:var(--font-family);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-base);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.image-modal-btn:hover{background:var(--color-primary);color:var(--color-text-on-primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}.image-modal-btn:active{transform:translateY(0)}.image-modal-btn-zoom{width:48px;height:48px;font-size:var(--font-size-2xl)}.image-modal-btn-reset{padding:0 var(--spacing-lg);height:48px;font-size:var(--font-size-sm)}.image-modal-btn-close{width:48px;height:48px;font-size:var(--font-size-xl);border-color:var(--color-danger);color:var(--color-danger)}.image-modal-btn-close:hover{background:var(--color-danger);color:var(--color-text-primary);box-shadow:var(--glow-danger)}.image-modal-zoom-indicator{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:2px solid var(--color-primary);background:#000c;color:var(--color-primary);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);text-shadow:var(--text-shadow-neon)}@media(max-width:768px){.image-modal-overlay{padding:var(--spacing-lg)}.image-modal-container{gap:var(--spacing-md)}.image-modal-img{max-width:95vw;max-height:65vh}.image-modal-controls{gap:var(--spacing-sm);flex-wrap:wrap}.image-modal-btn-zoom,.image-modal-btn-close{width:44px;height:44px;font-size:var(--font-size-xl)}.image-modal-btn-reset{height:44px;padding:0 var(--spacing-md);font-size:var(--font-size-xs)}.image-modal-zoom-indicator{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}}.pee-history-overlay{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:ph-fadeIn .3s ease}@keyframes ph-fadeIn{0%{opacity:0}to{opacity:1}}.pee-history-modal{width:95vw;max-width:420px;max-height:90vh;background:var(--color-bg-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;animation:ph-slideIn .4s cubic-bezier(.16,1,.3,1)}@keyframes ph-slideIn{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ph-header{position:relative;padding:var(--spacing-lg) var(--spacing-md);background:linear-gradient(135deg,#aaad0d4d,#000000e6);border-bottom:1px solid var(--color-secondary);text-align:center}.ph-close-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm)}.ph-title{font-family:var(--font-family);font-weight:900;font-size:var(--font-size-2xl);color:var(--color-secondary-light);text-shadow:var(--glow-secondary);letter-spacing:4px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.ph-subtitle{font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:4px;letter-spacing:2px}.ph-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.ph-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md)}.ph-loading-icon{animation:ph-pulse 1.5s ease-in-out infinite}@keyframes ph-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.ph-loading-text{font-family:var(--font-family);color:var(--color-text-secondary);font-style:italic}.ph-error{text-align:center;padding:var(--spacing-xl);color:var(--color-danger);font-family:var(--font-family)}.ph-rank-card{text-align:center;padding:var(--spacing-lg);background:var(--color-bg-glass);border:2px solid;border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);animation:ph-rankGlow 3s ease-in-out infinite;position:relative;overflow:hidden}.ph-rarity-mythique:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent 0%,rgba(255,0,85,.15) 10%,transparent 20%,rgba(255,215,0,.1) 30%,transparent 40%);animation:ph-mythicSpin 8s linear infinite;pointer-events:none}.ph-rarity-légendaire:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent 0%,rgba(255,215,0,.1) 15%,transparent 30%);animation:ph-mythicSpin 10s linear infinite;pointer-events:none}@keyframes ph-mythicSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ph-rankGlow{0%,to{box-shadow:0 0 10px #a2ad0d4d}50%{box-shadow:0 0 25px #ada20d99,0 0 50px #aaad0d33}}.ph-rank-rarity{font-family:var(--font-family);font-size:10px;font-weight:900;letter-spacing:3px;text-transform:uppercase;margin-bottom:var(--spacing-sm)}.ph-rank-icon{margin-bottom:var(--spacing-sm)}.ph-rank-title{font-family:var(--font-family);font-weight:900;font-size:var(--font-size-xl);letter-spacing:3px;text-transform:uppercase;text-shadow:0 0 20px currentColor}.ph-rank-desc{font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-xs);font-style:italic}.ph-rank-owner{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-sm)}.ph-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.ph-stat-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-radius:var(--radius-md);padding:var(--spacing-sm);text-align:center;transition:all var(--transition-base)}.ph-stat-card:hover{border-color:var(--color-primary);box-shadow:0 0 10px var(--color-primary-glow)}.ph-stat-icon{color:var(--color-text-muted);margin-bottom:2px}.ph-stat-value{font-family:var(--font-family);font-weight:900;font-size:var(--font-size-lg);color:var(--color-text-primary)}.ph-stat-bonus{color:var(--color-primary);text-shadow:0 0 8px var(--color-primary-glow)}.ph-stat-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:2px}.ph-titles-section{margin-bottom:var(--spacing-md)}.ph-section-title{font-family:var(--font-family);font-weight:900;font-size:var(--font-size-sm);color:var(--color-secondary-light);letter-spacing:3px;text-transform:uppercase;margin-bottom:var(--spacing-md);text-shadow:0 0 10px var(--color-secondary-glow);display:flex;align-items:center;gap:var(--spacing-sm)}.ph-titles-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.ph-title-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base, var(--spacing-sm));background:var(--color-bg-elevated);border:1px solid;border-radius:var(--radius-sm);transition:all var(--transition-base)}.ph-title-badge:hover{background:var(--color-bg-glass);transform:translateY(-1px)}.ph-title-badge-icon{flex-shrink:0}.ph-title-badge-info{min-width:0}.ph-title-badge-name{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:11px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ph-title-badge-rarity{font-size:9px;font-weight:var(--font-weight-medium);opacity:.7;text-transform:uppercase;letter-spacing:1px}.ph-bonus-breakdown{background:var(--color-bg-elevated);border:1px solid rgba(238,255,0,.2);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.ph-bonus-title{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);color:var(--color-primary);letter-spacing:2px;margin-bottom:var(--spacing-sm);text-shadow:0 0 8px var(--color-primary-glow);display:flex;align-items:center;gap:var(--spacing-xs)}.ph-bonus-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.ph-bonus-row span{display:flex;align-items:center;gap:4px}.ph-bonus-pts{color:var(--color-success);font-weight:var(--font-weight-bold)}.ph-bonus-total{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-sm);margin-top:var(--spacing-sm);border-top:1px solid var(--color-border-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text-primary)}.ph-bonus-total-value{color:var(--color-primary);font-size:var(--font-size-lg);text-shadow:0 0 12px var(--color-primary-glow)}.ph-detail-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.ph-detail-stat{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--color-bg-glass);border:1px solid var(--color-border-primary);border-radius:var(--radius-full);font-size:11px;color:var(--color-text-secondary)}.ph-timeline{position:relative;padding-left:24px}.ph-event{position:relative;margin-bottom:var(--spacing-md);animation:ph-eventSlide .4s ease-out both}.ph-event:nth-child(1){animation-delay:.05s}.ph-event:nth-child(2){animation-delay:.1s}.ph-event:nth-child(3){animation-delay:.15s}.ph-event:nth-child(4){animation-delay:.2s}.ph-event:nth-child(5){animation-delay:.25s}.ph-event:nth-child(6){animation-delay:.3s}.ph-event:nth-child(7){animation-delay:.35s}.ph-event:nth-child(8){animation-delay:.4s}@keyframes ph-eventSlide{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.ph-event-line{position:absolute;left:-16px;top:0;bottom:-16px;width:2px;background:linear-gradient(to bottom,var(--event-color, #333),rgba(51,51,51,.3))}.ph-event:last-child .ph-event-line{display:none}.ph-event-dot{position:absolute;left:-20px;top:8px;width:10px;height:10px;border-radius:50%;background:var(--event-color, #333);box-shadow:0 0 8px var(--event-color, transparent)}.ph-event-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-left:3px solid var(--event-color, #333);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-base)}.ph-event-card:hover{border-color:var(--event-color, #333);box-shadow:0 0 10px color-mix(in srgb,var(--event-color, #333) 30%,transparent)}.ph-event-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:4px}.ph-event-icon{display:flex;align-items:center}.ph-event-title{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--event-color, var(--color-text-primary))}.ph-event-pts{margin-left:auto;font-family:var(--font-family);font-weight:900;font-size:var(--font-size-xs);padding:2px 6px;border-radius:var(--radius-sm)}.ph-event-pts.positive{color:var(--color-success);background:#00ff881a}.ph-event-pts.negative{color:var(--color-danger);background:#ff00551a}.ph-event-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.4}.ph-event-date{font-size:10px;color:var(--color-text-muted);margin-top:4px}.ph-event-actor{font-size:10px;color:var(--color-danger);font-style:italic;margin-top:2px}.ph-empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted);font-size:var(--font-size-sm)}.ph-empty-icon{margin-bottom:var(--spacing-md);opacity:.5}@media(max-width:768px){.pee-history-modal{width:100vw;max-width:100vw;min-height:100vh;border-radius:0}.ph-header{padding-top:var(--spacing-2xl)}.ph-close-btn{padding-top:var(--spacing-xl)}.ph-stats-grid{grid-template-columns:repeat(2,1fr)}.ph-stat-value{font-size:var(--font-size-base)}.ph-titles-grid{grid-template-columns:1fr}}.report-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);animation:reportFadeIn .2s ease-out}@keyframes reportFadeIn{0%{opacity:0}to{opacity:1}}.report-modal{background:var(--color-bg-secondary);border:1px solid var(--color-danger);border-radius:var(--radius-lg);width:100%;max-width:360px;padding:var(--spacing-lg);box-shadow:0 4px 30px var(--color-danger-glow);animation:reportSlideUp .2s ease-out}@keyframes reportSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.report-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-danger)}.report-header-icon{font-size:20px}.report-close{margin-left:auto;background:none;border:none;color:var(--color-text-secondary);font-size:22px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-base)}.report-close:hover{color:var(--color-text-primary);background:#ffffff1a}.report-reasons{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.report-reason-btn{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);text-align:left}.report-reason-btn:hover:not(:disabled){border-color:var(--color-danger);background:#ff00551a}.report-reason-btn.selected{border-color:var(--color-danger);background:#ff005526;box-shadow:0 0 8px var(--color-danger-glow)}.report-reason-btn:disabled{opacity:.5;cursor:not-allowed}.reason-icon{font-size:18px;flex-shrink:0}.reason-label{font-weight:var(--font-weight-medium)}.report-description{width:100%;padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);resize:none;outline:none;transition:border-color var(--transition-base)}.report-description:focus{border-color:var(--color-danger)}.report-description:disabled{opacity:.5}.report-char-count{text-align:right;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:4px;margin-bottom:var(--spacing-md)}.report-submit{width:100%;padding:var(--spacing-md);background:var(--color-danger);border:none;border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-base)}.report-submit:hover:not(:disabled){box-shadow:0 4px 16px var(--color-danger-glow);transform:translateY(-1px)}.report-submit:disabled{opacity:.4;cursor:not-allowed}.report-result{padding:var(--spacing-lg);border-radius:var(--radius-sm);font-size:var(--font-size-sm);text-align:center;line-height:1.5}.report-result.success{background:#00ff881a;border:1px solid var(--color-success);color:var(--color-success)}.report-result.duplicate{background:#ffaa001a;border:1px solid var(--color-warning);color:var(--color-warning)}.report-result.error{background:#ff00551a;border:1px solid var(--color-danger);color:var(--color-danger)}.pee-banner{position:absolute;bottom:90px;max-width:440px;left:50%;transform:translate(-50%);width:calc(100% - var(--spacing-lg) * 2);display:flex;align-items:center;gap:var(--spacing-sm);background:#0a0a0ef2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) var(--spacing-xs);color:var(--color-text-primary);z-index:var(--z-dropdown);cursor:pointer;overflow:hidden;box-shadow:var(--shadow-xl),0 0 0 1px #ffffff0f;animation:bannerSlideUp .35s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent;touch-action:manipulation}@keyframes bannerSlideUp{0%{transform:translate(-50%) translateY(30px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.pee-banner:active{transform:translate(-50%) scale(.985)}.pee-banner-accent{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:var(--radius-md) 0 0 var(--radius-md)}.pee-banner-accent.free{background:linear-gradient(180deg,var(--color-info),#0080ff)}.pee-banner-accent.strategic{background:linear-gradient(180deg,var(--color-warning),#ff4400)}.pee-banner-photo{width:56px;height:56px;min-width:56px;border-radius:var(--radius-sm);overflow:hidden;background:#ffffff0d;margin-left:var(--spacing-sm)}.pee-banner-photo-img{width:100%;height:100%;object-fit:cover}.pee-banner-photo-loading{width:100%;height:100%;background:linear-gradient(90deg,#ffffff08 25%,#ffffff14,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pee-banner-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);background:#ffffff0a}.pee-banner-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.pee-banner-title{display:flex;align-items:center;gap:var(--spacing-xs)}.pee-banner-emoji{font-size:var(--font-size-sm)}.pee-banner-type{font-size:13px;font-weight:var(--font-weight-bold);font-family:var(--font-family);white-space:nowrap}.pee-banner-hp{display:flex;align-items:center;margin-left:var(--spacing-xs)}.pee-banner-hp .cp-heart{font-size:11px;margin-right:1px}.pee-banner-author{display:flex;align-items:center;gap:var(--spacing-xs);font-size:11px;color:var(--color-text-muted)}.pee-banner-you{color:var(--color-primary);font-weight:600;font-size:10px}.pee-banner-clan{background:#667eea4d;color:#8da4ef;font-size:9px;font-weight:var(--font-weight-bold);padding:1px 5px;border-radius:var(--spacing-xs);letter-spacing:.5px}.pee-banner-meta{display:flex;align-items:center;gap:var(--spacing-sm);font-size:11px}.pee-banner-distance{display:flex;align-items:center;gap:2px;color:var(--color-text-muted)}.pee-banner-distance.close{color:var(--color-success);font-weight:600}.pee-banner-distance.mid{color:var(--color-warning)}.pee-banner-pts{color:var(--color-primary);font-weight:var(--font-weight-bold);font-size:11px;text-shadow:0 0 6px var(--color-primary-glow)}.pee-banner-right{display:flex;align-items:center;justify-content:left;min-width:44px}.pee-banner-action{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:10px;font-weight:var(--font-weight-bold);font-family:var(--font-family);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent}.banner-action-attack{background:linear-gradient(135deg,#ff00554d,#ff44004d);color:var(--color-danger);border:1px solid rgba(255,0,85,.4)}.banner-action-attack:active{transform:scale(.92)}.banner-action-fusion{background:linear-gradient(135deg,#0f83,#00c8ff33);color:var(--color-success);border:1px solid rgba(0,255,136,.3)}.banner-action-cooldown{background:#3c3c3c80;color:var(--color-danger);border:1px solid rgba(255,0,85,.2);opacity:.7;font-family:monospace;font-size:var(--font-size-xs)}.pee-banner-chevron{color:var(--color-text-muted);opacity:.5}.pee-banner-close{position:absolute;top:0;right:-3px;width:35px;height:35px;display:flex;justify-content:right;align-items:center;padding-right:10px;color:var(--color-text-muted);opacity:.5;border-radius:var(--radius-full);-webkit-tap-highlight-color:transparent}.pee-detail-overlay{position:fixed;inset:0;background:var(--color-bg-primary);z-index:100;display:flex;flex-direction:column;color:var(--color-text-primary);animation:detailSlideIn var(--transition-slow) ease-out}@keyframes detailSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.pee-detail-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);padding-top:var(--spacing-2xl);background:#0a0a0efa;border-bottom:1px solid rgba(255,255,255,.06);min-height:52px}.pee-detail-back{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;padding:6px var(--spacing-sm);border-radius:var(--radius-sm)}.pee-detail-back:active{background:#eeff001a}.pee-detail-header-title{font-size:15px;font-weight:var(--font-weight-bold);font-family:var(--font-family)}.pee-detail-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-full);-webkit-tap-highlight-color:transparent}.pee-detail-close:active{background:#ffffff1a}.pee-detail-content{flex:1;overflow-y:auto;padding:0 0 100px;-webkit-overflow-scrolling:touch}.pee-detail-photo{position:relative;width:100%;aspect-ratio:4/3;background:#ffffff08;cursor:pointer;overflow:hidden}.pee-detail-photo-img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.pee-detail-photo:active .pee-detail-photo-img{transform:scale(1.02)}.pee-detail-photo-loading,.pee-detail-photo-error{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.pee-detail-photo-zoom-hint{position:absolute;bottom:var(--spacing-sm);right:var(--spacing-sm);background:#000000b3;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-lg);font-size:11px;color:#ffffffb3;pointer-events:none}.pee-detail-section{padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.04)}.pee-detail-section-title{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm)}.pee-detail-author-section{background:#ffffff05}.pee-detail-author-row{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary)}.pee-detail-author-name{font-size:15px;font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.pee-detail-you{font-size:11px;color:var(--color-primary);background:#eeff001a;padding:2px var(--spacing-sm);border-radius:var(--radius-sm);font-weight:var(--font-weight-bold)}.pee-detail-clan-badge{font-size:11px;color:#8da4ef;margin-top:2px}.pee-detail-comment{font-size:var(--font-size-sm);font-style:italic;color:var(--color-text-secondary);line-height:1.5}.pee-detail-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-sm);padding:var(--spacing-md)}.pee-detail-stat-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:center}.pee-detail-stat-value{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);font-size:15px;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.pee-detail-stat-value.close{color:var(--color-success)}.stat-icon-health{color:var(--color-danger)}.pee-detail-stat-card.bonus .pee-detail-stat-value{color:var(--color-primary);text-shadow:var(--text-shadow-neon)}.pee-detail-stat-label{font-size:10px;color:var(--color-text-muted);margin-top:var(--spacing-xs);text-transform:uppercase;letter-spacing:.5px}.pee-detail-action-section{background:#ff98000f;border-left:3px solid var(--color-warning)}.pee-detail-action-type{font-size:var(--font-size-sm);font-weight:600}.pee-detail-territory-name{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.pee-detail-points-section{background:#eeff000a;border-left:3px solid var(--color-primary)}.pee-detail-points-value{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-primary);text-shadow:0 0 12px var(--color-primary-glow)}.pee-detail-points-bonus{font-size:var(--font-size-xs);color:var(--color-warning);margin-top:var(--spacing-xs)}.pee-detail-points-distance{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:6px;padding:6px var(--spacing-sm);background:#ffffff08;border-radius:6px}.pee-detail-admin{background:#ff00550f;color:var(--color-danger);font-size:var(--font-size-xs);font-family:monospace;border-left:3px solid var(--color-danger)}.pee-detail-merged-gallery{display:flex;gap:var(--spacing-sm);overflow-x:auto;padding-bottom:var(--spacing-xs)}.pee-detail-merged-thumb{width:64px;height:64px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid rgba(0,255,136,.3);cursor:pointer;flex-shrink:0;transition:transform var(--transition-fast)}.pee-detail-merged-thumb:active{transform:scale(1.08)}.pee-detail-merged-thumb.loading{background:#ffffff0d;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--color-text-muted)}.pee-detail-merged-thumb.error{background:#ff00551a;border-color:var(--color-danger);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--color-danger)}.pee-detail-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.pee-detail-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;text-transform:uppercase;letter-spacing:1.5px;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.pee-detail-btn:active:not(.disabled){transform:scale(.97)}.pee-detail-btn.attack{background:linear-gradient(135deg,var(--color-danger),#FF6600);color:var(--color-text-primary);box-shadow:0 0 20px var(--color-danger-glow)}.pee-detail-btn.attack.disabled{background:linear-gradient(135deg,#333,#444);color:var(--color-danger);box-shadow:none;opacity:.7;cursor:not-allowed}.pee-detail-btn.history{background:#6a0dad33;border:2px solid var(--color-secondary);color:var(--color-secondary-light)}.pee-detail-btn.report{background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--color-text-muted);font-size:var(--font-size-xs);padding:var(--spacing-sm)}.pee-detail-btn.report:active{color:var(--color-danger);border-color:var(--color-danger)}.pee-detail-btn.delete{background:var(--color-danger);color:var(--color-text-primary)}.pee-detail-btn.delete.disabled{background:#666;opacity:.6;cursor:not-allowed}.cp-heart{font-size:var(--font-size-sm);margin-right:1px}@media(min-width:768px){.pee-detail-overlay{max-width:500px;left:50%;transform:translate(-50%);border-left:1px solid rgba(255,255,255,.06);border-right:1px solid rgba(255,255,255,.06)}@keyframes detailSlideIn{0%{transform:translate(-50%) translate(100%)}to{transform:translate(-50%)}}}.custom-map-controls{position:absolute;top:16px;right:12px;display:flex;flex-direction:column;gap:2px;z-index:999;background:#0a0a0ebf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:14px;padding:4px;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 20px #0006}.map-ctrl-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:#ffffffd9;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;touch-action:manipulation}.map-ctrl-btn:active{background:#ffffff1f;transform:scale(.92)}@media(hover:hover){.map-ctrl-btn:hover{background:#ffffff14;color:#fff}}.map-ctrl-btn.disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.map-ctrl-btn.locate.active{color:#fff34d}.map-ctrl-btn.locate.active:active{background:#4da6ff26}.map-ctrl-divider{height:1px;margin:2px 8px;background:#ffffff14}@media(max-width:768px){.custom-map-controls{top:25px;right:10px}.map-ctrl-btn{width:38px;height:38px}}.map-action-bar{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);z-index:900;display:flex;gap:var(--spacing-sm)}.map-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:76px;height:76px;border-radius:var(--radius-lg);background:var(--color-bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(238,255,0,.25);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 16px #0006;-webkit-tap-highlight-color:transparent;touch-action:manipulation;padding:var(--spacing-xs)}.map-action-btn:hover{border-color:var(--color-primary);box-shadow:0 4px 20px var(--color-primary-glow);transform:translateY(-2px)}.map-action-btn:active{transform:scale(.95)}.map-action-btn.strategic{border-color:#fff007bf}.map-action-btn.strategic:hover{border-color:var(--color-secondary);box-shadow:0 4px 20px var(--color-secondary-glow)}.map-action-btn.strategic.cooldown{opacity:.5;cursor:not-allowed}.map-action-btn.strategic.cooldown:hover{transform:none;box-shadow:0 4px 16px #0006}.map-action-btn.free{border-color:#eeff00bf}.map-action-btn-wrapper{position:relative}.map-action-btn.filter{border-color:#b8b8b8f3}.map-action-btn.filter.active{background:linear-gradient(135deg,#667eea4d,#764ba24d);border-color:#667eea;box-shadow:0 0 15px #667eea66}.map-action-filter-icon{filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));color:var(--color-text-secondary)}.map-action-btn.filter.active .map-action-filter-icon{color:#667eea}.filter-menu-overlay{position:fixed;inset:0;z-index:899}.filter-menu{position:absolute;bottom:calc(100% + 8px);right:0;background:var(--color-bg-glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-xs);min-width:160px;z-index:901;box-shadow:0 8px 32px #00000080}.filter-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);transition:background .15s ease}.filter-menu-item:active{background:#ffffff14}.filter-menu-back{opacity:.7;font-size:var(--font-size-xs);padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:2px}.filter-menu-empty{opacity:.4;font-style:italic;cursor:default}.filter-menu{max-height:300px;overflow-y:auto}.filter-checkbox{width:18px;height:18px;border-radius:4px;border:2px solid rgba(255,255,255,.3);flex-shrink:0;transition:all .15s ease}.filter-checkbox.checked{background:var(--color-primary);border-color:var(--color-primary)}.map-action-icon{width:36px;height:36px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}.map-action-emoji{font-size:28px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}.map-action-label{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:10px;color:var(--color-text-secondary);text-align:center;line-height:1.1;white-space:nowrap}.map-action-label.cooldown-label{display:flex;align-items:center;gap:3px;color:var(--color-danger);text-shadow:0 0 6px var(--color-danger-glow)}@media(max-width:768px){.map-action-btn{width:70px;height:70px}.map-action-icon{width:32px;height:32px}.map-action-emoji{font-size:24px}.map-action-label{font-size:9px}}.modal-overlay{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--spacing-lg);animation:fadeIn .2s ease-out}.add-pee-modal{background:var(--color-bg-elevated);border:2px solid var(--color-primary);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 0 40px #ef06,0 10px 50px #00000080;animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid rgba(238,255,0,.2)}.modal-title{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);color:var(--color-primary);text-shadow:var(--text-shadow-neon);margin:0}.modal-close-btn{width:32px;height:32px;background:transparent;border:1px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-size-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent}.modal-close-btn:hover{background:var(--color-primary);color:#000;transform:scale(1.1)}.modal-content{padding:var(--spacing-lg)}.modal-error{padding:var(--spacing-md);background:var(--color-danger);color:#fff;border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);text-align:center;border:1px solid rgba(255,0,85,.5);box-shadow:0 0 15px #ff00554d;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.step-camera{text-align:center;padding:var(--spacing-xl) 0}.camera-icon{font-size:5rem;margin-bottom:var(--spacing-lg);filter:drop-shadow(0 0 20px rgba(238,255,0,.6));animation:pulse-camera 2s ease-in-out infinite}@keyframes pulse-camera{0%,to{transform:scale(1);filter:drop-shadow(0 0 20px rgba(238,255,0,.6))}50%{transform:scale(1.1);filter:drop-shadow(0 0 30px rgba(238,255,0,.8))}}.camera-text{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.btn-primary,.btn-secondary{width:100%;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);border:2px solid transparent;margin-top:var(--spacing-md);-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--color-primary);color:#000;border-color:var(--color-primary);box-shadow:0 0 20px #ef06}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 0 30px #ef09}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-text-primary);border-color:#ffffff4d}.btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.btn-full{margin-top:var(--spacing-lg)}.submit-clan-choice{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.btn-half{width:100%;margin-top:0;font-size:var(--font-size-sm);padding:var(--spacing-md) var(--spacing-sm)}.btn-clan{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 0 20px #667eea66;color:#fff}.btn-clan:hover{box-shadow:0 0 30px #667eea99}.step-preview{text-align:center}.photo-preview{margin-bottom:var(--spacing-lg);border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--color-primary);box-shadow:0 0 30px #ef06}.preview-image{width:100%;height:auto;display:block}.preview-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.step-comment{animation:fadeIn .3s ease-out}.comment-photo-thumb{width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--color-primary);margin:0 auto var(--spacing-lg)}.comment-photo-thumb img{width:100%;height:100%;object-fit:cover}.form-label{display:block;font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-primary);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.form-textarea{width:100%;padding:var(--spacing-md);background:var(--color-bg-primary);border:2px solid rgba(238,255,0,.3);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);resize:vertical;min-height:100px;outline:none;transition:all var(--transition-base)}.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #ef03}.form-textarea::placeholder{color:var(--color-text-muted)}.char-count{text-align:right;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.points-preview{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:var(--spacing-md);background:#00ff881a;border:1px solid rgba(0,255,136,.3);border-radius:var(--radius-md);margin-top:var(--spacing-md)}.points-preview.attack{background:#ff00551a;border-color:#f056}.points-preview.attack .points-preview-value{color:#f05;text-shadow:0 0 10px rgba(255,0,85,.6)}.points-preview-value{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);color:#0f8;text-shadow:0 0 8px rgba(0,255,136,.5)}.points-preview-detail{font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.points-preview-warning{font-family:var(--font-family);font-size:var(--font-size-xs);color:#ff9800;font-style:italic}.points-preview-loading{font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-muted);animation:pulse-text 1.5s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:.5}50%{opacity:1}}.step-loading{text-align:center;padding:var(--spacing-xl) 0}.loading-spinner{width:60px;height:60px;border:4px solid rgba(238,255,0,.2);border-top-color:var(--color-primary);border-radius:50%;margin:0 auto var(--spacing-lg);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.step-loading p{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-secondary)}@media(max-width:768px){.modal-overlay{padding:0}.add-pee-modal{max-width:100%;max-height:100vh;border-radius:0;border-left:none;border-right:none}.camera-icon{font-size:4rem}.modal-header,.modal-content{padding:var(--spacing-md)}}.admin-cheat-panel{position:absolute;z-index:9999;background:#0a0a0afa;border:2px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:0 2px 10px var(--color-primary-glow);min-width:220px;max-width:260px;font-family:var(--font-family);-webkit-user-select:none;user-select:none;font-size:var(--font-size-xs);touch-action:none;transition:opacity .2s ease,background-color .2s ease}.admin-cheat-panel.joystick-moving{opacity:.15;pointer-events:none}.admin-cheat-panel.collapsed{min-width:auto}.admin-cheat-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:move;-webkit-user-select:none;user-select:none;touch-action:none}.admin-cheat-title{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:.3px}.admin-cheat-icon{font-size:16px}.cheat-active-badge{background:#0f83;border:1px solid var(--color-success);padding:2px var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-success);animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.admin-cheat-collapse-btn{background:#fff3;border:none;color:var(--color-text-primary);width:36px;height:36px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);transition:all var(--transition-base)}.admin-cheat-collapse-btn:hover{background:#ffffff4d;transform:scale(1.1)}.admin-cheat-content{padding:var(--spacing-sm);max-height:500px;overflow-y:auto;color:var(--color-text-primary)}.cheat-section{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.1)}.cheat-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.cheat-section-title{font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-sm);color:var(--color-primary);font-size:var(--font-size-xs)}.cheat-toggle-btn{width:100%;padding:var(--spacing-sm);background:linear-gradient(135deg,var(--color-bg-elevated) 0%,var(--color-border-primary) 100%);border:2px solid var(--color-border-primary);border-radius:var(--radius-sm);color:var(--color-text-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-slow)}.cheat-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--color-primary-glow)}.cheat-toggle-btn.active{background:linear-gradient(135deg,var(--color-success) 0%,#009944 100%);border-color:var(--color-success);box-shadow:var(--glow-success)}.joystick-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.joystick-base{width:110px;height:110px;background:radial-gradient(circle,var(--color-bg-elevated) 0%,var(--color-bg-secondary) 100%);border:2px solid var(--color-border-primary);border-radius:var(--radius-full);position:relative;cursor:pointer;box-shadow:inset 0 0 15px #00000080;touch-action:none}.joystick-stick{position:absolute;width:40px;height:40px;background:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-full);top:50%;left:50%;margin-top:-20px;margin-left:-20px;transition:box-shadow var(--transition-base);box-shadow:0 3px 8px var(--color-primary-glow);touch-action:none;pointer-events:none}.joystick-stick.active{background:var(--color-primary-dark);box-shadow:var(--glow-primary)}.joystick-info{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center}.speed-slider{width:100%;height:8px;background:var(--color-border-primary);border-radius:var(--radius-sm);outline:none;-webkit-appearance:none;appearance:none;margin-bottom:var(--spacing-md)}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:linear-gradient(135deg,var(--color-danger) 0%,#cc0052 100%);border:2px solid var(--color-danger);border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--glow-danger)}.speed-slider::-moz-range-thumb{width:24px;height:24px;background:linear-gradient(135deg,var(--color-danger) 0%,#cc0052 100%);border:2px solid var(--color-danger);border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--glow-danger)}.speed-slider:disabled{opacity:.3;cursor:not-allowed}.speed-presets{display:flex;gap:var(--spacing-sm)}.speed-presets button{flex:1;padding:8px var(--spacing-sm);background:var(--color-border-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-base)}.speed-presets button:hover:not(:disabled){background:var(--color-bg-elevated);border-color:var(--color-danger)}.speed-presets button:disabled{opacity:.3;cursor:not-allowed}.teleport-inputs{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.teleport-inputs input{padding:8px var(--spacing-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-xs);outline:none}.teleport-inputs input:focus{border-color:var(--color-danger);box-shadow:0 0 8px var(--color-danger-glow)}.teleport-inputs input:disabled{opacity:.3;cursor:not-allowed}.teleport-buttons{display:flex;gap:var(--spacing-sm);flex-direction:column}.teleport-buttons button{padding:8px var(--spacing-sm);background:var(--color-border-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.teleport-buttons button:hover:not(:disabled){background:var(--color-bg-elevated);transform:translateY(-1px)}.teleport-buttons button:disabled{opacity:.3;cursor:not-allowed}.teleport-btn{background:linear-gradient(135deg,var(--color-danger) 0%,#cc0052 100%)!important;border-color:var(--color-danger)!important;font-weight:var(--font-weight-bold)!important}.teleport-btn:hover:not(:disabled){box-shadow:0 4px 12px var(--color-danger-glow)}.current-position{background:var(--color-bg-elevated);padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);line-height:1.4;color:var(--color-text-secondary);font-family:Courier New,monospace}.admin-cheat-content::-webkit-scrollbar{width:8px}.admin-cheat-content::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:var(--radius-sm)}.admin-cheat-content::-webkit-scrollbar-thumb{background:var(--color-danger);border-radius:var(--radius-sm)}.admin-cheat-content::-webkit-scrollbar-thumb:hover{background:var(--color-danger);box-shadow:var(--glow-danger)}@media(max-width:768px){.admin-cheat-panel{max-width:90vw}.joystick-base{width:120px;height:120px}.joystick-stick{width:44px;height:44px;margin-top:-22px;margin-left:-22px}}.gallery-panel{position:absolute;bottom:0;left:0;right:0;height:70%;background:var(--color-bg-primary);border-top-left-radius:20px;border-top-right-radius:20px;border-top:2px solid var(--color-primary);z-index:950;display:flex;flex-direction:column;animation:gallery-slide-up .3s ease-out;will-change:transform}@keyframes gallery-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.gallery-panel-pill{width:40px;height:4px;border-radius:2px;background:var(--color-text-muted);margin:var(--spacing-sm) auto 0;opacity:.5}.gallery-panel-header{display:flex;flex-direction:column;padding:0 var(--spacing-lg) var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0;touch-action:none;cursor:grab}.gallery-panel-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.gallery-panel-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);flex:1}.gallery-panel-close,.gallery-panel-back{width:32px;height:32px;border-radius:50%;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-secondary);flex-shrink:0}.gallery-panel-content{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.gallery-panel-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);font-size:var(--font-size-sm)}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.gallery-thumb{aspect-ratio:1;overflow:hidden;border-radius:4px;cursor:pointer;background:var(--color-bg-elevated)}.gallery-thumb img{width:100%;height:100%;object-fit:cover}.gallery-thumb:active{opacity:.7}.gallery-thumb-loading{width:100%;height:100%;background:var(--color-bg-elevated);animation:gallery-pulse 1.2s ease-in-out infinite}@keyframes gallery-pulse{0%,to{opacity:.4}50%{opacity:.8}}.gallery-thumb-error,.gallery-thumb-placeholder{width:100%;height:100%;background:var(--color-bg-elevated)}.gallery-carousel{position:relative;width:100%;height:100%;overflow:hidden;touch-action:pan-y}.carousel-track{display:flex;width:100%;height:100%;will-change:transform}.carousel-slide{flex:0 0 100%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.carousel-slide-prev{margin-left:-100%}.carousel-slide-current,.carousel-slide-next{position:relative}.carousel-slide-img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.carousel-main-img{touch-action:none;transition:transform .15s ease}.carousel-main-img.zoomed{cursor:grab;transition:none}.carousel-slide-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.gallery-inline-viewer{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.gallery-viewer-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.gallery-inline-img{flex:1;height:100%;object-fit:contain;touch-action:none;transition:transform .15s ease;border-radius:var(--radius-sm)}.gallery-inline-img.dragging{transition:none;cursor:grabbing}.gallery-inline-img.zoomed{cursor:grab}.gallery-inline-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;flex-shrink:0;border-top:1px solid var(--color-border)}.gallery-ctrl-btn{width:40px;height:40px;border-radius:var(--radius-md);border:2px solid var(--color-primary);background:var(--color-bg-elevated);color:var(--color-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.gallery-ctrl-btn.reset{width:auto;padding:0 var(--spacing-md);font-size:var(--font-size-xs)}.gallery-ctrl-btn:active{background:var(--color-primary);color:var(--color-bg-primary)}.gallery-zoom-label{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);min-width:60px;text-align:center}.gallery-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;color:#fff;cursor:pointer;z-index:5;-webkit-tap-highlight-color:transparent;transition:background .15s}.gallery-nav-btn:active{background:#000c}.gallery-nav-prev{left:8px}.gallery-nav-next{right:8px}.points-animation-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:10000;pointer-events:none}.points-animation{display:flex;align-items:baseline;gap:6px;animation:floatUp 2.5s ease-out forwards}.points-animation.positive .points-animation-value{color:#0f8;text-shadow:0 0 20px rgba(0,255,136,.8),0 0 40px rgba(0,255,136,.4),0 0 60px rgba(0,255,136,.2)}.points-animation.negative .points-animation-value{color:#f05;text-shadow:0 0 20px rgba(255,0,85,.8),0 0 40px rgba(255,0,85,.4),0 0 60px rgba(255,0,85,.2)}.points-animation-value{font-family:var(--font-family);font-weight:900;font-size:4rem;letter-spacing:2px}.points-animation-label{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:1.5rem;color:#fffc;text-shadow:0 0 10px rgba(255,255,255,.3)}@keyframes floatUp{0%{opacity:0;transform:translateY(40px) scale(.5)}15%{opacity:1;transform:translateY(0) scale(1.2)}30%{transform:translateY(-10px) scale(1)}70%{opacity:1;transform:translateY(-60px) scale(1)}to{opacity:0;transform:translateY(-120px) scale(.8)}}@media(max-width:768px){.points-animation-value{font-size:3rem}.points-animation-label{font-size:1.2rem}}.feed-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.feed-content--drawer{height:100%}.feed-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,0)}.feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;color:var(--color-text-muted);font-family:var(--font-family);text-align:center;padding:var(--spacing-xl);gap:var(--spacing-sm)}.feed-empty-sub{font-size:var(--font-size-sm);opacity:.6}.feed-event-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin:2px 0;border-bottom:1px solid rgba(255,255,255,.06);border-left:3px solid var(--color-primary);background:#ffffff05}.feed-event-icon{color:var(--color-primary);flex-shrink:0}.feed-event-content{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px;flex:1;min-width:0}.feed-event-text{font-size:var(--font-size-sm);color:var(--color-text-primary)}.feed-event-user{font-weight:var(--font-weight-bold)}.feed-event-points{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:var(--font-weight-bold)}.feed-event-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.feed-post{border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:var(--spacing-sm);margin-bottom:2px}.feed-post-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;-webkit-tap-highlight-color:transparent}.feed-post-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid rgba(238,255,0,.3)}.feed-post-avatar img{width:100%;height:100%;object-fit:cover}.feed-post-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#eeff0026;color:var(--color-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm)}.feed-post-user-info{display:flex;flex-direction:column}.feed-post-username{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text-primary);display:flex;align-items:center;gap:4px}.feed-clan-badge{color:#667eea}.feed-post-city{font-size:10px;font-weight:500;color:var(--color-text-muted);background:#ffffff0f;padding:1px 6px;border-radius:8px;margin-left:2px}.feed-post-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.feed-post-photo{position:relative;width:100%;height:280px;overflow:hidden;background:#000;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.feed-post-photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.feed-double-tap-heart{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:heartPop .8s ease-out forwards;pointer-events:none;z-index:10;filter:drop-shadow(0 0 12px rgba(255,45,85,.6))}@keyframes heartPop{0%{transform:translate(-50%,-50%) scale(0) rotate(-10deg);opacity:0}15%{transform:translate(-50%,-50%) scale(1.3) rotate(5deg);opacity:1}30%{transform:translate(-50%,-50%) scale(1) rotate(0);opacity:1}to{transform:translate(-50%,-50%) scale(1.5) rotate(10deg);opacity:0}}.feed-post-reactions{padding:var(--spacing-sm) var(--spacing-md);position:relative}.feed-reaction-pills{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.feed-reaction-pill{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);cursor:pointer;font-size:var(--font-size-sm);transition:all .15s ease;-webkit-tap-highlight-color:transparent}.feed-reaction-pill.active{background:#667eea33;border-color:#667eea80}.feed-reaction-pill:active{transform:scale(.95)}.feed-reaction-pill.just-reacted{animation:emojiPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes emojiPop{0%{transform:scale(1)}50%{transform:scale(1.35) rotate(5deg)}to{transform:scale(1) rotate(0)}}.feed-reaction-count{font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.feed-reaction-add{display:flex;align-items:center;justify-content:center;width:32px;height:28px;border-radius:20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--color-text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s ease}.feed-reaction-add:active{background:#ffffff1f;transform:scale(1.1) rotate(15deg)}.feed-emoji-overlay{position:fixed;inset:0;z-index:98}.feed-emoji-picker{position:absolute;bottom:calc(100% + 4px);right:var(--spacing-md);width:260px;max-height:280px;overflow-y:auto;background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-sm);z-index:99;box-shadow:0 8px 32px #0009;animation:pickerPop .2s cubic-bezier(.34,1.56,.64,1)}@keyframes pickerPop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.feed-emoji-category{margin-bottom:var(--spacing-sm)}.feed-emoji-cat-label{font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-muted);padding:2px 4px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.feed-emoji-grid{display:flex;flex-wrap:wrap;gap:2px}.feed-emoji-item{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent;transition:transform .1s ease}.feed-emoji-item:active{background:#ffffff1a;transform:scale(1.2)}.feed-post-comment{padding:4px var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent}.feed-post-comment.expanded{-webkit-line-clamp:unset;line-clamp:unset;display:block}.feed-comment-user{font-weight:var(--font-weight-bold);color:var(--color-text-secondary);font-size:var(--font-size-xs)}.feed-comment-more{color:var(--color-text-muted);opacity:.5;font-size:var(--font-size-xs);padding:0 var(--spacing-md);cursor:pointer}.feed-lightbox{position:fixed;inset:0;z-index:9999;background:#000000f2;display:flex;align-items:center;justify-content:center;animation:lbFadeIn .2s ease;-webkit-tap-highlight-color:transparent}.feed-lightbox img{max-width:100%;max-height:100%;object-fit:contain}.feed-lightbox-close{position:absolute;top:calc(16px + env(safe-area-inset-top,0px));right:16px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;color:#fff;cursor:pointer}@keyframes lbFadeIn{0%{opacity:0}to{opacity:1}}.feed-post-location{padding:4px var(--spacing-md) 0;font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-muted)}.feed-tab{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:950;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;-webkit-tap-highlight-color:transparent;animation:tabBreathe 3s ease-in-out infinite}.feed-tab-inner{width:28px;height:56px;background:var(--color-bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(238,255,0,.3);border-left:none;border-radius:0 14px 14px 0;display:flex;align-items:center;justify-content:center;color:var(--color-primary);box-shadow:4px 0 16px #0000004d,0 0 12px #eeff001a;transition:all .2s ease}.feed-tab:active .feed-tab-inner{transform:scale(.9);border-color:#ef09;box-shadow:4px 0 20px #eeff004d}.feed-tab-label{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-primary);text-shadow:0 0 6px rgba(238,255,0,.5);writing-mode:horizontal-tb}@keyframes tabBreathe{0%,to{transform:translateY(-50%) translate(0)}50%{transform:translateY(-50%) translate(2px)}}.feed-drawer-backdrop{position:fixed;inset:0;background:#000000b3;z-index:1999;-webkit-tap-highlight-color:transparent}.feed-drawer{position:fixed;top:0;left:0;bottom:0;z-index:2000;background:var(--color-bg-primary);display:flex;flex-direction:column;overflow:hidden;box-shadow:8px 0 32px #0009;will-change:transform;border-right:1px solid rgba(238,255,0,.15)}.feed-drawer-header{flex-shrink:0;padding:var(--spacing-lg) var(--spacing-md) var(--spacing-sm);padding-top:calc(var(--spacing-xl) + env(safe-area-inset-top,0px));background:var(--color-bg-elevated);border-bottom:1px solid rgba(238,255,0,.15);text-align:center;position:relative}.feed-drawer-back{position:absolute;left:var(--spacing-sm);top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff14;color:var(--color-text-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s ease}.feed-drawer-back:active{background:#ffffff26;transform:scale(.92)}.feed-drawer-handle{width:36px;height:4px;border-radius:2px;background:#fff3;margin:0 auto var(--spacing-sm)}.feed-drawer-title{font-family:var(--font-family);font-weight:800;font-size:1.4rem;color:var(--color-primary);text-shadow:var(--text-shadow-neon);margin:0;letter-spacing:1px}.feed-drawer-subtitle{font-size:.7rem;color:var(--color-text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:1.5px}.feed-drawer-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.feed-drawer-edge{position:absolute;right:0;top:50%;transform:translateY(-50%);width:16px;height:80px;display:flex;align-items:center;justify-content:center;z-index:10}.feed-drawer-edge-line{width:3px;height:32px;border-radius:2px;background:#ffffff1f}.feed-drawer--open .feed-post{animation:postFadeIn .3s ease-out backwards}.feed-drawer--open .feed-post:nth-child(1){animation-delay:.05s}.feed-drawer--open .feed-post:nth-child(2){animation-delay:.08s}.feed-drawer--open .feed-post:nth-child(3){animation-delay:.11s}.feed-drawer--open .feed-post:nth-child(4){animation-delay:.14s}.feed-drawer--open .feed-post:nth-child(5){animation-delay:.17s}.feed-drawer--open .feed-post:nth-child(6){animation-delay:.2s}@keyframes postFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.feed-reaction-pill.just-reacted{animation:emojiPop .3s ease-out}@keyframes emojiPop{0%{transform:scale(1)}40%{transform:scale(1.15)}to{transform:scale(1)}}.feed-empty-emoji{width:64px;height:64px;animation:emptyBounce 2s ease-in-out infinite}.feed-empty-emoji img{width:100%;height:100%;object-fit:contain}@keyframes emptyBounce{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-10px) rotate(-5deg)}50%{transform:translateY(0) rotate(0)}75%{transform:translateY(-6px) rotate(5deg)}}.feed-fun-loader{display:flex;gap:6px;justify-content:center;padding:var(--spacing-xl)}.feed-fun-loader-dot{width:10px;height:10px;border-radius:50%;background:var(--color-primary);animation:loaderBounce .6s ease-in-out infinite alternate}.feed-fun-loader-dot:nth-child(2){animation-delay:.15s}.feed-fun-loader-dot:nth-child(3){animation-delay:.3s}@keyframes loaderBounce{0%{transform:translateY(0);opacity:.4}to{transform:translateY(-12px);opacity:1}}.map-controls{position:absolute;top:var(--spacing-base);right:var(--spacing-base);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:1000;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-md)}.map-control-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:50%;color:var(--color-text-primary);font-size:var(--font-size-xl);cursor:pointer;transition:all var(--transition-base);box-shadow:0 0 10px #4caf504d}.map-control-btn:hover{background:rgba(var(--color-primary-rgb),.3);border-color:var(--color-primary);transform:scale(1.1);box-shadow:0 0 20px rgba(var(--color-primary-rgb),.5)}.map-control-btn:active{transform:scale(.95)}.map-control-btn.active{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 0 20px rgba(var(--color-primary-rgb),.6)}.map-control-btn:disabled{opacity:.5;cursor:not-allowed}.user-location-marker{width:16px;height:16px;border-radius:50%;background:#2196f3;border:3px solid white;box-shadow:0 0 6px #2196f3cc;cursor:pointer;animation:pulse-user-location 2s ease-in-out infinite}@keyframes pulse-user-location{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.user-location-accuracy{position:absolute;border-radius:50%;background:#2196f333;border:2px solid rgba(33,150,243,.4);pointer-events:none}.checkpoint-marker{width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-base)}.checkpoint-marker:hover{transform:scale(1.3)}.checkpoint-marker.free{font-size:24px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.checkpoint-marker.strategic{font-size:24px;filter:drop-shadow(0 2px 8px rgba(255,215,0,.8))}.territory-marker{cursor:pointer;transition:transform var(--transition-base)}.territory-marker:hover{transform:scale(1.15)}.map-debug-panel{position:absolute;background:#000000f2;padding:12px 16px;border-radius:var(--radius-md);color:#fff;font-size:.8rem;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);z-index:1000;max-width:320px;min-width:250px;border:2px solid var(--color-primary);box-shadow:0 0 20px #eeff004d;font-family:Courier New,monospace;-webkit-user-select:none;user-select:none;transition:box-shadow .2s ease}.map-debug-panel.dragging{box-shadow:0 0 30px #ef09;cursor:grabbing!important}.map-debug-panel.collapsed{min-width:auto;padding:8px 12px}.debug-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm);gap:var(--spacing-sm)}.map-debug-panel .debug-title{font-weight:700;color:var(--color-primary);font-size:.9rem;text-shadow:0 0 10px rgba(238,255,0,.5);flex:1;-webkit-user-select:none;user-select:none}.debug-collapse-btn{background:transparent;border:1px solid var(--color-primary);color:var(--color-primary);width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .2s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;touch-action:manipulation}.debug-collapse-btn:hover{background:var(--color-primary);color:#000;transform:scale(1.1);box-shadow:0 0 10px #eeff0080}.debug-content{animation:fadeIn .2s ease;-webkit-user-select:text;user-select:text;cursor:text}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.map-debug-panel .debug-item{font-size:.7rem;margin-top:4px;line-height:1.4}.checkpoint-popup{position:absolute;bottom:var(--spacing-xl);left:var(--spacing-base);right:var(--spacing-base);z-index:1001;animation:slide-in-up .3s ease-out}.map-container{width:100%;height:100%;position:relative}.gallery-fab{position:absolute;bottom:100px;right:var(--spacing-md);z-index:900;width:48px;height:48px;border-radius:50%;background:var(--color-bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-secondary);box-shadow:0 4px 16px #0006;transition:all .15s ease}.gallery-fab:active{transform:scale(.9)}.mapboxgl-canvas{outline:none}.mapboxgl-ctrl-group{background:#0009!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)!important;box-shadow:var(--shadow-md)!important}.mapboxgl-ctrl-group button{background:transparent!important;color:var(--color-text-primary)!important}.mapboxgl-ctrl-group button:hover{background:rgba(var(--color-primary-rgb),.2)!important}.mapboxgl-popup-content{background:#000000e6!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-text-primary)!important;border-radius:var(--radius-md)!important;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-lg)!important;padding:var(--spacing-base)!important;font-family:var(--font-family)!important}.mapboxgl-popup-tip{border-top-color:#000000e6!important}.mapboxgl-ctrl-logo{opacity:.3!important;transform:scale(.7)!important;transform-origin:bottom left!important;transition:opacity .2s ease!important}.mapboxgl-ctrl-logo:hover{opacity:.6!important}.mapboxgl-ctrl-attrib{opacity:.3!important;font-size:9px!important;background:#00000080!important;-webkit-backdrop-filter:blur(5px)!important;backdrop-filter:blur(5px)!important;transition:opacity .2s ease!important}.mapboxgl-ctrl-attrib:hover{opacity:.8!important}.mapboxgl-ctrl-attrib-button{opacity:.4!important}.mapboxgl-ctrl-bottom-right{bottom:2px!important;right:2px!important}.mapboxgl-ctrl-bottom-left{bottom:2px!important;left:2px!important}@media(max-width:768px){.map-controls{top:var(--spacing-sm);right:var(--spacing-sm);padding:var(--spacing-sm)}.map-control-btn{width:40px;height:40px;font-size:var(--font-size-lg)}.map-debug-panel{font-size:.7rem;padding:var(--spacing-sm) var(--spacing-md)}}.map-page{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary);color:var(--color-text-primary)}.map-header{padding:var(--spacing-md);background:var(--color-bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-primary);position:relative;z-index:10}.map-title{margin:0;font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl);color:var(--color-primary);text-shadow:var(--text-shadow-neon);display:flex;align-items:center;gap:var(--spacing-sm)}.map-subtitle{margin:var(--spacing-sm) 0 0 0;font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.map-username{color:var(--color-primary);font-weight:var(--font-weight-bold)}.map-container{flex:1;position:relative;overflow:hidden}.gps-error-overlay{position:absolute;inset:0;background:#000000bf;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--spacing-lg)}.gps-error-card{background:var(--color-bg-secondary);border:1px solid var(--color-warning);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;max-width:320px;width:100%;box-shadow:0 4px 30px #ffaa0026}.gps-error-icon{font-size:48px;margin-bottom:var(--spacing-md)}.gps-error-title{margin:0 0 var(--spacing-sm);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-warning)}.gps-error-message{margin:0 0 var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.gps-error-retry{width:100%;padding:var(--spacing-md);background:var(--color-warning);border:none;border-radius:var(--radius-sm);color:#000;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-base)}.gps-error-retry:hover:not(:disabled){box-shadow:0 4px 16px #ffaa004d;transform:translateY(-1px)}.gps-error-retry:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.map-header{padding:var(--spacing-sm);padding-top:30px}.map-title{font-size:var(--font-size-xl)}}.typing-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:var(--font-size-xs);color:var(--color-text-muted);font-style:italic;animation:typing-fade-in .3s ease}.typing-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.typing-dots{display:inline-flex;gap:3px;align-items:center}.typing-dots .dot{width:5px;height:5px;border-radius:50%;background:var(--color-primary);animation:dot-bounce 1.4s ease-in-out infinite}.typing-dots .dot:nth-child(2){animation-delay:.2s}.typing-dots .dot:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}@keyframes typing-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.emoji-picker-overlay{position:fixed;inset:0;z-index:90}.emoji-picker{overflow:hidden;position:absolute;bottom:100%;left:var(--spacing-md);right:var(--spacing-md);margin-bottom:8px;background:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-sm);z-index:100;animation:emoji-slide-up .2s ease;box-shadow:0 -4px 20px #0006}.emoji-picker-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:4px;padding:4px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.emoji-picker-grid::-webkit-scrollbar{display:none}.emoji-picker-item{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:44px;height:44px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;padding:2px}.emoji-picker-item:hover{background:var(--color-bg-elevated);border-color:var(--color-primary);transform:scale(1.15)}.emoji-picker-item:active{transform:scale(.9)}.emoji-picker-img{width:38px;height:38px;object-fit:contain}.chat-emoji-inline{display:inline-block;width:20px;height:20px;vertical-align:middle;object-fit:contain;margin:0 1px}@keyframes emoji-slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.context-menu-overlay{position:fixed;inset:0;z-index:200}.context-menu{position:fixed;z-index:210;background:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:6px;min-width:180px;box-shadow:0 4px 24px #00000080;animation:context-menu-pop .15s ease}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);cursor:pointer;transition:background .15s ease;text-align:left}.context-menu-item:hover{background:var(--color-bg-elevated)}.context-menu-item.danger{color:var(--color-danger)}.context-menu-item.danger:hover{background:#ff44441a}.context-menu-icon{font-size:16px;flex-shrink:0}@keyframes context-menu-pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.chat-page{display:flex;flex-direction:column;width:100%;height:100%;overflow-x:hidden;background:var(--color-bg-primary);color:var(--color-text-primary)}.chat-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-primary);z-index:10;flex-shrink:0}.chat-tabs{display:flex;gap:var(--spacing-xs)}.chat-tab{padding:6px 16px;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.chat-tab:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.chat-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#000;font-weight:var(--font-weight-bold)}.chat-tab:disabled{opacity:.4;cursor:not-allowed}.chat-messages-viewport{flex:1;position:relative;overflow:hidden}.chat-messages-inner{width:100%;height:100%}.chat-messages{height:100%;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.chat-loading,.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);font-size:var(--font-size-sm)}.chat-loading-more{text-align:center;padding:var(--spacing-sm);color:var(--color-text-muted);font-size:var(--font-size-xs)}.chat-new-msgs-btn{position:absolute;bottom:70px;left:50%;transform:translate(-50%);background:var(--color-primary);color:var(--color-bg-primary);padding:6px 16px;border-radius:20px;font-size:var(--font-size-xs);font-weight:700;cursor:pointer;z-index:20;box-shadow:var(--shadow-md);animation:chatNewMsgSlideUp .2s ease-out;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.chat-new-msgs-btn:active{transform:translate(-50%) scale(.95)}@keyframes chatNewMsgSlideUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.chat-date-separator{display:flex;align-items:center;justify-content:center;margin:var(--spacing-md) 0 var(--spacing-sm)}.chat-date-separator span{background:var(--color-bg-elevated);color:var(--color-text-muted);font-size:var(--font-size-xs);padding:4px 12px;border-radius:var(--radius-full)}.chat-message{display:flex;gap:var(--spacing-sm);max-width:80%;align-self:flex-start;animation:message-slide-in .25s ease;user-select:none;-webkit-user-select:none}.chat-message.own{align-self:flex-start}.chat-message.grouped{margin-top:-4px}.chat-message.deleted{opacity:.6}@keyframes message-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-avatar{width:32px;height:32px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-primary)}.chat-avatar.clickable{cursor:pointer;transition:transform .15s ease}.chat-avatar.clickable:active{transform:scale(.9)}.chat-avatar img{width:100%;height:100%;object-fit:cover}.chat-bubble{background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:12px 12px 12px 4px;padding:8px 12px;min-width:60px}.chat-message.own .chat-bubble{background:#00ff881f;border-color:#0f83;border-radius:12px 12px 12px 4px}.chat-avatar-spacer{width:32px;flex-shrink:0}.chat-sender-row{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.chat-sender{font-size:11px;font-weight:var(--font-weight-bold);color:var(--color-primary)}.chat-sender-you{font-size:10px;font-weight:var(--font-weight-normal, 400);color:var(--color-text-muted)}.chat-text{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.4;word-break:break-word}.chat-text.message-deleted{font-style:italic;color:var(--color-text-muted)}.chat-text.emoji-only{line-height:1.2}.chat-text.emoji-only .chat-emoji-inline{width:45px;height:45px}.chat-emoji-inline{width:32px;height:32px}.chat-time{font-size:10px;color:var(--color-text-muted)}.message-edited-label{font-size:9px;color:var(--color-text-muted);font-style:italic}.edit-mode-bar{display:flex;align-items:center;justify-content:space-between;padding:6px var(--spacing-md);background:#00ff8814;border-top:1px solid rgba(0,255,136,.2);font-size:var(--font-size-xs);color:var(--color-primary);flex-shrink:0}.edit-mode-cancel{background:transparent;border:1px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-size-xs);font-family:var(--font-family);padding:4px 10px;cursor:pointer;transition:all .15s ease}.edit-mode-cancel:hover{background:var(--color-primary);color:#000}.chat-mute-banner{background:#ff444426;color:#f66;font-size:12px;font-weight:600;text-align:center;padding:8px 16px;border-top:1px solid rgba(255,68,68,.3)}.chat-input-bar{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--color-border-primary);position:relative;align-items:flex-end;flex-shrink:0}.emoji-toggle-btn{width:46px;height:46px;border-radius:var(--radius-full);background:transparent;border:1px solid rgba(255,255,255,.1);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease;color:var(--color-text-secondary)}.emoji-toggle-btn:hover{border-color:var(--color-primary);background:var(--color-bg-elevated)}.chat-input-wrapper{flex:1;position:relative;min-width:0}.chat-input{width:100%;padding:12px 18px;background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--font-size-lg);font-family:var(--font-family);outline:none;transition:border-color var(--transition-base);resize:none;overflow-y:hidden;min-height:44px;max-height:120px;line-height:1.4}.chat-input.has-preview{color:transparent;caret-color:var(--color-text-primary);-webkit-text-fill-color:transparent}.chat-input-preview{position:absolute;inset:0;padding:12px 18px;font-size:var(--font-size-lg);font-family:var(--font-family);line-height:1.4;color:var(--color-text-primary);pointer-events:none;white-space:pre-wrap;word-break:break-word;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.chat-input-preview::-webkit-scrollbar{display:none}.chat-input-preview .chat-emoji-inline{width:32px;height:32px;vertical-align:middle;margin:0 1px}.char-counter{position:absolute;bottom:4px;right:8px;font-size:11px;color:var(--color-text-muted);pointer-events:none;font-variant-numeric:tabular-nums}.chat-input:focus{border-color:var(--color-primary)}.chat-input:disabled{opacity:.5}.chat-input::placeholder{color:var(--color-text-muted)}.chat-send-btn{width:42px;height:42px;border-radius:var(--radius-full);background:var(--color-primary);border:none;color:#000;font-size:18px;font-weight:var(--font-weight-bold);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);flex-shrink:0;position:relative}.chat-send-btn:hover:not(:disabled){box-shadow:0 0 12px var(--color-primary-glow);transform:scale(1.05)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn.cooldown{background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.15)}.cooldown-badge{font-size:14px;font-weight:var(--font-weight-bold);color:var(--color-text-muted)}.send-btn-icon{width:20px;height:20px;object-fit:contain}.original-message-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:300;padding:var(--spacing-lg)}.original-message-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);max-width:400px;width:100%}.original-message-modal h3{margin:0 0 var(--spacing-md);color:var(--color-primary);font-size:var(--font-size-lg)}.original-message-modal .original-text{background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5}.original-message-modal .current-text{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.original-message-modal button{width:100%;padding:10px;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#000;font-weight:var(--font-weight-bold);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all .15s ease}.original-message-modal button:hover{box-shadow:0 0 12px var(--color-primary-glow)}@media(max-width:768px){.chat-header{padding:var(--spacing-sm) var(--spacing-md);max-height:80px;height:100%;display:flex;justify-content:center;align-items:flex-end}.chat-text,.chat-title{font-size:var(--font-size-lg)}.chat-message{max-width:85%}}.clan-chat{display:flex;flex-direction:column;height:300px;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:var(--color-bg-primary)}.clan-chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:4px}.clan-chat-loading,.clan-chat-empty{display:flex;align-items:center;justify-content:center;flex:1;color:var(--color-text-muted);font-size:var(--font-size-sm)}.clan-chat-msg{display:flex;flex-direction:column;align-items:flex-start;max-width:80%}.clan-chat-msg.own{align-self:flex-end;align-items:flex-end}.clan-chat-author{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:var(--font-weight-medium);margin-bottom:2px;padding-left:8px}.clan-chat-bubble{display:inline-flex;align-items:flex-end;gap:6px;padding:6px 10px;border-radius:12px;background:var(--color-bg-elevated);word-break:break-word}.clan-chat-msg.own .clan-chat-bubble{background:var(--color-primary);color:var(--color-bg-primary)}.clan-chat-text{font-size:var(--font-size-sm);line-height:1.4}.clan-chat-text .chat-emoji-inline{width:20px;height:20px;vertical-align:middle}.clan-chat-time{font-size:10px;opacity:.6;flex-shrink:0}.clan-chat-input-bar{display:flex;align-items:flex-end;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.clan-chat-input-wrapper{flex:1;position:relative;min-width:0}.clan-chat-input-wrapper .char-counter{position:absolute;bottom:4px;right:8px;font-size:11px;color:var(--color-text-muted);pointer-events:none;font-variant-numeric:tabular-nums}.clan-chat-input{width:100%;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:8px 14px;color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);outline:none;resize:none;overflow-y:hidden;min-height:36px;max-height:100px;line-height:1.4}.clan-chat-input::placeholder{color:var(--color-text-muted)}.clan-chat-send{width:36px;height:36px;border-radius:50%;border:none;background:var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.clan-chat-send.cooldown{background:var(--color-bg-elevated);pointer-events:none}.clan-cooldown-badge{font-size:12px;font-weight:var(--font-weight-bold);color:var(--color-text-muted)}.clan-page{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary);color:var(--color-text-primary)}.clan-no-clan{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center}.clan-no-clan h2{margin:var(--spacing-md) 0 var(--spacing-xs);color:var(--color-primary)}.clan-cta-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%;max-width:300px;margin-top:var(--spacing-xl)}.clan-cta-btn{padding:var(--spacing-md);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);cursor:pointer;transition:opacity .2s}.clan-cta-btn:disabled{opacity:.5}.clan-cta-btn.primary{background:var(--color-primary);color:var(--color-bg-primary)}.clan-cta-btn.secondary{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.clan-browse-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.clan-browse-header h3{margin:0;font-size:var(--font-size-md)}.back-btn1{border:none;color:var(--color-primary);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer}.clan-browse,.clan-create{flex:1;display:flex;flex-direction:column;overflow-y:auto}.clan-browse .friends-list{padding:var(--spacing-md)}.clan-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.clan-form{padding:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.clan-textarea{resize:none;min-height:80px}.clan-header{padding:var(--spacing-lg);text-align:center;border-bottom:1px solid var(--color-border)}.clan-tag{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:var(--font-weight-bold);letter-spacing:2px}.clan-name{margin:var(--spacing-xs) 0;font-size:var(--font-size-xl)}.clan-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--spacing-sm) 0 0}.clan-stats-row{display:flex;justify-content:center;gap:var(--spacing-lg);margin-top:var(--spacing-md);flex-wrap:wrap}.clan-stat{display:flex;flex-direction:column;align-items:center}.clan-stat-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.clan-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.clan-section{flex:1;overflow-y:auto;padding:var(--spacing-md)}.clan-section-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-sm);text-transform:uppercase;letter-spacing:1px}.clan-members-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.clan-member-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.clan-member-card .friend-avatar{position:relative;overflow:visible}.clan-member-card .friend-avatar img{border-radius:50%}.online-dot{position:absolute;bottom:2px;right:2px;width:10px;height:10px;border-radius:50%;background:var(--color-success, #00ff88);border:2px solid var(--color-bg-elevated);box-shadow:0 0 4px var(--color-success, #00ff88)}.clan-actions{padding:var(--spacing-md);border-top:1px solid var(--color-border)}.clan-management-bar{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.clan-mgmt-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-family:var(--font-family);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap}.moderation-mute-overlay{position:fixed;inset:0;z-index:9999;background:#000c;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.clan-mgmt-btn:active{background:var(--color-bg-secondary)}.clan-mgmt-btn.disabled{opacity:.4;pointer-events:none}.clan-mgmt-hint{font-size:9px;color:var(--color-text-muted);font-style:italic}.role-marechal{color:var(--color-primary)}.clan-range{width:100%;accent-color:var(--color-primary)}.clan-logs-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.clan-log-item{padding:var(--spacing-sm);background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.clan-log-text{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.4}.clan-log-reason{color:var(--color-text-muted);font-style:italic}.clan-log-time{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:4px}.clan-section{flex:unset;overflow-y:visible}.clan-leaderboard-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.clan-leaderboard-row{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer}.clan-leaderboard-row:active{background:var(--color-bg-glass)}.clan-leaderboard-row.own-clan{border-color:var(--color-primary);background:#667eea14}.clan-lb-rank{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);min-width:36px;text-align:center}.clan-lb-info{flex:1;min-width:0}.clan-lb-name{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clan-lb-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.clan-leaderboard-detail{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:90%;width:18%;max-width:400px;max-height:80vh;overflow-y:auto}.clan-invite-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center}.clan-invite-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.clan-invite-actions .clan-cta-btn{flex:1;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.clan-invite-actions .clan-cta-btn:active{opacity:.7}.clan-invite-actions .clan-cta-btn.disabled{opacity:.5;pointer-events:none}@media(max-width:768px){.clan-page{padding-top:var(--spacing-2xl)}}.dm-overlay{position:fixed;top:0;left:0;width:100%;height:var(--app-height, 100dvh);z-index:200;background:var(--color-bg-primary);display:flex;flex-direction:column}.dm-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-primary);background:var(--color-bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);flex-shrink:0}.dm-back-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;display:flex;align-items:center;padding:4px}.dm-user-info{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);min-width:0}.dm-user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-primary)}.dm-user-avatar img{width:100%;height:100%;object-fit:cover}.dm-user-name{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.dm-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.dm-loading-more{text-align:center;padding:var(--spacing-sm);color:var(--color-text-muted);font-size:var(--font-size-xs)}.dm-message{display:flex;gap:var(--spacing-sm);max-width:80%;align-self:flex-start}.dm-message.own{align-self:flex-end;flex-direction:row-reverse}.dm-message.grouped{margin-top:-4px}.dm-msg-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;font-weight:var(--font-weight-bold);color:var(--color-primary)}.dm-msg-avatar img{width:100%;height:100%;object-fit:cover}.dm-msg-avatar-spacer{width:28px;flex-shrink:0}.dm-bubble{background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:12px 12px 12px 4px;padding:8px 12px;min-width:40px}.dm-message.own .dm-bubble{background:#00ff881f;border-color:#0f83;border-radius:12px 12px 4px}.dm-msg-time{font-size:10px;color:var(--color-text-muted);margin-top:2px}.dm-msg-text{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.4;word-break:break-word}.dm-msg-text .chat-emoji-inline{width:20px;height:20px;vertical-align:middle;margin:0 1px}.dm-msg-read{font-size:9px;color:var(--color-text-muted);text-align:right;margin-top:1px}.dm-clan-invite{background:linear-gradient(135deg,rgba(0,255,136,.06) 0%,transparent 60%);border:1px solid rgba(0,255,136,.25);border-left:3px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--spacing-md);min-width:200px}.dm-clan-invite-header{display:flex;align-items:center;gap:6px;color:var(--color-primary);margin-bottom:4px}.dm-clan-invite-tag{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:var(--font-weight-bold);letter-spacing:1px}.dm-clan-invite-name{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:2px 0 4px}.dm-clan-invite-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-sm);line-height:1.3}.dm-clan-invite-btn{width:100%;padding:8px;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#000;font-weight:var(--font-weight-bold);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:opacity .15s;text-align:center}.dm-clan-invite-btn.loading{opacity:.5;pointer-events:none}.dm-clan-invite-already{font-size:var(--font-size-xs);color:var(--color-text-muted);font-style:italic;padding:6px 0 2px}.dm-input-bar{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--color-border-primary);background:var(--color-bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);align-items:flex-end;flex-shrink:0}.dm-input-wrapper{flex:1;position:relative;min-width:0}.dm-input-wrapper .char-counter{position:absolute;bottom:4px;right:8px;font-size:11px;color:var(--color-text-muted);pointer-events:none;font-variant-numeric:tabular-nums}.dm-input{width:100%;padding:10px 14px;background:var(--color-bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);outline:none;transition:border-color var(--transition-base);resize:none;overflow-y:hidden;min-height:40px;max-height:100px;line-height:1.4}.dm-input:focus{border-color:var(--color-primary)}.dm-send-btn{width:38px;height:38px;border-radius:50%;background:var(--color-secondary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.dm-send-btn:disabled{opacity:.4;cursor:not-allowed}.dm-send-btn img{width:18px;height:18px;object-fit:contain;filter:brightness(0) invert(1)}.dm-typing{padding:4px var(--spacing-md);font-size:var(--font-size-xs);color:var(--color-text-muted);font-style:italic}@media(max-width:768px){.dm-header{padding-top:var(--spacing-2xl)}}.friends-page{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary)}.friends-tabs{display:flex;padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-xs);border-bottom:1px solid var(--color-border);flex-shrink:0}.friends-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.friends-tab.active{background:var(--color-primary);color:var(--color-bg-primary);font-weight:var(--font-weight-bold)}.tab-count{font-size:var(--font-size-xs);opacity:.7}.tab-badge{background:var(--color-danger);color:#fff;font-size:10px;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold)}.friends-error{padding:var(--spacing-sm) var(--spacing-md);background:#ff00551a;color:var(--color-danger);font-size:var(--font-size-sm);text-align:center}.friends-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.friends-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.friends-empty{text-align:center;padding:var(--spacing-2xl) var(--spacing-md);color:var(--color-text-muted)}.empty-icon{font-size:48px;margin-bottom:var(--spacing-md)}.empty-hint{font-size:var(--font-size-sm);margin-top:var(--spacing-xs);opacity:.6}.friend-card{position:relative;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border);user-select:none;-webkit-user-select:none}.friend-unread-badge{min-width:22px;height:22px;padding:0 6px;font-size:11px;font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--color-secondary);color:var(--color-text-on-primary);border-radius:var(--radius-full);animation:pulse-neon 2s ease-in-out infinite}.friend-card.clickable{cursor:pointer;transition:background .15s}.friend-card.clickable:active{background:var(--color-bg-secondary)}.friend-avatar.clickable{cursor:pointer;transition:transform .15s}.friend-avatar.clickable:active{transform:scale(.9)}.friend-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center}.friend-avatar img{width:100%;height:100%;object-fit:cover}.friend-avatar span{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.friend-info{flex:1;min-width:0}.friend-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-level{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.friend-action-btn{padding:var(--spacing-xs) var(--spacing-md);border:none;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;transition:opacity .2s;white-space:nowrap}.friend-action-btn:disabled{opacity:.5}.friend-action-btn.add{background:var(--color-primary);color:var(--color-bg-primary)}.friend-action-btn.accept{background:var(--color-success);color:#fff}.friend-action-btn.reject{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.friend-action-btn.danger{background:transparent;color:var(--color-danger);border:1px solid rgba(255,0,85,.3)}.friend-status{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.request-actions{display:flex;gap:var(--spacing-xs)}.friends-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-sm) 0 var(--spacing-xs)}.friend-status-badge{font-size:10px;font-weight:var(--font-weight-medium);padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.friend-status-badge.pending{background:#ffaa0026;color:#fa0;border:1px solid rgba(255,170,0,.3)}.friends-search{display:flex;flex-direction:column;gap:var(--spacing-md)}.search-input-container{position:relative}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--color-primary)}.search-input::placeholder{color:var(--color-text-muted)}@media(max-width:768px){.friends-tabs{padding-top:var(--spacing-2xl)}}.achievement-section{margin-top:var(--spacing-lg)}.achievement-section-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px;margin:0 0 var(--spacing-md)}.achievement-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.achievement-badge{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:center}.achievement-badge.unlocked{background:#eeff000d;border:1px solid var(--tier-color, var(--color-primary));box-shadow:0 0 8px #eeff0026}.achievement-badge.locked{background:var(--color-bg-secondary);border:1px solid var(--color-border);opacity:.5;filter:grayscale(.8)}.achievement-badge.locked:has(.achievement-progress){opacity:.75;filter:grayscale(.4)}.achievement-badge:active{transform:scale(.95)}.achievement-icon{font-size:28px;line-height:1}.achievement-name{font-size:10px;color:var(--color-text-muted);line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.achievement-loading{text-align:center;color:var(--color-text-muted);padding:var(--spacing-md);font-size:var(--font-size-sm)}.achievement-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:300;padding:var(--spacing-md)}.achievement-modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:320px;width:100%;text-align:center}.achievement-modal-icon{font-size:56px;margin-bottom:var(--spacing-md)}.achievement-modal-name{font-size:var(--font-size-lg);margin:0 0 var(--spacing-sm)}.achievement-modal-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--spacing-md);line-height:1.4}.achievement-modal-tier{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm)}.achievement-modal-status{font-size:var(--font-size-xs);margin-bottom:var(--spacing-md)}.achievement-modal-status.unlocked{color:var(--color-success)}.achievement-modal-status.locked{color:var(--color-text-muted)}.achievement-progress{width:100%;height:4px;background:#ffffff1a;border-radius:2px;position:relative;margin-top:2px;overflow:hidden}.achievement-progress-bar{height:100%;background:var(--tier-color, var(--color-primary));border-radius:2px;transition:width .4s ease}.achievement-progress-text{position:absolute;top:-12px;right:0;font-size:8px;color:var(--color-text-muted)}.achievement-modal-progress{margin-bottom:var(--spacing-md)}.achievement-modal-progress-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-bottom:6px}.achievement-modal-progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .4s ease}.achievement-modal-progress-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.achievement-modal-close{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer}.notification-bell-container{position:relative}.notification-bell-btn{position:relative;background:none;border:none;cursor:pointer;padding:8px;font-size:20px;line-height:1}.bell-icon{filter:grayscale(.3)}.notification-badge{position:absolute;top:2px;right:0;background:var(--color-danger);color:#fff;font-size:10px;font-weight:var(--font-weight-bold);min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--font-family)}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080;z-index:200;display:flex;flex-direction:column;overflow:hidden}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.notification-title{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text-primary)}.mark-all-read-btn{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-xs);font-family:var(--font-family);cursor:pointer}.notification-list{overflow-y:auto;flex:1}.notification-empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.notification-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .15s}.notification-item:hover{background:#ffffff08}.notification-item.unread{background:#eeff0008}.notification-icon{font-size:18px;flex-shrink:0;margin-top:2px}.notification-content{flex:1;min-width:0}.notification-text{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.3}.notification-body{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.notification-time{font-size:11px;color:var(--color-text-muted);margin-top:2px}.notification-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary);flex-shrink:0;margin-top:6px}@media(max-width:768px){.notification-dropdown{width:calc(100vw - 32px);right:-8px}}.profile-page{display:flex;flex-direction:column;background:var(--color-bg-primary);color:var(--color-text-primary)}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);padding-top:30px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-primary);position:relative;z-index:10;max-height:80px;height:100%}.profile-back-btn{background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);color:var(--color-text-primary);font-size:var(--font-size-xl);width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.profile-back-btn:hover{border-color:var(--color-primary);box-shadow:var(--glow-primary)}.profile-title{margin:0;font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);color:var(--color-primary);text-shadow:var(--text-shadow-neon)}.profile-header-spacer{width:40px}.profile-content{flex:1;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) 0}.profile-avatar-container{position:relative;width:100px;height:100px;border-radius:var(--radius-full);border:3px solid var(--color-primary);box-shadow:var(--glow-primary);overflow:visible;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated)}.profile-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.profile-avatar-placeholder{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-primary);text-shadow:var(--text-shadow-neon)}.profile-display-name{margin:0;font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl);color:var(--color-text-primary)}.profile-email{margin:0;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-muted)}.profile-level-badge{background:var(--color-secondary);color:var(--color-text-primary);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);box-shadow:var(--glow-secondary)}.profile-level-progress{background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-md)}.profile-level-progress-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.profile-level-current{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-primary)}.profile-level-next{font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-muted)}.profile-level-bar{width:100%;height:8px;background:var(--color-bg-primary);border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--color-border-primary)}.profile-level-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);transition:width .5s ease;box-shadow:0 0 8px var(--color-primary-glow)}.profile-level-score-info{text-align:center;margin-top:var(--spacing-xs);font-family:var(--font-family);font-size:var(--font-size-xs);color:var(--color-text-muted)}.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.profile-stat-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);transition:all var(--transition-base)}.profile-stat-card:hover{border-color:var(--color-primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}.profile-stat-icon{font-size:var(--font-size-2xl)}.profile-stat-value{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl);color:var(--color-primary);text-shadow:var(--text-shadow-neon)}.profile-stat-label{font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center}.profile-score-card{background:var(--color-bg-elevated);border:1px solid var(--color-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--glow-secondary)}.profile-score-label{font-family:var(--font-family);font-weight:var(--font-weight-medium);font-size:var(--font-size-base);color:var(--color-text-secondary)}.profile-score-value{font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl);color:var(--color-primary);text-shadow:var(--text-shadow-neon)}.profile-actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:auto;padding-bottom:var(--spacing-md)}.profile-action-btn{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);border:1px solid var(--color-border-primary);width:100%}.profile-action-icon{font-size:var(--font-size-xl)}.profile-settings-btn{background:var(--color-bg-elevated);color:var(--color-text-primary)}.profile-settings-btn:hover{border-color:var(--color-primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}.profile-logout-btn{background:var(--color-bg-elevated);color:var(--color-danger);border-color:var(--color-danger)}.profile-logout-btn:hover{background:#ff00551a;box-shadow:var(--glow-danger);transform:translateY(-2px)}.profile-header-actions{display:flex;justify-content:flex-end;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md) 0}.profile-header-icon-btn{background:none;border:none;cursor:pointer;padding:8px;color:var(--color-text-secondary);transition:color .15s;display:flex;align-items:center;justify-content:center}.profile-header-icon-btn:hover{color:var(--color-primary)}.profile-avatar-edit-badge{position:absolute;bottom:4px;right:4px;background:var(--color-primary);color:var(--color-bg-primary);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--color-bg-primary);box-shadow:0 2px 4px #0000004d}.profile-section-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px;margin:0 0 var(--spacing-md)}.profile-activity-section{margin-top:var(--spacing-lg)}.profile-activity-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profile-activity-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.activity-icon{font-size:18px;flex-shrink:0}.activity-info{flex:1;min-width:0}.activity-label{font-size:var(--font-size-sm);color:var(--color-text-primary)}.activity-time{font-size:11px;color:var(--color-text-muted)}.activity-points{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:var(--font-weight-bold);white-space:nowrap}.avatar-overlay{position:fixed;inset:0;z-index:300;background:#000000b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.avatar-overlay-content{background:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);position:relative}.avatar-overlay-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.avatar-overlay-title{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.avatar-overlay-preview{width:140px;height:140px;border-radius:50%;border:3px solid var(--color-primary);box-shadow:var(--glow-primary);overflow:hidden;background:var(--color-bg-primary)}.avatar-overlay-img{width:100%;height:100%;object-fit:cover}.avatar-overlay-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%}.avatar-overlay-btn{width:100%;padding:12px;border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.avatar-overlay-regen{background:var(--color-bg-primary);border:1px solid var(--color-border-primary);color:var(--color-text-primary)}.avatar-overlay-regen:hover{border-color:var(--color-primary)}.avatar-overlay-save{background:var(--color-primary);border:1px solid var(--color-primary);color:#000}.avatar-overlay-save:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.profile-content{padding:var(--spacing-md);padding-top:var(--spacing-2xl)}.profile-avatar-container{width:80px;height:80px}.profile-avatar-placeholder{font-size:var(--font-size-3xl)}.profile-display-name{font-size:var(--font-size-xl)}}.page-container{position:relative;width:100%;height:100%;overflow:clip;background:var(--color-bg-primary)}.page-strip{display:flex;width:500%;height:100%;position:relative}.page-strip[data-index="0"]{transform:translate(0)}.page-strip[data-index="1"]{transform:translate(-20%)}.page-strip[data-index="2"]{transform:translate(-40%)}.page-strip[data-index="3"]{transform:translate(-60%)}.page-strip[data-index="4"]{transform:translate(-80%)}.page-strip.swiping{will-change:transform}.page-slot{width:20%;height:100%;flex-shrink:0;overflow-y:auto;overflow-x:hidden;position:relative}.page-slot.distant{visibility:hidden}.page-slot.adjacent,.page-slot.active{visibility:visible}:root{--color-primary: #EEFF00;--color-primary-rgb: 238, 255, 0;--color-primary-glow: rgba(238, 255, 0, .4);--color-primary-dark: #CCDD00;--color-secondary: #ebc106;--color-secondary-glow: rgba(255, 206, 72, .4);--color-secondary-light: #ebc106;--color-bg-primary: #0e0e03;--color-bg-secondary: #0A0A0A;--color-bg-elevated: #1A1A1A;--color-bg-input: #111111;--color-bg-glass: rgba(26, 26, 26, .7);--color-text-primary: #FFFFFF;--color-text-secondary: #e0dddd;--color-text-muted: #707070;--color-text-on-primary: #000000;--color-success: #00FF88;--color-success-glow: rgba(0, 255, 136, .4);--color-danger: #FF0055;--color-danger-glow: rgba(255, 0, 85, .4);--color-warning: #FFAA00;--color-warning-glow: rgba(255, 170, 0, .4);--color-error: #FF0055;--color-info: #00DDFF;--color-info-glow: rgba(0, 221, 255, .4);--color-territory-street: #EEFF00;--color-territory-monument: #6A0DAD;--color-territory-contested: #FF0055;--color-territory-owned: #11ff00;--color-map-road: #2A2A2A;--color-map-water: #001122;--color-map-park: #002200;--color-border-primary: #333333;--color-border-active: var(--color-primary);--color-border-glow: var(--color-primary-glow);--font-family: "Quicksand", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 3rem;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-base: 12px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 38px;--spacing-2xl: 55px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 32px rgba(0, 0, 0, .6);--glow-primary: 0 0 10px var(--color-primary-glow), 0 0 20px var(--color-primary-glow), 0 0 30px var(--color-primary-glow);--glow-secondary: 0 0 10px var(--color-secondary-glow), 0 0 20px var(--color-secondary-glow), 0 0 30px var(--color-secondary-glow);--glow-success: 0 0 10px var(--color-success-glow), 0 0 20px var(--color-success-glow);--glow-danger: 0 0 10px var(--color-danger-glow), 0 0 20px var(--color-danger-glow);--text-shadow-neon: 0 0 8px var(--color-primary-glow), 0 0 12px var(--color-primary-glow);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-modal: 1100;--z-tooltip: 1200;--z-notification: 1300}.glass{background:var(--color-bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.neon-glow{box-shadow:var(--glow-primary)}.neon-text{text-shadow:var(--text-shadow-neon)}.bento-card{background:var(--color-bg-elevated);border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--color-border-primary);transition:all var(--transition-base)}.bento-card:hover{border-color:var(--color-primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}.btn{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);border:none;outline:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-primary{background:var(--color-primary);color:var(--color-text-on-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--glow-primary);transform:translateY(-2px)}.btn-secondary{background:var(--color-secondary);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-secondary-light);box-shadow:var(--glow-secondary);transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;padding:var(--spacing-md);background:var(--color-bg-elevated);border:2px solid var(--color-border-primary);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);outline:none;transition:all var(--transition-base)}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.input::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-dark);box-shadow:var(--glow-primary)}@keyframes pulse-neon{0%,to{box-shadow:var(--glow-primary)}50%{box-shadow:0 0 20px var(--color-primary-glow),0 0 40px var(--color-primary-glow),0 0 60px var(--color-primary-glow)}}.pulse-neon{animation:pulse-neon 2s ease-in-out infinite}@keyframes slide-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-slide-in{animation:slide-in-up .3s ease-out}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-weight:var(--font-weight-regular);color:var(--color-text-primary);background:var(--color-bg-primary);line-height:1.6;overflow-x:hidden}#root{width:100%;height:100%;margin:0;padding:0;display:flex;flex-direction:column;overflow:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-family);font-weight:var(--font-weight-bold);line-height:1.2;color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl);text-shadow:var(--text-shadow-neon)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-muted{color:var(--color-text-muted)}.text-center{text-align:center}.text-bold{font-weight:var(--font-weight-bold)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.app-layout{position:fixed;top:0;left:0;width:100%;height:var(--app-height, 100dvh);display:flex;flex-direction:column;overflow:hidden}.page-transition-container{position:relative;flex:1;overflow:hidden}.overlay-page{position:absolute;inset:0;z-index:100;background:var(--color-bg-primary);overflow-y:auto}.loading-screen{display:flex;justify-content:center;align-items:center;height:100%;background:linear-gradient(135deg,#ff8c00,#ffb347,gold 60%,#ff6b00);background-size:400% 400%;animation:loading-gradient 4s ease infinite;color:#fff;position:relative;overflow:hidden}.loading-screen:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 60%);animation:loading-shine 3s ease-in-out infinite}.loading-content{text-align:center;animation:loading-appear .8s ease-out;z-index:1}.loading-icon{font-size:64px;margin-bottom:16px;animation:loading-drop 2s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}.loading-title{font-weight:800;font-size:28px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.2);margin-bottom:20px;letter-spacing:1px}.loading-text{color:#ffffffe6;font-size:14px;font-weight:500}.loading-bar{width:120px;height:4px;background:#ffffff4d;border-radius:4px;margin:16px auto 0;overflow:hidden}.loading-bar-fill{height:100%;width:40%;background:#fff;border-radius:4px;animation:loading-bar-slide 1.2s ease-in-out infinite}.loading-bubbles{position:absolute;inset:0;pointer-events:none;overflow:hidden}.loading-bubble{position:absolute;border-radius:50%;background:#ffffff1f;animation:loading-bubble-rise linear infinite}.loading-bubble:nth-child(1){width:20px;height:20px;left:10%;bottom:-20px;animation-duration:4s;animation-delay:0s}.loading-bubble:nth-child(2){width:35px;height:35px;left:30%;bottom:-35px;animation-duration:5s;animation-delay:1s}.loading-bubble:nth-child(3){width:15px;height:15px;left:55%;bottom:-15px;animation-duration:3.5s;animation-delay:.5s}.loading-bubble:nth-child(4){width:25px;height:25px;left:75%;bottom:-25px;animation-duration:4.5s;animation-delay:2s}.loading-bubble:nth-child(5){width:18px;height:18px;left:90%;bottom:-18px;animation-duration:3s;animation-delay:1.5s}.loading-bubble:nth-child(6){width:30px;height:30px;left:45%;bottom:-30px;animation-duration:5.5s;animation-delay:.8s}@keyframes loading-gradient{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes loading-shine{0%,to{transform:translate(-30%,-30%) rotate(0)}50%{transform:translate(30%,30%) rotate(180deg)}}@keyframes loading-appear{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes loading-drop{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-12px) rotate(-5deg)}75%{transform:translateY(4px) rotate(3deg)}}@keyframes loading-bar-slide{0%{transform:translate(-120px)}to{transform:translate(300px)}}@keyframes loading-bubble-rise{0%{transform:translateY(0) scale(1);opacity:.6}to{transform:translateY(-100vh) scale(1.3);opacity:0}}@media(max-width:768px){html{font-size:14px}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}}@media print{body{background:#fff;color:#000}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fade-in .3s ease-out}.slide-in-right{animation:slide-in-right .3s ease-out}.slide-in-left{animation:slide-in-left .3s ease-out}
