.btn{padding:.75rem 1.35rem;border:2px solid transparent;border-radius:0;font-weight:700;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-base),background-color var(--transition-base),border-color var(--transition-base);position:relative;overflow:hidden;clip-path:var(--clip-button);box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);border-color:#00000024;color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md);background:var(--color-primary-hover)}.btn-secondary{background:#ffffff73;border-color:#0003;color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:#4fb3ff0f;border-color:var(--color-primary);transform:translateY(-1px)}.btn:focus-visible{outline:none;box-shadow:var(--shadow-glow)}.btn:active:not(:disabled){transform:translateY(0)}.btn-small{padding:.5rem .95rem;font-size:.875rem}.btn-medium{padding:.75rem 1.35rem;font-size:1rem}.btn-large{padding:1rem 1.8rem;font-size:1.125rem}:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}.map-component-wrapper{position:relative;width:100%;height:100%;min-height:400px}.map-container{width:100%;height:100%;z-index:0;border-radius:8px;overflow:hidden}.map-loading-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;gap:1rem}.map-loading-spinner{border:4px solid #f3f4f6;border-top:4px solid #2e90fa;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.map-loading-overlay p{color:#6b7280;font-size:14px;font-weight:500}.map-error-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;display:flex;align-items:center;gap:8px;z-index:1001;box-shadow:0 4px 6px #0000001a;max-width:90%}.map-error-icon{font-size:18px}.map-error-banner span{color:#991b1b;font-size:14px;font-weight:500}.map-retry-button{background:#dc2626;color:#fff;border:none;border-radius:4px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;margin-left:8px;transition:background .2s}.map-retry-button:hover{background:#b91c1c}.map-retry-button:active{background:#991b1b}.leaflet-container{font-family:inherit;background:#f9fafb}.leaflet-control-zoom{border:none!important;box-shadow:0 2px 8px #00000026}.leaflet-control-zoom a{background:#fff;color:#374151;border-bottom:1px solid #e5e7eb;transition:background .2s}.leaflet-control-zoom a:hover{background:#f9fafb;color:#111827}.leaflet-control-attribution{background:#fffc;font-size:11px}.quest-marker-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:2px solid white;box-shadow:0 4px 10px #0f172a40;transition:transform .2s ease,box-shadow .2s ease}.quest-marker-icon .quest-marker-dot{width:10px;height:10px;border-radius:50%;background:#fff;display:block}.marker--available{background:#22c55e}.marker--in_progress{background:#3b82f6}.marker--completed{background:#64748b}.marker--locked{background:#f97316}.marker--approved{background:#f59e0b;animation:pulse-approved 2s infinite}@keyframes pulse-approved{0%,to{box-shadow:0 0 #f59e0b66,0 4px 10px #0f172a40}50%{box-shadow:0 0 0 8px #f59e0b00,0 4px 10px #0f172a40}}.marker--priority-high{box-shadow:0 0 0 4px #f43f5e4d,0 4px 10px #0f172a40}.marker--difficulty-hard{border-color:#f97316}.marker--difficulty-medium{border-color:#facc15}.marker--difficulty-easy{border-color:#4ade80}.marker--nearby{box-shadow:0 0 0 4px #38bdf859,0 4px 10px #0f172a40;transform:translateY(-1px) scale(1.03)}.quest-marker-icon:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #0f172a4d}.quest-marker-tooltip{display:flex;flex-direction:column;gap:4px;font-size:12px;max-width:220px}.quest-marker-tooltip-description{margin:0;font-size:11px;line-height:1.35;color:#4b5563;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.quest-marker-status{display:inline-flex;padding:2px 6px;border-radius:999px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.quest-marker-status.status--available{background:#22c55e26;color:#166534}.quest-marker-status.status--in_progress{background:#3b82f626;color:#1e40af}.quest-marker-status.status--completed{background:#64748b26;color:#334155}.quest-marker-status.status--locked{background:#f9731626;color:#9a3412}.quest-marker-status.status--approved{background:#f59e0b26;color:#92400e}.quest-marker-popup-content{display:flex;flex-direction:column;gap:8px;min-width:200px}.quest-marker-popup-content h3{margin:0;font-size:16px;color:#111827}.quest-marker-popup-content p{margin:0;color:#4b5563;font-size:13px}.quest-marker-popup-meta{display:flex;gap:8px;align-items:center}.quest-marker-link{color:#2563eb;font-weight:600;font-size:13px;text-decoration:none}.quest-marker-link:hover{text-decoration:underline}.quest-marker-dialog-button{appearance:none;border:1px solid #c7d2fe;background:#eef2ff;color:#3730a3;border-radius:8px;font-size:12px;font-weight:600;line-height:1.2;padding:6px 10px;cursor:pointer;text-align:left}.quest-marker-dialog-button:hover{background:#e0e7ff}.ol-quest-popup{display:none;pointer-events:none;position:relative;z-index:600}.ol-quest-popup.is-open{display:block;pointer-events:auto}.ol-quest-popup-card{min-width:210px;max-width:260px;padding:.75rem .85rem;border-radius:12px;background:#020617f7;border:1px solid rgba(148,163,184,.4);color:#f8fafc;box-shadow:0 0 0 1px #94a3b81a,0 20px 40px #020617a6,0 8px 16px #02061773;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transform-origin:bottom center;animation:popupSlideIn .25s ease-out}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ol-quest-popup-card h4{margin:0 0 .35rem;font-size:1rem;font-weight:700;color:#fff;letter-spacing:.01em}.ol-quest-popup-card p{margin:0 0 .65rem;color:#f1f5f9f5;font-size:.84rem;line-height:1.4;letter-spacing:.002em}.ol-quest-popup-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.ol-quest-popup-list{display:flex;flex-direction:column;gap:.55rem}.ol-quest-popup-item{display:flex;flex-direction:column;gap:.4rem;padding:.55rem .6rem;border-radius:9px;background:#0f172a94;border:1px solid rgba(148,163,184,.18)}.ol-quest-popup-item-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.ol-quest-popup-item-title{font-size:.86rem;font-weight:700;color:#fff}.ol-quest-popup-item p{margin:0;color:#f1f5f9f2;font-size:.78rem;line-height:1.35}.ol-quest-popup .quest-marker-status{background:#0f172ae6;border:1px solid rgba(148,163,184,.4);color:#e2e8f0;font-size:.72rem;padding:.3rem .6rem;font-weight:700}.ol-quest-popup .quest-marker-dialog-button{border:1px solid rgba(96,165,250,.7);background:#2563ebd9;color:#e0f2fe;font-size:.8rem;padding:.45rem .75rem;border-radius:7px;font-weight:600;transition:all .2s ease;cursor:pointer}.ol-quest-popup .quest-marker-dialog-button:hover{background:#2563eb;color:#fff;border-color:#60a5fae6;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}@media(max-width:768px){.map-component-wrapper{min-height:300px}.map-error-banner{font-size:12px;padding:10px 14px}}.search-box{position:relative;width:100%;max-width:400px}.search-input-wrapper{position:relative}.search-input{width:100%;padding:12px 40px 12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;background:#fff;transition:all .2s;box-shadow:0 2px 4px #0000001a}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 4px 8px #3b82f633}.search-input::placeholder{color:#9ca3af}.search-loading{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:#6b7280;pointer-events:none}.search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:400px;overflow-y:auto;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000}.search-result{width:100%;display:flex;align-items:flex-start;gap:12px;padding:12px;border:none;background:#fff;text-align:left;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f3f4f6}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result.selected{background-color:#f3f4f6}.search-result:focus{outline:2px solid #3b82f6;outline-offset:-2px}.search-result-icon{font-size:20px;flex-shrink:0}.search-result-content{flex:1;min-width:0}.search-result-title{font-weight:600;color:#1f2937;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-description{font-size:12px;color:#6b7280;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-meta{display:flex;gap:8px;font-size:11px;color:#9ca3af}.search-result-type{text-transform:capitalize}.search-result-coords{font-family:monospace}.search-result-empty{padding:16px;text-align:center;color:#6b7280;font-size:14px}@media(max-width:640px){.search-box{max-width:none}.search-result{padding:10px}.search-result-description{display:none}}.avatar-lock-indicator{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs, 4px);padding:var(--spacing-xs, 4px);border-radius:var(--border-radius-full, 50%);font-weight:600;transition:all .2s ease}.avatar-lock-indicator.locked{background-color:#ef4444e6;color:#fff}.avatar-lock-indicator.unlocked{background-color:#22c55ee6;color:#fff}.avatar-lock-indicator .lock-icon{flex-shrink:0}.avatar-lock-indicator .lock-label{font-size:var(--font-size-xs, 12px);white-space:nowrap}.avatar-lock-indicator.size-small{padding:var(--spacing-xs, 2px) var(--spacing-sm, 4px);min-width:20px;min-height:20px}.avatar-lock-indicator.size-medium{padding:var(--spacing-xs, 4px) var(--spacing-sm, 6px);min-width:24px;min-height:24px}.avatar-lock-indicator.size-large{padding:var(--spacing-sm, 6px) var(--spacing-md, 8px);min-width:32px;min-height:32px}.avatar-lock-indicator:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}@media(max-width:768px){.avatar-lock-indicator .lock-label{display:none}}.avatar-unlock-tooltip-wrapper{position:relative;display:inline-block}.avatar-unlock-tooltip-trigger{position:relative;display:inline-flex;align-items:center;gap:var(--spacing-xs, 4px);cursor:help}.tooltip-info-icon{color:var(--color-info, #3b82f6);transition:transform .2s ease}.avatar-unlock-tooltip-trigger:hover .tooltip-info-icon,.avatar-unlock-tooltip-trigger:focus .tooltip-info-icon{transform:scale(1.1)}.avatar-unlock-tooltip-trigger:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px;border-radius:var(--border-radius-sm, 4px)}.avatar-unlock-tooltip-content{position:absolute;z-index:1000;min-width:250px;max-width:350px;padding:var(--spacing-md, 12px);background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:var(--border-radius-md, 8px);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));font-size:var(--font-size-sm, 14px);animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.avatar-unlock-tooltip-content.placement-top{bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--spacing-sm, 8px)}.avatar-unlock-tooltip-content.placement-bottom{top:100%;left:50%;transform:translate(-50%);margin-top:var(--spacing-sm, 8px)}.avatar-unlock-tooltip-content.placement-left{right:100%;top:50%;transform:translateY(-50%);margin-right:var(--spacing-sm, 8px)}.avatar-unlock-tooltip-content.placement-right{left:100%;top:50%;transform:translateY(-50%);margin-left:var(--spacing-sm, 8px)}.tooltip-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm, 8px);padding-bottom:var(--spacing-sm, 8px);border-bottom:1px solid var(--color-border-light, #f3f4f6)}.tooltip-title{margin:0;font-size:var(--font-size-md, 16px);font-weight:600;color:var(--color-text, #1f2937)}.tooltip-unlocked-badge{display:inline-block;padding:2px 8px;background-color:#22c55e1a;color:#16a34a;border-radius:var(--border-radius-full, 9999px);font-size:var(--font-size-xs, 12px);font-weight:600}.tooltip-body{color:var(--color-text-secondary, #6b7280)}.tooltip-avatar-name{margin:0 0 var(--spacing-sm, 8px) 0;font-weight:500;color:var(--color-text, #1f2937)}.tooltip-criteria-list{margin:0;padding-left:var(--spacing-md, 16px);list-style:disc}.tooltip-criteria-item{margin-bottom:var(--spacing-xs, 4px);line-height:1.5}.tooltip-criteria-item strong{color:var(--color-text, #1f2937)}.tooltip-no-criteria{margin:0;font-style:italic;color:var(--color-text-muted, #9ca3af)}.tooltip-loading{display:flex;align-items:center;gap:var(--spacing-sm, 8px);color:var(--color-text-secondary, #6b7280)}.tooltip-loading .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.avatar-unlock-tooltip-content{max-width:280px;font-size:var(--font-size-xs, 12px)}.tooltip-title{font-size:var(--font-size-sm, 14px)}}@media(prefers-color-scheme:dark){.avatar-unlock-tooltip-content{background:var(--color-bg-dark, #1f2937);border-color:var(--color-border-dark, #374151);color:var(--color-text-dark, #f3f4f6)}.tooltip-title,.tooltip-avatar-name,.tooltip-criteria-item strong{color:var(--color-text-dark, #f3f4f6)}.tooltip-body{color:var(--color-text-secondary-dark, #d1d5db)}}.avatar-unlock-animation{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-out}.confetti-container{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none}.confetti-piece{position:absolute;width:10px;height:10px;top:-10px;left:50%;opacity:0;animation:confettiFall 3s ease-in-out forwards}.confetti-piece:nth-child(3n){background:#ef4444;border-radius:50%}.confetti-piece:nth-child(3n+1){background:#3b82f6;border-radius:0}.confetti-piece:nth-child(3n+2){background:#f59e0b;clip-path:polygon(50% 0%,0% 100%,100% 100%)}@keyframes confettiFall{0%{top:-10px;opacity:1;transform:translate(0) rotate(0)}to{top:100vh;opacity:0;transform:translate(calc(var(--x-offset, 0) * 200px)) rotate(var(--rotation, 720deg))}}.confetti-piece:nth-child(2n){--x-offset: 1}.confetti-piece:nth-child(odd){--x-offset: -1}.confetti-piece:nth-child(4n){--x-offset: .5}.confetti-piece:nth-child(5n){--x-offset: -.5}.unlock-notification{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2xl, 32px);background:#fff;border-radius:var(--border-radius-lg, 16px);box-shadow:var(--shadow-2xl, 0 25px 50px -12px rgba(0, 0, 0, .25));max-width:400px;text-align:center;animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.unlock-icon-wrapper{margin-bottom:var(--spacing-md, 16px);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.unlock-icon{color:var(--color-primary, #3b82f6);filter:drop-shadow(0 0 8px rgba(59,130,246,.5))}.unlock-avatar-portrait{width:120px;height:120px;border-radius:50%;border:4px solid var(--color-primary, #3b82f6);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));margin-bottom:var(--spacing-lg, 20px);object-fit:cover;animation:portraitReveal .6s ease-out .3s both}@keyframes portraitReveal{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.unlock-title{margin:0 0 var(--spacing-sm, 8px) 0;font-size:var(--font-size-2xl, 24px);font-weight:700;color:var(--color-text, #1f2937);animation:slideUp .5s ease-out .5s both}.unlock-avatar-name{margin:0 0 var(--spacing-md, 16px) 0;font-size:var(--font-size-xl, 20px);font-weight:600;color:var(--color-primary, #3b82f6);animation:slideUp .5s ease-out .6s both}.unlock-message{margin:0;font-size:var(--font-size-md, 16px);color:var(--color-text-secondary, #6b7280);animation:slideUp .5s ease-out .7s both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.unlock-notification{max-width:90%;padding:var(--spacing-xl, 24px)}.unlock-avatar-portrait{width:100px;height:100px}.unlock-title{font-size:var(--font-size-xl, 20px)}.unlock-avatar-name{font-size:var(--font-size-lg, 18px)}.unlock-message{font-size:var(--font-size-sm, 14px)}.confetti-piece{width:8px;height:8px}}@media(prefers-reduced-motion:reduce){.avatar-unlock-animation,.unlock-notification,.unlock-avatar-portrait,.unlock-title,.unlock-avatar-name,.unlock-message{animation:none}.confetti-piece{display:none}.unlock-icon-wrapper{animation:none}.unlock-notification{opacity:1;transform:scale(1)}}.avatar-collection-view{display:flex;flex-direction:column;width:100%;max-width:1200px;height:90vh;max-height:800px;background:#fff;border-radius:var(--border-radius-lg, 12px);box-shadow:var(--shadow-2xl, 0 25px 50px -12px rgba(0, 0, 0, .25));overflow:hidden}.collection-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg, 20px) var(--spacing-xl, 24px);border-bottom:2px solid var(--color-border, #e5e7eb);background:var(--color-bg-secondary, #f9fafb)}.collection-title-section{display:flex;align-items:center;gap:var(--spacing-md, 12px);color:var(--color-primary, #3b82f6)}.collection-title{margin:0;font-size:var(--font-size-2xl, 24px);font-weight:700;color:var(--color-text, #1f2937)}.collection-close-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:var(--border-radius-md, 8px);color:var(--color-text-secondary, #6b7280);cursor:pointer;transition:all .2s ease}.collection-close-button:hover{background:#0000000d;color:var(--color-text, #1f2937)}.collection-close-button:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.collection-filters{display:flex;gap:var(--spacing-sm, 8px);padding:var(--spacing-md, 16px) var(--spacing-xl, 24px);border-bottom:1px solid var(--color-border-light, #f3f4f6)}.filter-button{display:inline-flex;align-items:center;gap:var(--spacing-xs, 4px);padding:var(--spacing-sm, 8px) var(--spacing-md, 16px);background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:var(--border-radius-full, 9999px);font-size:var(--font-size-sm, 14px);font-weight:500;color:var(--color-text-secondary, #6b7280);cursor:pointer;transition:all .2s ease}.filter-button:hover{background:var(--color-bg-secondary, #f9fafb);border-color:var(--color-primary-light, #93c5fd)}.filter-button.active{background:var(--color-primary, #3b82f6);border-color:var(--color-primary, #3b82f6);color:#fff}.filter-button:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.collection-content{flex:1;padding:var(--spacing-xl, 24px);overflow-y:auto}.collection-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--spacing-md, 16px);color:var(--color-text-secondary, #6b7280)}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border, #e5e7eb);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.collection-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--spacing-sm, 8px);padding:var(--spacing-xl, 24px);text-align:center;color:var(--color-error, #ef4444)}.error-detail{font-size:var(--font-size-sm, 14px);color:var(--color-text-secondary, #6b7280)}.collection-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--spacing-md, 16px);padding:var(--spacing-2xl, 32px);text-align:center;color:var(--color-text-secondary, #6b7280)}.empty-title{margin:0;font-size:var(--font-size-xl, 20px);font-weight:600;color:var(--color-text, #1f2937)}.empty-message{margin:0;max-width:400px;font-size:var(--font-size-md, 16px);line-height:1.5}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-lg, 20px)}.avatar-card{position:relative;display:flex;flex-direction:column;background:#fff;border:2px solid var(--color-border-light, #f3f4f6);border-radius:var(--border-radius-lg, 12px);overflow:hidden;cursor:pointer;transition:all .2s ease}.avatar-card:hover{border-color:var(--color-primary, #3b82f6);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));transform:translateY(-2px)}.avatar-card:focus-visible{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.avatar-card-portrait-wrapper{position:relative;width:100%;aspect-ratio:1;overflow:hidden;background:var(--color-bg-secondary, #f9fafb)}.avatar-card-portrait{width:100%;height:100%;object-fit:cover}.avatar-new-badge{position:absolute;top:var(--spacing-sm, 8px);right:var(--spacing-sm, 8px);display:inline-flex;align-items:center;gap:var(--spacing-xs, 4px);padding:var(--spacing-xs, 4px) var(--spacing-sm, 8px);background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;border-radius:var(--border-radius-full, 9999px);font-size:var(--font-size-xs, 11px);font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1));animation:newBadgePulse 2s ease-in-out infinite}@keyframes newBadgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.avatar-card-indicator{position:absolute;bottom:var(--spacing-sm, 8px);left:var(--spacing-sm, 8px)}.avatar-card-info{padding:var(--spacing-md, 16px)}.avatar-card-name{margin:0 0 var(--spacing-xs, 4px) 0;font-size:var(--font-size-lg, 18px);font-weight:600;color:var(--color-text, #1f2937);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-card-title{margin:0 0 var(--spacing-sm, 8px) 0;font-size:var(--font-size-sm, 14px);color:var(--color-text-secondary, #6b7280);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-card-unlock-date{margin:0;font-size:var(--font-size-xs, 12px);color:var(--color-text-muted, #9ca3af)}@media(max-width:1024px){.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-md, 16px)}}@media(max-width:768px){.avatar-collection-view{height:100vh;max-height:none;border-radius:0}.collection-header{padding:var(--spacing-md, 16px)}.collection-title{font-size:var(--font-size-xl, 20px)}.collection-filters{padding:var(--spacing-sm, 8px) var(--spacing-md, 16px);overflow-x:auto;-webkit-overflow-scrolling:touch}.filter-button{flex-shrink:0}.collection-content{padding:var(--spacing-md, 16px)}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sm, 12px)}.avatar-card-info{padding:var(--spacing-sm, 12px)}.avatar-card-name{font-size:var(--font-size-md, 16px)}}@media(prefers-reduced-motion:reduce){.avatar-card,.filter-button,.collection-close-button{transition:none}.avatar-card:hover{transform:none}.avatar-new-badge{animation:none}.loading-spinner{animation:none;border-top-color:var(--color-border, #e5e7eb)}}.avatar-marker-icon{background:transparent;border:none;cursor:pointer;transition:transform .2s ease-in-out}.avatar-marker-icon:hover{transform:scale(1.1)}.avatar-marker-outer{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid;box-shadow:0 2px 8px #0003;background:#fff;transition:all .2s ease-in-out}.avatar-marker-inner{width:12px;height:12px;border-radius:50%;background:currentColor}.avatar-marker--active .avatar-marker-outer{border-color:#10b981;color:#10b981}.avatar-marker--inactive .avatar-marker-outer{border-color:#6b7280;color:#6b7280}.avatar-marker--quest_giving .avatar-marker-outer{border-color:#f59e0b;color:#f59e0b;animation:pulse-avatar 2s ease-in-out infinite}@keyframes pulse-avatar{0%,to{box-shadow:0 2px 8px #0003,0 0 #f59e0b66}50%{box-shadow:0 2px 8px #0003,0 0 0 8px #f59e0b00}}.avatar-marker-tooltip .avatar-tooltip-content{display:flex;flex-direction:column;gap:4px;padding:4px;min-width:120px}.avatar-tooltip-content .avatar-name{font-size:14px;font-weight:600;color:#1f2937;margin:0}.avatar-tooltip-content .avatar-title{font-size:12px;color:#6b7280;font-style:italic}.avatar-tooltip-content .avatar-status{font-size:11px;font-weight:500;padding:2px 6px;border-radius:4px;display:inline-block;margin-top:2px}.avatar-status--active{background-color:#d1fae5;color:#065f46}.avatar-status--inactive{background-color:#f3f4f6;color:#374151}.avatar-status--quest_giving{background-color:#fef3c7;color:#92400e}.avatar-marker-popup .avatar-popup-content{min-width:200px;padding:8px}.avatar-popup-header{display:flex;gap:12px;align-items:center;margin-bottom:12px}.avatar-marker-popup .avatar-portrait{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb}.avatar-marker-popup .avatar-header-text{flex:1}.avatar-marker-popup .avatar-popup-name{margin:0;font-size:16px;font-weight:600;color:#1f2937}.avatar-marker-popup .avatar-popup-title{margin:2px 0 0;font-size:13px;color:#6b7280;font-style:italic}.avatar-popup-meta{display:flex;gap:8px;margin-bottom:12px}.avatar-interact-button{display:block;width:100%;padding:8px 12px;background-color:#3b82f6;color:#fff;text-align:center;border-radius:6px;text-decoration:none;font-weight:500;font-size:14px;transition:background-color .2s ease-in-out}.avatar-interact-button:hover{background-color:#2563eb}.avatar-dialog-button{display:block;width:100%;padding:8px 12px;margin-bottom:8px;border:1px solid #c7d2fe;border-radius:6px;background:#eef2ff;color:#3730a3;font-weight:600;font-size:14px;cursor:pointer}.avatar-dialog-button:hover{background:#e0e7ff}.avatar-marker-icon:focus{outline:2px solid #3b82f6;outline-offset:2px}@media(max-width:768px){.avatar-marker-outer{width:28px;height:28px}.avatar-marker-inner{width:10px;height:10px}.avatar-marker-popup .avatar-portrait{width:40px;height:40px}}.avatar-marker--locked .avatar-marker-outer{border-color:#ef4444;color:#ef4444;opacity:.7}.avatar-marker-lock{position:absolute;top:-2px;right:-2px;width:12px;height:12px;background:#ef4444;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;color:#fff}.avatar-marker-lock:before{content:"🔒"}.avatar-lock-indicator-wrapper{margin-top:4px}.avatar-locked-message{padding:8px;margin:0;font-size:13px;color:#6b7280;text-align:center;font-style:italic;background:#fef2f2;border-radius:4px;border:1px solid #fecaca}.quest-dialog-backdrop{position:fixed;inset:0;background:#0f172ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out;padding:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.quest-dialog-modal{background:transparent;border:none;border-radius:0;box-shadow:none;width:100vw;height:100vh;max-width:none;max-height:none;overflow:visible;padding:0;position:relative;animation:scaleIn .2s ease-out}.quest-dialog-modal:before{display:none}.quest-dialog-modal:after{display:none}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.quest-dialog-close{position:absolute;top:clamp(18px,2vw,28px);right:clamp(18px,2vw,28px);background:#33415599;border:none;border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#cbd5e1;transition:all .2s ease;z-index:10}.quest-dialog-close:hover{background:#334155e6;color:#fff;transform:scale(1.05)}.quest-dialog-header{text-align:left;margin-bottom:18px}.quest-dialog-title{font-size:clamp(1.9rem,2.2vw,2.6rem);font-weight:700;color:#f1f5f9;margin:0 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.quest-dialog-avatar-name{font-size:1rem;color:#94a3b8;margin:0;font-style:italic}.quest-dialog-content{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,1fr) minmax(360px,1fr);gap:clamp(20px,2.5vw,40px);width:100%;height:100%;padding:clamp(28px,4vw,56px) clamp(32px,4vw,56px) 0;align-items:stretch;min-height:100vh;box-sizing:border-box}.quest-dialog-stage-spacer{min-width:0}.quest-dialog-sprite-column{display:flex;justify-content:center;align-items:flex-end;position:relative;z-index:1;min-height:0;overflow:visible}.quest-dialog-sprite-panel{position:relative;width:100%;height:100%;overflow:visible}.quest-dialog-sprite-image{position:absolute;left:50%;bottom:0;width:auto;height:clamp(540px,88vh,1280px);max-width:none;max-height:none;object-fit:contain;object-position:center bottom;transform:translate(-50%);display:block}.sprite-layer{transition:opacity .45s ease-in-out}.sprite-layer--active{opacity:1;z-index:1}.sprite-layer--hidden{opacity:0;z-index:0}.quest-dialog-details{position:relative;z-index:2;min-width:0;display:flex;align-items:center;justify-content:flex-start;min-height:0;padding-bottom:clamp(20px,3vw,36px)}.quest-dialog-details-shell{width:min(100%,42rem);max-height:min(88vh,980px);overflow-y:auto;padding:clamp(24px,2vw,30px);padding-right:clamp(12px,1.2vw,18px);border:1px solid rgba(148,163,184,.18);border-radius:24px;background:linear-gradient(180deg,#080f1feb,#0f172ad6),radial-gradient(circle at top,rgba(96,165,250,.08),transparent 45%);box-shadow:0 28px 60px #02061775,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.quest-dialog-text{width:100%;min-height:0;position:relative;padding:14px 16px;border-radius:18px;border:1px solid transparent;transition:background-color .25s ease,border-color .25s ease,box-shadow .25s ease}.quest-dialog-text.is-processing{background:#0f172ab8;border-color:#94a3b880;box-shadow:0 10px 24px #02061761}.animated-text-container{display:flex;flex-direction:column;align-items:stretch;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.animated-text-content{color:#f1f5f9;font-size:clamp(1.05rem,.28vw + .98rem,1.18rem);line-height:1.68;text-shadow:0 1px 2px rgba(2,6,23,.55)}.animated-paragraph{margin:0 0 10px;text-align:left}.animated-paragraph.completed{opacity:.8}.animated-paragraph.current{opacity:1}.typewriter-cursor{display:inline-block;width:2px;background:#60a5fa;animation:blink 1s step-end infinite;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.skip-hint{position:static;align-self:flex-end;font-size:11px;color:#64748b;font-style:italic;margin-top:0;animation:fadeInOut 2s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.4}50%{opacity:1}}.quest-dialog-conditions{margin-top:0;border:1px solid transparent;border-radius:18px;background:transparent;padding:0 12px;max-height:0;overflow:hidden;opacity:0;transform:translateY(8px);transition:opacity .7s ease,transform .7s ease,max-height .7s ease,margin-top .7s ease,padding .7s ease,border-color .7s ease}.quest-dialog-conditions.is-visible{margin-top:14px;padding:14px 16px;max-height:320px;opacity:1;transform:translateY(0);border-color:#94a3b880;background:#0f172ab8;box-shadow:0 10px 24px #02061757}.quest-dialog-conditions h3{margin:0 0 8px;font-size:1rem;font-weight:700;color:#f8fafc}.quest-dialog-conditions ul{margin:0;padding-left:16px;display:grid;gap:6px}.quest-dialog-conditions li{font-size:1rem;line-height:1.45;color:#f1f5f9;text-shadow:0 1px 2px rgba(2,6,23,.5)}.quest-dialog-conditions li.met{color:#86efac}.quest-dialog-conditions li.not-met{color:#fda4af}.quest-dialog-conditions-empty{margin:0;color:#94a3b8;font-size:.98rem}.quest-dialog-actions{display:flex;gap:16px;justify-content:flex-end;margin-top:18px;padding-top:16px;border-top:1px solid rgba(148,163,184,.22);position:static;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .85s ease,transform .85s ease}.quest-dialog-actions.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}.quest-dialog-actions button{min-width:140px;padding:12px 24px;font-size:16px;font-weight:600;border-radius:10px;transition:all .3s ease;box-shadow:0 2px 8px #00000026}.quest-dialog-actions button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #00000040}.quest-dialog-actions button:active:not(:disabled){transform:translateY(0)}.quest-dialog-actions button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none}.quest-dialog-modal.loading,.quest-dialog-modal.error{display:flex;align-items:center;justify-content:center;width:min(720px,calc(100vw - 32px));height:auto;min-height:300px;padding:32px}.quest-dialog-loading{font-size:18px;color:#94a3b8;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.quest-dialog-error{text-align:center}.quest-dialog-error h2{font-size:24px;color:#f87171;margin:0 0 12px}.quest-dialog-error p{font-size:16px;color:#94a3b8;margin:0}@media(max-width:768px){.quest-dialog-backdrop{padding:20px 8px}.quest-dialog-modal{width:calc(100vw - 16px);height:auto;padding:16px 12px;border-radius:12px;max-height:95vh;overflow-y:auto}.quest-dialog-modal:before{display:none}.quest-dialog-modal:after{display:none}.quest-dialog-title{font-size:24px}.quest-dialog-content{grid-template-columns:1fr;gap:12px;width:auto;height:auto;padding:0;min-height:auto;margin-bottom:12px}.quest-dialog-stage-spacer{display:none}.quest-dialog-sprite-column{position:static;opacity:1;transform:none;pointer-events:auto;margin-top:12px;min-height:auto;overflow:visible}.quest-dialog-sprite-panel{min-height:auto;height:auto}.quest-dialog-sprite-image{position:static;width:auto;height:min(28vh,240px);transform:none;margin:0 auto}.quest-dialog-details{display:block}.quest-dialog-details-shell{width:100%;max-height:none;overflow:visible;padding:0;border:none;border-radius:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.quest-dialog-actions{flex-direction:column-reverse;justify-content:stretch}.quest-dialog-actions button{width:100%}}.quest-dialog-modal.reward-popup{background:linear-gradient(135deg,#1a2847,#243556);border:1px solid rgba(79,179,255,.16);border-radius:16px;height:auto;padding:16px 16px 12px;width:min(860px,calc(100vw - 32px));max-width:none}.quest-dialog-modal.reward-popup .quest-dialog-close{top:12px;right:12px;background:#94a3b82e;border:1px solid rgba(148,163,184,.25);color:#dbeafe}.quest-dialog-modal.reward-popup .quest-dialog-close:hover{background:#94a3b84d;color:#fff}.reward-dialog-content{margin-bottom:14px;min-height:clamp(420px,66vh,820px);grid-template-columns:minmax(280px,.9fr) minmax(0,1.1fr);gap:clamp(14px,1.6vw,24px)}.reward-sprite-column{display:flex;justify-content:center;align-items:flex-end}.reward-sprite-panel{position:relative;width:100%;min-height:clamp(420px,66vh,820px);overflow:visible;display:flex;justify-content:center}.reward-sprite-image{position:absolute;left:50%;bottom:0;width:auto;height:min(84vh,860px);object-fit:contain;object-position:center bottom;transform:translate(-50%);display:block}.reward-dialog-details{max-height:clamp(420px,70vh,760px);overflow-y:auto;padding:8px clamp(6px,1vw,12px) 4px}.reward-display{display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center}.reward-title{margin:0;font-size:clamp(1.8rem,2.3vw,2.15rem);font-weight:700;color:#fff}.reward-subtitle{margin:0;font-size:1rem;color:#ffffffc9}.reward-unlock-banner{display:flex;align-items:center;justify-content:center;width:100%;max-width:560px;padding:12px 16px;background:#22c55e1a;border:1px solid rgba(34,197,94,.22);border-radius:8px;margin-top:2px}.unlock-emoji{font-size:1.5rem;flex-shrink:0}.unlock-text{font-size:1rem;font-weight:600;color:#22c55e}.achievement-text{font-size:clamp(1.25rem,2.2vw,1.75rem);font-weight:800;line-height:1.16;letter-spacing:.02em;text-transform:uppercase;color:#86efac;text-shadow:0 0 8px rgba(34,197,94,.26)}.reward-items{display:flex;flex-direction:column;gap:10px;width:100%;max-width:560px}.reward-items .reward-item--stat{min-height:64px}.reward-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 14px;background:#ffffff0d;border:1px solid rgba(79,179,255,.12);border-radius:8px}.reward-emoji{font-size:1.75rem;flex-shrink:0}.reward-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex:1}.reward-label{display:block;font-size:.85rem;color:#fff9;text-transform:uppercase;letter-spacing:.05em}.reward-value{display:block;font-size:1.15rem;font-weight:600;color:#22c55e}.reward-meter{display:flex;flex-direction:column;gap:8px;width:100%;max-width:380px;margin:4px auto 0}.reward-meter-label{font-size:.8rem;color:#fff9;text-transform:uppercase;letter-spacing:.04em}.reward-meter-bar{height:8px;background:#0000004d;border-radius:4px;overflow:hidden;border:1px solid rgba(79,179,255,.15)}.reward-meter-values{font-size:.86rem;color:#e2e8f0eb;letter-spacing:.01em}.reward-meter-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#22c55e);border-radius:4px;transition:width .8s ease-out}.reward-button{margin-top:12px;min-width:170px;padding:.82rem 2.2rem!important}@media(max-width:768px){.quest-dialog-modal.reward-popup{width:min(96vw,720px);padding:16px}.reward-dialog-content{display:flex;flex-direction:column;gap:12px;min-height:auto;margin-bottom:10px}.reward-sprite-panel{min-height:240px}.reward-sprite-image{position:static;width:100%;height:min(48vh,360px);transform:none;margin:0 auto}.reward-dialog-details{max-height:none;overflow:visible;padding-right:0}}@media(min-width:1024px){.quest-dialog-details{justify-content:center}}.final-quest-backdrop{position:fixed;inset:0;z-index:1300;display:grid;place-items:start center;background:radial-gradient(circle at top,rgba(245,158,11,.16),transparent 30%),radial-gradient(circle at bottom,rgba(236,72,153,.14),transparent 38%),#0a0a12d1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow-y:auto;padding:clamp(12px,2vw,24px)}.final-quest-modal{position:relative;width:min(920px,calc(100vw - (2*clamp(12px,2vw,24px))));max-height:calc(100dvh - (2*clamp(12px,2vw,24px)));margin:auto 0;overflow-x:hidden;overflow-y:auto;border-radius:32px;border:1px solid rgba(255,255,255,.18);box-shadow:0 36px 90px #0000007a;color:#fff7ed;animation:finalQuestRise .3s ease;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.28) transparent}.final-quest-modal--achievement{width:min(1080px,calc(100vw - (2*clamp(12px,2vw,24px))))}.final-quest-modal--completion{background:linear-gradient(145deg,#581c87f0,#9d174de6),linear-gradient(180deg,rgba(255,255,255,.06),transparent)}.final-quest-modal--achievement{background:linear-gradient(145deg,#4338caf5,#9d174deb),linear-gradient(180deg,rgba(255,255,255,.08),transparent);border-color:#facc156b;box-shadow:0 0 0 1px #fde04747,0 0 44px #f59e0b57,0 0 120px #facc1538,0 36px 90px #0000007a}.final-quest-close{position:absolute;top:18px;right:18px;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:#0f172a6b;color:#fff7ed;cursor:pointer}.final-quest-glow{position:absolute;border-radius:999px;filter:blur(12px);opacity:.72}.final-quest-glow--one{top:-80px;left:-40px;width:280px;height:280px;background:#fbbf2438}.final-quest-glow--two{right:-60px;bottom:-100px;width:320px;height:320px;background:#f472b633}.final-quest-glow--gold{inset:-16% -10%;border-radius:40px;background:radial-gradient(circle at center,rgba(250,204,21,.28),transparent 42%),radial-gradient(circle at 50% 35%,rgba(255,247,146,.18),transparent 28%);filter:blur(26px);opacity:.9}.final-quest-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;padding:clamp(44px,6vh,56px) clamp(24px,3vw,40px) clamp(28px,4vh,40px);text-align:center}.final-quest-content--achievement{gap:14px;padding:clamp(44px,6vh,56px) clamp(18px,3vw,48px) clamp(24px,4vh,40px)}.final-quest-kicker{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:#ffffff1f;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:700;color:#fde68a}.final-quest-kicker--achievement{color:#fbcfe8}.final-quest-title{margin:0;font-size:clamp(2.2rem,4vw,3.6rem);line-height:1;text-shadow:0 10px 30px rgba(0,0,0,.24)}.final-quest-title--achievement{max-width:14ch;font-size:clamp(1.9rem,4.4vw,3.5rem)}.final-quest-subtitle{margin:0;max-width:700px;font-size:1.05rem;line-height:1.55;color:#fff7edd6}.final-quest-subtitle--achievement{font-size:1.2rem;color:#fef3c7}.final-quest-message-card{width:min(720px,100%);padding:26px;border-radius:24px;background:#0f172a3d;border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px #ffffff14}.final-quest-message{margin:0;font-size:clamp(1.05rem,2vw,1.35rem);line-height:1.75}.final-quest-reward-callout{display:inline-flex;align-items:center;gap:.55rem;max-width:min(560px,100%);padding:.75rem 1rem;border-radius:999px;background:#fef08a2e;border:1px solid rgba(253,224,71,.3);color:#fef3c7;font-size:.92rem;font-weight:700}.final-quest-permanent-item{display:flex;align-items:center;gap:16px;width:min(540px,100%);padding:18px 20px;border-radius:22px;background:linear-gradient(135deg,#facc1538,#f973162e);border:1px solid rgba(253,224,71,.32);text-align:left}.final-quest-permanent-item__icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:16px;background:#ffffff29;color:#fef08a;flex-shrink:0}.final-quest-permanent-item__body{display:flex;flex-direction:column;gap:4px}.final-quest-permanent-item__label{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:#fff7edc2}.final-quest-permanent-item__name{font-size:1.15rem;color:#fff}.final-quest-note{margin:0;max-width:640px;color:#fff7edc7;line-height:1.6}.final-quest-achievement-frame{width:min(860px,100%);padding:clamp(12px,1.6vw,20px);border-radius:32px;background:linear-gradient(180deg,#ffffff2e,#ffffff0a);border:1px solid rgba(255,255,255,.18);box-shadow:0 20px 40px #00000052,inset 0 1px #ffffff2e}.final-quest-achievement-image{display:block;width:100%;max-height:min(58dvh,640px);object-fit:contain;border-radius:24px}.final-quest-achievement-text{margin:0;max-width:760px;font-size:clamp(.98rem,1.35vw,1.05rem);line-height:1.65;color:#fff7ede0}.final-quest-button{min-width:220px}@keyframes finalQuestRise{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.final-quest-backdrop{padding:16px}.final-quest-modal{max-height:calc(100dvh - 32px)}.final-quest-content{padding:52px 20px 28px}.final-quest-content--achievement{padding:52px 16px 32px}.final-quest-message-card,.final-quest-permanent-item,.final-quest-achievement-frame{width:100%}.final-quest-permanent-item{flex-direction:column;text-align:center}}.avatar-unlock-backdrop{position:fixed;inset:0;z-index:calc(var(--z-modal) + 10);display:flex;align-items:center;justify-content:center;padding:0;background:#020617d1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.avatar-unlock-modal{position:relative;width:100vw;height:100vh;border:1px solid var(--color-border-strong);background:radial-gradient(circle at 72% 16%,rgba(79,179,255,.16),transparent 52%),linear-gradient(135deg,#0f1724f0,#0f1724e0);box-shadow:var(--shadow-lg);overflow:hidden}.avatar-unlock-top-close{position:absolute;top:16px;right:16px;width:42px;height:42px;border:1px solid var(--color-border);background:#ffffff1f;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition-fast),background-color var(--transition-base);z-index:2}.avatar-unlock-top-close:hover{background:#fff3;transform:translateY(-1px)}.avatar-unlock-layout{height:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,1fr) minmax(360px,1fr);gap:clamp(20px,2.5vw,40px);width:100%;padding:clamp(28px,4vw,56px) clamp(32px,4vw,56px) 0;align-items:stretch;box-sizing:border-box}.avatar-unlock-stage-spacer{min-width:0}.avatar-unlock-sprite-column{display:flex;justify-content:center;align-items:flex-end;position:relative;z-index:1;min-height:0;overflow:visible}.avatar-unlock-sprite-panel{position:relative;width:100%;height:100%;overflow:visible}.avatar-unlock-sprite{position:absolute;left:50%;bottom:0;width:auto;height:clamp(540px,88vh,1280px);max-width:none;max-height:none;object-fit:contain;object-position:center bottom;transform:translate(-50%);display:block;filter:drop-shadow(0 26px 54px rgba(0,0,0,.46));pointer-events:none}.avatar-unlock-content{display:flex;align-items:center;justify-content:flex-start;min-height:0;padding-bottom:clamp(20px,3vw,36px);position:relative;z-index:2}.avatar-unlock-content-inner{width:min(100%,36rem);display:flex;flex-direction:column;gap:18px;padding:clamp(24px,2vw,30px);border:1px solid rgba(148,163,184,.18);border-radius:24px;background:linear-gradient(180deg,#080f1feb,#0f172ad6),radial-gradient(circle at top,rgba(96,165,250,.08),transparent 45%);box-shadow:0 28px 60px #02061775,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.avatar-unlock-title{margin:0;font-family:var(--font-family-display);font-size:clamp(2rem,3.2vw,2.8rem);line-height:1.1;letter-spacing:.02em;text-transform:uppercase;color:#fff}.avatar-unlock-subtitle{margin:0;color:#ffffffd1;font-size:clamp(1rem,1.5vw,1.15rem);line-height:var(--line-height-relaxed)}.avatar-unlock-banner{border:1px solid rgba(16,185,129,.38);background:#10b9811f;padding:14px 18px;clip-path:var(--clip-tag)}.avatar-unlock-banner-text{display:block;margin:0;color:#86efac;font-weight:800;letter-spacing:.03em;text-transform:uppercase;font-size:clamp(1rem,1.7vw,1.25rem);line-height:1.25}.avatar-unlock-close-button{width:fit-content;min-width:228px;margin-top:10px;padding:.82rem 1.85rem;border:1px solid rgba(79,179,255,.45);background:linear-gradient(180deg,#4fb3ff38,#4fb3ff1f);color:#eaf6ff;font-weight:700;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;clip-path:var(--clip-button);box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-base),background-color var(--transition-base),border-color var(--transition-base)}.avatar-unlock-close-button:hover:not(:disabled){transform:translateY(-1px);border-color:#4fb3ffb3;background:linear-gradient(180deg,#4fb3ff5c,#4fb3ff33);box-shadow:var(--shadow-lg)}.avatar-unlock-close-button:focus-visible{outline:none;box-shadow:var(--shadow-glow)}@media(max-width:980px){.avatar-unlock-backdrop{padding:16px}.avatar-unlock-modal{width:100%;height:100%}.avatar-unlock-layout{grid-template-columns:1fr;grid-template-rows:minmax(220px,40vh) 1fr;gap:16px;padding:68px 16px 16px}.avatar-unlock-stage-spacer{display:none}.avatar-unlock-sprite{height:min(62vh,620px)}.avatar-unlock-content{justify-content:center;padding-bottom:0}.avatar-unlock-content-inner{width:min(100%,40rem)}}.map-page{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.map-page-container{flex:1;position:relative;background-color:var(--color-bg-tertiary);padding:0;min-height:0}.map-initial-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:300;color:#e2e8f0;font-weight:600;letter-spacing:.01em;background:linear-gradient(180deg,#0f172ad1,#020617d1)}.map-quest-zoom-hint{position:absolute;left:50%;bottom:1rem;transform:translate(-50%);z-index:500;padding:.65rem .9rem;border:1px solid var(--color-border, #dce3ea);background:#111827d1;color:#f8fafc;border-radius:10px;font-size:.88rem;box-shadow:0 8px 22px #0f172a40;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.map-zoom-level{position:absolute;top:.5rem;left:.5rem;z-index:500;padding:.4rem .65rem;border-radius:8px;border:1px solid var(--color-border, #dce3ea);background:#111827d1;color:#f8fafc;font-size:.82rem;font-weight:600;letter-spacing:.01em}.map-quest-nav{position:absolute;right:.5rem;top:.5rem;z-index:500;display:flex;align-items:center;gap:.5rem;padding:.35rem;border-radius:10px;border:1px solid var(--color-border, #dce3ea);background:#111827d1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.map-quest-nav-label{color:#94a3b8;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:0 .25rem;white-space:nowrap;-webkit-user-select:none;user-select:none}.map-quest-nav-select{appearance:none;border:1px solid rgba(148,163,184,.45);background:#1e293beb;color:#f8fafc;border-radius:8px;min-width:200px;height:32px;font-size:.8rem;font-weight:500;cursor:pointer;padding:0 .75rem}.map-quest-nav-select:hover{background:#334155f2}.map-quest-nav-select:focus{outline:none;border-color:#60a5fabf;box-shadow:0 0 0 2px #3b82f638}@media(max-width:768px){.map-page-container{padding:0}.map-quest-zoom-hint{width:calc(100% - 1rem);left:.5rem;right:.5rem;transform:none;text-align:center}.map-zoom-level{top:.4rem;left:.4rem}.map-quest-nav{top:.4rem;right:.4rem}}
