:root{--breakpoint-xs: 360px;--breakpoint-sm: 390px;--breakpoint-md: 412px;--breakpoint-lg: 430px;--breakpoint-xl: 768px;--breakpoint-xxl: 1024px;--touch-target-min: 44px;--touch-target-comfortable: 48px;--font-scale-xs: .75;--font-scale-sm: .875;--font-scale-base: 1;--font-scale-lg: 1.125;--font-scale-xl: 1.25;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-xxl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 50%;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--rarity-common: #9ca3af;--rarity-uncommon: #fbbf24;--rarity-rare: #ef4444;--rarity-unique: #a855f7;--rarity-legendary: #d97706;--color-primary: #667eea;--color-primary-dark: #764ba2;--color-secondary: #8b5cf6;--color-accent: #f59e0b;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--base-font-size: 16px;--base-font-size-sm: 15px;--base-font-size-xs: 14px}@media (max-width: 430px){:root{--base-font-size: 15px}}@media (max-width: 390px){:root{--base-font-size: 14px}}@media (max-width: 360px){:root{--base-font-size: 14px}}: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;min-width:100vw;min-height:100vh;width:100vw;height:100vh;overflow-x:hidden;background-color:#242424}#root{width:100%;height:100%;display:flex;flex-direction:column}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}.full-width{width:100%;max-width:100vw;box-sizing:border-box}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.facts-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:20px;margin-top:16px;margin-bottom:40px;color:#fff;box-shadow:0 4px 16px #0000004d;min-height:120px;width:100%;box-sizing:border-box;position:relative;overflow:hidden}.facts-header{text-align:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.facts-header h3{margin:0;font-size:18px;color:#8b5cf6;font-weight:600;text-shadow:0 2px 10px rgba(139,92,246,.3)}.facts-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80px}.fact-card{background:#ffffff0d;padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);width:100%;transition:all .3s ease;position:relative;overflow:hidden}.fact-card:hover{background:#ffffff14;transform:translateY(-2px);border-color:#fff3;box-shadow:0 6px 20px #0003}.fact-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#8b5cf6,#667eea);opacity:0;transition:opacity .3s ease}.fact-card:hover:before{opacity:1}.fact-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.fact-emoji{font-size:20px;flex-shrink:0}.fact-category{background:#8b5cf633;color:#8b5cf6;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(139,92,246,.3)}.fact-text{margin-bottom:12px}.fact-text p{margin:0;font-size:18px;line-height:1.6;color:#ffffffe6;text-align:left}.fact-tags{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.tags-label{margin:0 0 8px;font-size:12px;color:#ffffffb3;font-weight:500}.tags-list{display:flex;flex-wrap:wrap;gap:6px}.creature-tag{background:#667eea33;color:#667eea;padding:4px 8px;border-radius:8px;font-size:11px;font-weight:600;text-transform:capitalize;border:1px solid rgba(102,126,234,.3)}.facts-loading{text-align:center;padding:20px}.loading-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.1);border-top:3px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.facts-loading p{margin:0;font-size:14px;color:#fffc}.facts-error{text-align:center;padding:16px;background:#ef44441a;border-radius:8px;border:1px solid rgba(239,68,68,.3);width:100%}.facts-error p{margin:0;color:#ef4444;font-size:14px;font-weight:500}.no-facts{text-align:center;padding:20px;width:100%}.no-facts p{margin:0;font-size:14px;color:#ffffffb3;font-style:italic}@media (max-width: 480px){.facts-panel{padding:16px;margin-top:12px;margin-bottom:30px;border-radius:10px;min-height:100px}.facts-header{margin-bottom:12px;padding-bottom:10px}.facts-header h3{font-size:16px}.fact-card{padding:14px}.fact-header{gap:8px;margin-bottom:10px}.fact-emoji{font-size:18px}.fact-category{font-size:11px;padding:3px 8px}.fact-text p{font-size:17px;line-height:1.5}.tags-label{font-size:11px}.creature-tag{font-size:10px;padding:3px 6px}.facts-loading,.no-facts{padding:16px}.facts-loading p,.no-facts p{font-size:13px}}@media (max-width: 320px){.facts-panel{padding:12px;margin-bottom:25px}.facts-header h3{font-size:15px}.fact-card{padding:12px}.fact-text p{font-size:16px}.creature-tag{font-size:9px;padding:2px 5px}}@media (max-height: 600px) and (orientation: landscape){.facts-panel{margin-bottom:20px;min-height:80px}.fact-card,.facts-loading,.no-facts{padding:12px}}@media (prefers-contrast: high){.fact-card{border-color:#fff6}.fact-category{border-color:#8b5cf699}.creature-tag{border-color:#667eea99}}@media (prefers-reduced-motion: reduce){.fact-card,.loading-spinner{animation:none;transition:none}.fact-card:hover{transform:none}}.creature-icon-container{position:relative;pointer-events:auto!important;transition:all .3s cubic-bezier(.4,0,.2,1);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.creature-icon-container:hover{filter:brightness(1.1) saturate(1.1)}.creature-icon-container:active{transition:all .1s ease}.creature-icon-container img{transition:filter .2s ease}.creature-icon-container[data-selected=true]{animation:selectedPulse 2s ease-in-out infinite}@keyframes selectedPulse{0%,to{box-shadow:0 4px 16px #0009,0 0 0 3px var(--creature-color),0 0 0 5px #fffc}50%{box-shadow:0 6px 20px #000c,0 0 0 3px var(--creature-color),0 0 0 5px #fff,0 0 20px var(--creature-color)}}.creature-trail-dot{position:relative;pointer-events:auto!important;cursor:pointer;transition:all .2s ease}.creature-trail-dot:hover{z-index:10!important}.trail-dot-inner{transition:all .2s cubic-bezier(.4,0,.2,1)!important;border-style:solid;box-sizing:border-box}.creature-trail-dot:hover .trail-dot-inner{animation:trailDotHover .3s ease}@keyframes trailDotHover{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1.2)}}.date-popup{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);white-space:nowrap}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.creature-icon-container[data-creature-rarity=common]{--creature-color: #6b7280}.creature-icon-container[data-creature-rarity=uncommon]{--creature-color: #10b981}.creature-icon-container[data-creature-rarity=rare]{--creature-color: #3b82f6}.creature-icon-container[data-creature-rarity=unique]{--creature-color: #8b5cf6;animation:uniqueGlow 3s ease-in-out infinite}.creature-icon-container[data-creature-rarity=legendary]{--creature-color: #f59e0b;animation:legendaryGlow 2s ease-in-out infinite}@keyframes uniqueGlow{0%,to{box-shadow:0 3px 12px #0006,0 0 0 1px #8b5cf64d}50%{box-shadow:0 3px 12px #0006,0 0 0 1px #8b5cf699,0 0 15px #8b5cf666}}@keyframes legendaryGlow{0%,to{box-shadow:0 3px 12px #0006,0 0 0 1px #f59e0b66}33%{box-shadow:0 3px 12px #0006,0 0 0 1px #f59e0bb3,0 0 20px #f59e0b80}66%{box-shadow:0 3px 12px #0006,0 0 0 1px #f59e0be6,0 0 25px #f59e0b99,0 0 35px #f59e0b4d}}@media (max-width: 480px){.creature-icon-container{min-width:44px;min-height:44px}.creature-trail-dot{min-width:32px;min-height:32px}.date-popup{max-width:250px;font-size:11px}}@media (prefers-reduced-motion: reduce){.creature-icon-container,.creature-trail-dot,.trail-dot-inner{animation:none!important;transition:none!important}.creature-icon-container:hover,.creature-trail-dot:hover{transform:none!important}}@media (prefers-contrast: high){.creature-icon-container{border-width:3px!important;border-color:#fff!important}.trail-dot-inner{border-width:2px!important;border-color:#fff!important}.date-popup{border-width:2px!important;background:#000000f2!important}}.creature-icon-container:focus{outline:3px solid #8b5cf6;outline-offset:2px}.creature-trail-dot:focus{outline:2px solid #8b5cf6;outline-offset:1px}.creature-icon-container.loading{opacity:.7;animation:loadingPulse 1.5s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.7}50%{opacity:1}}.creature-icon-container.error{border-color:#ef4444!important;background:#fef2f2!important}.creature-icon-container.error:after{content:"⚠️";position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:10px}.creature-icon-container,.creature-trail-dot{will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden}@media print{.creature-trail-dot,.date-popup{display:none!important}.creature-icon-container{animation:none!important;transition:none!important;box-shadow:none!important}}.globe-action-buttons{position:fixed;top:80px;left:0;right:0;display:flex;justify-content:space-between;padding:0 20px;z-index:1500;pointer-events:none;animation:slideInFromTop .3s ease}.globe-back-button,.globe-details-button{background:#fffffff2;color:#333;border:none;border-radius:12px;padding:12px 16px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 15px #0003;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);transition:all .3s ease;display:flex;align-items:center;gap:8px;min-height:var(--touch-target-min);pointer-events:auto;z-index:999;position:relative;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none}.globe-details-button{background:#8b5cf6f2;color:#fff;border:1px solid rgba(139,92,246,.3)}.globe-details-button:hover{background:#8b5cf6;transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.globe-back-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.globe-back-button:active,.globe-details-button:active{transform:translateY(0);box-shadow:0 2px 10px #0003}.back-icon,.details-icon{font-size:16px;font-weight:700}.back-text,.details-text{font-size:14px}@media (max-width: 430px){.globe-action-buttons{top:70px;padding:0 16px}.globe-back-button,.globe-details-button{padding:10px 14px;font-size:13px;min-height:40px}.back-icon,.details-icon{font-size:14px}.back-text,.details-text{font-size:13px}}@media (max-width: 360px){.globe-action-buttons{top:65px;padding:0 12px}.globe-back-button,.globe-details-button{padding:8px 12px;font-size:12px;gap:6px}.back-text,.details-text{font-size:12px}}@media (max-height: 500px) and (orientation: landscape){.globe-action-buttons{top:60px;padding:0 12px}.globe-back-button,.globe-details-button{padding:8px 12px;min-height:36px}}@media (prefers-contrast: high){.globe-back-button,.globe-details-button{border:2px solid #333}.globe-details-button{border-color:#fff}}@media (prefers-reduced-motion: reduce){.globe-action-buttons{animation:none}.globe-back-button,.globe-details-button{transition:none}.globe-back-button:hover,.globe-details-button:hover{transform:none}}@media (max-width: 280px){.globe-action-buttons{padding:0 8px}.globe-back-button,.globe-details-button{padding:6px 10px;font-size:11px;min-height:32px}.back-text,.details-text{font-size:11px}}.zoom-indicator{position:fixed;top:80px;z-index:1500;pointer-events:none;animation:slideInFromTop .3s ease}.zoom-indicator-left{left:20px}.zoom-indicator-center{left:50%;transform:translate(-50%)}.zoom-indicator-right{right:20px}.zoom-display{background:#000c;color:#fff;border-radius:8px;padding:8px 12px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 15px #0000004d;text-align:center;min-width:80px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.zoom-value{font-size:18px;font-weight:700;line-height:1.2;margin-bottom:2px;font-family:Courier New,monospace;text-shadow:0 1px 2px rgba(0,0,0,.5)}.zoom-label{font-size:10px;opacity:.8;text-transform:uppercase;letter-spacing:.5px;font-weight:500;color:#ffffffe6}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.zoom-indicator{top:70px}.zoom-indicator-left{left:16px}.zoom-indicator-right{right:16px}.zoom-display{padding:6px 10px;min-width:70px}.zoom-value{font-size:16px}.zoom-label{font-size:9px}}@media (max-width: 320px){.zoom-indicator{top:65px}.zoom-indicator-left{left:12px}.zoom-indicator-right{right:12px}.zoom-display{padding:5px 8px;min-width:60px}.zoom-value{font-size:14px}.zoom-label{font-size:8px}}@media (max-height: 500px) and (orientation: landscape){.zoom-indicator{top:60px}.zoom-display{padding:5px 8px}.zoom-value{font-size:14px}.zoom-label{font-size:8px}}@media (prefers-contrast: high){.zoom-display{border:2px solid white;background:#000000f2}}@media (prefers-reduced-motion: reduce){.zoom-indicator{animation:none}}.zoom-display:hover{background:#000000e6;transform:scale(1.05);transition:all .2s ease}.zoom-indicator.debug-mode .zoom-display{background:#8b5cf6e6;border-color:#8b5cf680;box-shadow:0 4px 15px #8b5cf666}.zoom-indicator.debug-mode .zoom-value{color:#fff!important}.zoom-indicator.minimal .zoom-display{background:#0009;padding:4px 8px;border:none;box-shadow:0 2px 8px #0003}.zoom-indicator.minimal .zoom-value{font-size:14px}.zoom-indicator.minimal .zoom-label{display:none}.discovery-overlay{position:fixed;inset:0;background:#000000e6;backdrop-filter:blur(10px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .4s ease}.discovery-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow:hidden;box-shadow:0 25px 80px #0009;border:1px solid rgba(139,92,246,.3);animation:modalSlideUp .5s ease;position:relative;display:flex;flex-direction:column}.discovery-close-btn{position:absolute;top:16px;right:16px;background:#ffffff1a;border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;z-index:10;transition:all .2s ease;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px)}.discovery-close-btn:hover:not(:disabled){background:#ef4444cc;transform:scale(1.1)}.discovery-close-btn:disabled{opacity:.5;cursor:not-allowed}.discovery-header{text-align:center;padding:30px 30px 20px;color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.discovery-header h2{margin:0 0 12px;font-size:24px;font-weight:700;background:linear-gradient(45deg,#8b5cf6,#667eea);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.discovery-header p{margin:0;font-size:14px;color:#fffc;line-height:1.5}.discovery-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#fff}.mystical-spinner{width:40px;height:40px;border:3px solid rgba(139,92,246,.3);border-top:3px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.discovery-loading p{margin:0;font-size:14px;color:#fffc}.discovery-error{padding:20px;text-align:center;color:#fff}.discovery-error p{margin:0 0 16px;color:#ef4444;font-size:14px}.discovery-error button{background:#ef4444;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.stones-container{padding:30px 20px 40px;display:flex;justify-content:center;align-items:center;min-height:300px}.stones-triangle{display:flex;flex-direction:column;align-items:center;gap:25px;width:100%;max-width:300px}.stone-row{display:flex;justify-content:center;width:100%}.stone-row.top{margin-bottom:10px}.stone-row.bottom{display:flex;justify-content:space-between;width:80%}.mystical-stone{width:90px;height:90px;cursor:pointer;transition:all .3s ease;position:relative;filter:drop-shadow(0 8px 16px rgba(0,0,0,.4))}.mystical-stone:hover{transform:translateY(-5px) scale(1.05);filter:drop-shadow(0 12px 24px rgba(0,0,0,.6))}.mystical-stone:active{transform:translateY(-2px) scale(1.02)}.stone-surface{width:100%;height:100%;background:linear-gradient(135deg,#6b7280,#4b5563,#374151);border-radius:20px;border:2px solid #9ca3af;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #ffffff1a,inset 0 -2px 4px #0003}.stone-surface:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.2) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(0,0,0,.1) 0%,transparent 50%);border-radius:18px;pointer-events:none}.rune-symbol{font-size:32px;color:#3b82f6;text-shadow:0 0 10px rgba(59,130,246,.6),0 0 20px rgba(59,130,246,.4),inset 0 1px 2px rgba(0,0,0,.3);z-index:2;position:relative;font-weight:700;animation:runeGlow 3s ease-in-out infinite}@keyframes runeGlow{0%,to{text-shadow:0 0 10px rgba(59,130,246,.6),0 0 20px rgba(59,130,246,.4)}50%{text-shadow:0 0 15px rgba(59,130,246,.8),0 0 30px rgba(59,130,246,.6),0 0 40px rgba(59,130,246,.4)}}.revelation-container{display:flex;justify-content:center;align-items:center;padding:40px 20px;min-height:300px}.cracking-stone{width:120px;height:120px;position:relative}.cracking-stone .stone-surface{width:100%;height:100%;position:relative;animation:stoneCrack 2s ease-in-out forwards}.rune-symbol.fading{animation:runeFade 2s ease-in-out forwards}@keyframes stoneCrack{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);background:linear-gradient(135deg,#ef4444,#dc2626,#b91c1c);box-shadow:0 0 20px #ef444499,inset 0 0 20px #0000004d}70%{transform:scale(1.05);opacity:.8;filter:blur(2px)}to{transform:scale(.8);opacity:0;filter:blur(5px)}}@keyframes runeFade{0%{opacity:1;color:#3b82f6}50%{opacity:.5;color:#ef4444;transform:scale(1.2)}to{opacity:0;transform:scale(.5)}}.creature-choice-container{padding:20px 30px 30px;color:#fff;text-align:center}.revealed-creature{margin-bottom:30px}.creature-image-showcase{width:150px;height:150px;margin:0 auto 20px;border-radius:50%;overflow:hidden;border:3px solid #8b5cf6;box-shadow:0 0 30px #8b5cf680,0 8px 25px #0000004d;animation:creatureReveal .8s ease-out}.creature-image-showcase img{width:100%;height:100%;object-fit:cover}@keyframes creatureReveal{0%{transform:scale(0) rotate(180deg);opacity:0}60%{transform:scale(1.1) rotate(-10deg);opacity:.8}to{transform:scale(1) rotate(0);opacity:1}}.creature-details h3{margin:0 0 12px;font-size:24px;font-weight:700;color:#8b5cf6;text-shadow:0 2px 10px rgba(139,92,246,.3)}.creature-meta{display:flex;justify-content:center;align-items:baseline;gap:16px;flex-wrap:wrap}.creature-type{background:#ffffff1a;padding:6px 12px;border-radius:12px;font-size:13px;font-weight:600;color:#ffffffe6}.creature-rarity{padding:6px 12px;border-radius:12px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.rarity-common{background:#9ca3af;color:#fff}.rarity-uncommon{background:#fbbf24;color:#000}.rarity-rare{background:#ef4444;color:#fff}.rarity-unique{background:#a855f7;color:#fff}.rarity-legendary{background:#d97706;color:#fff}.choice-buttons{display:flex;flex-direction:column;gap:12px}.btn-track,.btn-select-again{padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;min-height:50px}.btn-track{background:linear-gradient(45deg,#10b981,#059669);color:#fff;box-shadow:0 4px 15px #10b9814d}.btn-track:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-select-again{background:transparent;color:#fffc;border:1px solid rgba(255,255,255,.3)}.btn-select-again:hover:not(:disabled){background:#ffffff1a;color:#fff;border-color:#ffffff80}.btn-track:disabled,.btn-select-again:disabled{opacity:.6;cursor:not-allowed;transform:none}.final-selection-container{padding:20px 30px 30px;color:#fff;text-align:center}.final-header{margin-bottom:30px}.final-header h3{margin:0 0 8px;font-size:20px;color:#8b5cf6}.final-header p{margin:0;font-size:14px;color:#fffc}.final-stones{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.mystical-stone.final{width:80px;height:80px;animation:finalStoneGlow 2s ease-in-out infinite}@keyframes finalStoneGlow{0%,to{filter:drop-shadow(0 8px 16px rgba(0,0,0,.4))}50%{filter:drop-shadow(0 8px 16px rgba(139,92,246,.6))}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 480px){.discovery-overlay{padding:15px}.discovery-modal{max-width:100%;border-radius:16px}.discovery-header{padding:24px 20px 16px}.discovery-header h2{font-size:20px}.discovery-header p{font-size:13px}.stones-container{padding:20px 15px 30px;min-height:250px}.stones-triangle{gap:20px;max-width:250px}.mystical-stone{width:75px;height:75px}.rune-symbol{font-size:28px}.creature-choice-container{padding:16px 20px 24px}.creature-image-showcase{width:120px;height:120px;margin-bottom:16px}.creature-details h3{font-size:20px}.creature-meta{gap:12px}.creature-type,.creature-rarity{font-size:12px;padding:5px 10px}.choice-buttons{gap:10px}.btn-track,.btn-select-again{padding:14px 20px;font-size:15px}.final-selection-container{padding:16px 20px 24px}.mystical-stone.final{width:70px;height:70px}.final-stones{gap:15px}}@media (max-width: 320px){.discovery-overlay{padding:10px}.discovery-header{padding:20px 15px 12px}.discovery-header h2{font-size:18px}.stones-container{padding:15px 10px 25px}.mystical-stone{width:65px;height:65px}.rune-symbol{font-size:24px}.creature-image-showcase{width:100px;height:100px}.creature-details h3{font-size:18px}.btn-track,.btn-select-again{font-size:14px;padding:12px 16px}}@media (max-height: 600px) and (orientation: landscape){.discovery-modal{max-height:95vh}.discovery-header{padding:16px 20px 12px}.stones-container{padding:15px 20px 20px;min-height:180px}.creature-choice-container{padding:12px 20px 20px}.creature-image-showcase{width:100px;height:100px;margin-bottom:12px}}@media (prefers-contrast: high){.stone-surface{border-color:#fff;border-width:3px}.rune-symbol{color:#60a5fa;text-shadow:none}.creature-image-showcase{border-color:#fff;border-width:4px}}@media (prefers-reduced-motion: reduce){.mystical-stone,.creature-image-showcase,.btn-track,.btn-select-again,.rune-symbol,.cracking-stone .stone-surface{animation:none!important;transition:none!important}.mystical-stone:hover{transform:none}}.ad-container{display:flex;flex-direction:column;align-items:center;margin:15px 0;padding:10px;background:#ffffff0d;border-radius:8px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.ad-label{font-size:10px;color:#fff9;margin-bottom:5px;text-transform:uppercase;letter-spacing:1px;font-weight:500}.adsbygoogle{border-radius:6px;overflow:hidden;min-height:50px;width:100%;max-width:100%}.creature-registry-ad{margin:20px auto;max-width:320px}.creature-registry-ad .adsbygoogle{min-height:100px}.discovery-ad{margin:15px auto 25px;max-width:320px}.discovery-ad .adsbygoogle{min-height:50px}.subtype-ad{margin:20px auto;max-width:300px}.subtype-ad .adsbygoogle{min-height:250px}@media (min-width: 768px){.ad-container{margin:20px auto}.creature-registry-ad{max-width:728px}.creature-registry-ad .adsbygoogle{min-height:90px}.discovery-ad{max-width:468px}.subtype-ad{max-width:336px}.subtype-ad .adsbygoogle{min-height:280px}}@media (min-width: 1024px){.creature-registry-ad .adsbygoogle{min-height:120px}.subtype-ad .adsbygoogle{min-height:300px}}@media (prefers-color-scheme: dark){.ad-container{background:#0000004d;border:1px solid rgba(255,255,255,.05)}}.ad-container.loading .adsbygoogle{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.square-ad{margin:20px auto;max-width:300px}.square-ad .adsbygoogle{min-height:250px}.horizontal-ad{margin:15px auto;max-width:320px}.horizontal-ad .adsbygoogle{min-height:50px}@media (min-width: 768px){.square-ad{max-width:336px}.square-ad .adsbygoogle{min-height:280px}.horizontal-ad{max-width:728px}.horizontal-ad .adsbygoogle{min-height:90px}}@media (min-width: 1024px){.square-ad .adsbygoogle{min-height:300px}.horizontal-ad .adsbygoogle{min-height:120px}}.ad-container:empty:after{content:"";display:block;height:50px;background:#ffffff05;border-radius:6px}.welcome-screen{position:fixed;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:20px;box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch;height:100vh}.welcome-container{width:100%;max-width:450px;background:#fffffff2;border-radius:20px;padding:40px 30px;text-align:center;box-shadow:0 20px 60px #0000004d;backdrop-filter:blur(10px);display:flex;flex-direction:column;min-height:auto;height:auto;margin:20px 0 60px}.progress-dots{display:flex;justify-content:center;gap:8px;margin-bottom:30px;flex-shrink:0}.dot{width:10px;height:10px;border-radius:50%;background:#ddd;transition:all .3s ease}.dot.active{background:#667eea;transform:scale(1.2)}.welcome-content{flex-shrink:0;margin:15px 0}.welcome-title{font-size:22px;font-weight:700;color:#333;margin-bottom:10px;line-height:1.2}.welcome-description{font-size:14px;color:#666;line-height:1.4;margin-bottom:15px;text-align:center}.welcome-creatures-showcase{margin:30px 0;animation:fadeInUp .6s ease}.creatures-triangle{display:flex;flex-direction:column;align-items:center;gap:20px;margin:0 auto;max-width:300px;position:relative}.triangle-row{display:flex;justify-content:center;gap:20px}.triangle-row.top{margin-bottom:10px}.triangle-row.bottom{gap:40px}.creature-preview{display:flex;flex-direction:column;align-items:center;text-align:center;animation:float 3s ease-in-out infinite;position:relative;transition:transform .3s ease}.creature-preview:nth-child(1){animation-delay:0s}.triangle-row.bottom .creature-preview:nth-child(1){animation-delay:.5s}.triangle-row.bottom .creature-preview:nth-child(2){animation-delay:1s}.creature-preview:hover{transform:translateY(-5px) scale(1.05)}.creature-preview-image{width:90px;height:90px;border-radius:50%;background:linear-gradient(45deg,#667eea,#764ba2);padding:4px;margin-bottom:8px;box-shadow:0 6px 20px #667eea66;transition:all .3s ease;position:relative;overflow:hidden}.creature-preview-image:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(45deg,rgba(255,255,255,.3),transparent);pointer-events:none}.creature-preview-image:hover{transform:scale(1.1);box-shadow:0 8px 25px #667eea99}.creature-preview-image img{width:100%;height:100%;border-radius:50%;object-fit:cover;background:#fff;position:relative;z-index:2}.creature-preview-name{font-size:15px;font-weight:600;color:#fff;margin-bottom:3px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.creature-preview-type{font-size:11px;color:#667eea;font-weight:500;background:#667eea1a;padding:3px 10px;border-radius:12px;border:1px solid rgba(102,126,234,.2);backdrop-filter:blur(5px)}.veilsight-showcase{margin:20px 0;animation:fadeInUp .6s ease}.veilsight-logo{position:relative;width:240px;height:240px;margin:0 auto 15px;border-radius:50%;background:#fffffff2;display:flex;align-items:center;justify-content:center;animation:float 3s ease-in-out infinite;box-shadow:0 10px 30px #4c1d954d;overflow:hidden;padding:20px;border:2px solid #4c1d95}.lab-icon{width:200px;height:200px;background-image:url(/icons/veilsight-logo.png);background-size:contain;background-repeat:no-repeat;background-position:center;position:relative;z-index:2;border-radius:50%;animation:pulse 2s ease-in-out infinite}.user-form-section{margin:20px 0;animation:fadeInUp .6s ease;display:flex;flex-direction:column}.form-icon{font-size:32px;background:linear-gradient(135deg,#667eea,#764ba2);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 15px;box-shadow:0 4px 15px #667eea4d}.user-form{display:flex;flex-direction:column;gap:12px;text-align:left}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-weight:600;color:#333;font-size:13px}.form-group input{padding:10px 14px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease;background:#fff;color:#333}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#ef4444;background-color:#fef2f2}.form-group input.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.error-text{color:#ef4444;font-size:11px;font-weight:500;margin-top:2px}.general-error{background:#fef2f2;color:#ef4444;padding:10px;border-radius:8px;font-size:13px;border:1px solid #fecaca;text-align:center;margin-top:8px}.creature-showcase{margin:20px 0;animation:fadeInUp .6s ease;display:flex;flex-direction:column;align-items:center}.creature-image-container{width:85vw!important;height:85vw!important;max-width:300px!important;max-height:300px!important;margin:0 auto 15px;border-radius:20px!important;background:#fffffff2;padding:3px;animation:float 3s ease-in-out infinite;flex-shrink:0;box-shadow:0 10px 30px #667eea66;position:relative;overflow:hidden}.creature-image-container:before{content:"";position:absolute;inset:0;border-radius:20px;background:linear-gradient(45deg,rgba(102,126,234,.1),transparent);pointer-events:none;z-index:1}.creature-image{width:100%;height:100%;border-radius:12px;object-fit:cover;background:#fff;position:relative;z-index:2}.creature-badge{display:flex;justify-content:center;gap:10px;margin-top:10px;flex-wrap:wrap}.creature-type,.creature-subtype,.creature-rarity{background:#667eea1a;color:#667eea;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize}.creature-rarity{background:#ffc1071a;color:#ffc107}.welcome-actions{display:flex;flex-direction:column;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid rgba(0,0,0,.1);flex-shrink:0}.btn-primary{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;min-height:48px;width:100%;-webkit-tap-highlight-color:rgba(102,126,234,.3);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.features-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-top:20px}.feature{display:flex;flex-direction:column;align-items:center;gap:8px}.feature-icon{font-size:24px;background:#667eea1a;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center}.feature-text{font-size:12px;color:#666;font-weight:600;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width: 430px){.welcome-screen{padding:10px}.welcome-container{padding:25px 20px 40px;margin:10px 0 80px;max-width:calc(100vw - 20px);border-radius:16px}.welcome-title{font-size:20px}.welcome-description{font-size:13px;margin-bottom:12px}.creatures-triangle{gap:15px;max-width:280px}.triangle-row.bottom{gap:30px}.creature-preview-image{width:75px;height:75px}.creature-preview-name{font-size:13px}.creature-preview-type{font-size:10px;padding:2px 8px}.veilsight-logo{width:200px;height:200px;padding:15px}.lab-icon{width:170px;height:170px}.form-icon{width:50px;height:50px;font-size:28px;margin-bottom:12px}.form-row{grid-template-columns:1fr;gap:10px}.form-group input{padding:14px 16px;font-size:16px}.user-form{gap:10px}.creature-image-container{width:85vw!important;height:85vw!important;max-width:280px!important;max-height:280px!important;margin:0 auto 15px}.features-preview{grid-template-columns:1fr;gap:10px}.feature{flex-direction:row;justify-content:flex-start;text-align:left}.feature-icon{width:40px;height:40px;font-size:20px}.progress-dots{margin-bottom:20px;gap:6px}.dot{width:8px;height:8px}.welcome-actions{margin-top:40px;padding-top:25px}.btn-primary{min-height:56px;font-size:18px;padding:18px 24px}}@media (max-width: 360px){.welcome-container{padding:20px 15px 35px;margin:5px 0 70px}.creatures-triangle{gap:12px;max-width:240px}.triangle-row.bottom{gap:25px}.creature-preview-image{width:65px;height:65px}.creature-preview-name{font-size:12px}.creature-preview-type{font-size:9px;padding:2px 6px}.veilsight-logo{width:180px;height:180px;padding:12px}.lab-icon{width:156px;height:156px}.creature-image-container{width:85vw!important;height:85vw!important;max-width:250px!important;max-height:250px!important}.btn-primary{padding:16px 20px;font-size:16px;min-height:52px}.welcome-title{font-size:18px}.welcome-description{font-size:12px}}@media (max-height: 600px) and (orientation: landscape){.welcome-container{padding:15px 20px 30px;margin:5px 0 50px}.welcome-creatures-showcase{margin:15px 0}.creatures-triangle{gap:10px;max-width:250px}.triangle-row.bottom{gap:20px}.creature-preview-image{width:55px;height:55px}.creature-preview-name{font-size:11px}.creature-preview-type{font-size:9px;padding:1px 4px}.veilsight-logo{width:120px;height:120px;padding:10px}.lab-icon{width:100px;height:100px}.creature-image-container{width:85vw!important;height:85vw!important;max-width:200px!important;max-height:200px!important;margin:5px auto 10px}.welcome-title{font-size:16px;margin-bottom:8px}.welcome-description{font-size:12px;margin-bottom:10px}.progress-dots{margin-bottom:15px}.form-icon{width:40px;height:40px;font-size:24px;margin-bottom:10px}.user-form{gap:8px}.form-group input{padding:10px 12px}.welcome-actions{margin-top:20px;padding-top:15px}.btn-primary{min-height:48px;font-size:16px;padding:14px 20px}}@supports (padding: max(0px)){.welcome-screen{padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom));padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right))}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.creature-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (display-mode: standalone){.welcome-screen{padding-top:max(20px,env(safe-area-inset-top) + 8px)}}@media (hover: none) and (pointer: coarse){.btn-primary{min-height:48px;min-width:48px}}@media (prefers-color-scheme: dark){.welcome-container{background:#1a202cf2;color:#fff}.welcome-title{color:#fff}.welcome-description{color:#fffc}.form-group label{color:#fff}.form-group input{background:#2d3748cc;color:#fff;border-color:#fff3}.form-group input:focus{border-color:#667eea}}.loading-screen{position:fixed;inset:0;background:linear-gradient(135deg,#1e3c72,#2a5298,#667eea);display:flex;align-items:center;justify-content:center;z-index:2000;overflow:hidden}.loading-container{text-align:center;color:#fff;position:relative;padding:40px}.loading-icon{margin-bottom:30px;position:relative}.mystical-orb{width:80px;height:80px;margin:0 auto;position:relative;animation:float 3s ease-in-out infinite}.orb-inner{width:100%;height:100%;border-radius:50%;background:linear-gradient(45deg,#667eea,#764ba2,#f093fb);background-size:300% 300%;animation:gradient-shift 4s ease infinite;box-shadow:0 0 20px #667eea80,inset 0 0 20px #fff3}.orb-glow{position:absolute;inset:-10px;border-radius:50%;background:radial-gradient(circle,rgba(102,126,234,.3) 0%,transparent 70%);animation:pulse 2s ease-in-out infinite}.loading-title{font-size:28px;font-weight:700;margin-bottom:10px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);letter-spacing:1px}.loading-message{font-size:16px;color:#fffc;margin-bottom:40px;font-weight:300}.loading-progress{width:200px;margin:0 auto}.progress-bar{width:100%;height:3px;background:#fff3;border-radius:2px;overflow:hidden;margin-bottom:20px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;animation:progress 2s ease-in-out infinite}.loading-dots{display:flex;justify-content:center;gap:8px}.loading-dots .dot{width:8px;height:8px;border-radius:50%;background:#ffffffb3;animation:dot-bounce 1.4s ease-in-out infinite both}.loading-dots .dot:nth-child(1){animation-delay:-.32s}.loading-dots .dot:nth-child(2){animation-delay:-.16s}.particles{position:absolute;inset:0;pointer-events:none}.particle{position:absolute;width:4px;height:4px;background:#fff9;border-radius:50%;animation:float-particle 8s linear infinite}.particle-1{left:10%;animation-delay:0s;animation-duration:8s}.particle-2{left:20%;animation-delay:-2s;animation-duration:10s}.particle-3{left:80%;animation-delay:-4s;animation-duration:9s}.particle-4{left:90%;animation-delay:-6s;animation-duration:7s}.particle-5{left:60%;animation-delay:-1s;animation-duration:11s}.particle-6{left:40%;animation-delay:-3s;animation-duration:6s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes progress{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}@keyframes dot-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}@keyframes float-particle{0%{top:100%;opacity:0;transform:translate(0) rotate(0)}10%{opacity:1}90%{opacity:1}to{top:-10%;opacity:0;transform:translate(20px) rotate(360deg)}}@media (max-width: 480px){.loading-container{padding:20px}.mystical-orb{width:60px;height:60px}.loading-title{font-size:24px}.loading-message{font-size:14px}.progress-bar{width:150px}}@media (max-height: 500px) and (orientation: landscape){.mystical-orb{width:50px;height:50px}.loading-title{font-size:20px;margin-bottom:5px}.loading-message{font-size:12px;margin-bottom:20px}}.profile-container{padding:20px;max-height:70vh;overflow-y:auto;-webkit-overflow-scrolling:touch;color:#333}.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid rgba(139,92,246,.1)}.profile-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(45deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #667eea4d;flex-shrink:0}.avatar-emoji{font-size:28px;filter:brightness(0) invert(1)}.profile-info{flex:1;min-width:0}.profile-name{margin:0 0 4px;font-size:20px;font-weight:700;color:#333;line-height:1.2}.profile-subtitle{margin:0;font-size:14px;color:#667eea;font-weight:500}.profile-stats{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:24px}.stat-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.1);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;transition:all .2s ease}.stat-card:hover{background:#8b5cf614;transform:translateY(-1px)}.stat-icon{font-size:24px;width:40px;height:40px;border-radius:50%;background:#8b5cf61a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1}.stat-number{font-size:18px;font-weight:700;color:#333;line-height:1.2}.stat-label{font-size:12px;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.profile-details{margin-bottom:24px}.detail-section{margin-bottom:20px;background:#ffffff80;border-radius:12px;padding:16px;border:1px solid rgba(0,0,0,.05)}.detail-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333;border-bottom:1px solid rgba(139,92,246,.2);padding-bottom:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:14px;font-weight:500;color:#666}.detail-value{font-size:14px;color:#333;font-weight:600;text-align:right;max-width:60%;word-break:break-word}.detail-value.user-id{font-family:monospace;font-size:12px;color:#888}.profile-dev-section{background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:12px;padding:16px;margin-bottom:20px}.dev-warning{margin-bottom:16px}.dev-warning h4{margin:0 0 8px;font-size:14px;color:#dc2626;font-weight:600}.dev-warning p{margin:0;font-size:12px;color:#666;line-height:1.4}.reset-button{background:linear-gradient(45deg,#dc2626,#b91c1c);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;margin-bottom:8px;box-shadow:0 4px 12px #dc26264d}.reset-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #dc262666}.reset-button:active{transform:translateY(0)}.reset-warning{margin:0;font-size:11px;color:#dc2626;text-align:center;font-style:italic;line-height:1.3}.profile-loading,.profile-error{text-align:center;padding:40px 20px}.loading-spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.profile-error p{margin:0 0 16px;color:#dc2626;font-weight:500}.retry-button{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600}.retry-button:hover{background:#5a67d8}.profile-actions{margin-top:20px;padding-top:16px;border-top:1px solid rgba(0,0,0,.1)}.close-profile-button{background:#667eea1a;color:#667eea;border:1px solid rgba(102,126,234,.2);padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;width:100%;transition:all .2s ease}.close-profile-button:hover{background:#667eea26;border-color:#667eea4d}@media (max-width: 480px){.profile-container{padding:16px;max-height:75vh}.profile-header{gap:12px;margin-bottom:20px}.profile-avatar{width:50px;height:50px}.avatar-emoji{font-size:24px}.profile-name{font-size:18px}.profile-subtitle{font-size:13px}.stat-card{padding:12px;gap:10px}.stat-icon{width:36px;height:36px;font-size:20px}.stat-number{font-size:16px}.stat-label{font-size:11px}.detail-section{padding:12px}.detail-row{padding:6px 0}.detail-label,.detail-value{font-size:13px}}@media (max-width: 320px){.profile-container{padding:12px}.profile-stats{gap:8px}.stat-card,.detail-section{padding:10px}.profile-name{font-size:16px}}.creature-rarity-badge{display:inline-block;margin-left:8px;padding:2px 6px;background:#8b5cf61a;color:#8b5cf6;border-radius:8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-section .detail-row{padding:10px 0}.detail-section .detail-row:first-child{padding-top:8px}.detail-value{display:flex;align-items:center;justify-content:flex-end;gap:4px}.profile-error{text-align:center;padding:20px;color:#dc2626}.profile-error p{margin:0 0 12px;font-weight:500}@media (max-width: 480px){.profile-stats{gap:8px}.stat-card{padding:10px}.creature-rarity-badge{font-size:9px;padding:1px 4px;margin-left:4px}}.support-content{padding:20px;max-height:70vh;overflow-y:auto}.support-message{margin-bottom:30px}.support-message p{font-size:16px;line-height:1.6;color:#000!important;margin:0;text-align:center}.support-options{display:flex;flex-direction:column;gap:20px;align-items:center}.support-option{display:flex;align-items:center;gap:15px;padding:20px 30px;background:var(--card-background, #ffffff);border:2px solid var(--border-color, #ddd);border-radius:12px;cursor:pointer;transition:all .3s ease;text-decoration:none;font-size:16px;font-weight:500;width:100%;max-width:400px;justify-content:flex-start}.support-option:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:var(--accent-color, #007bff)}.support-option:active{transform:translateY(0)}.issue-button{border-color:#dc3545;background:linear-gradient(135deg,#dc3545,#c82333)}.issue-button:hover{border-color:#c82333;background:linear-gradient(135deg,#c82333,#bd2130)}.idea-button{border-color:#28a745;background:linear-gradient(135deg,#28a745,#218838)}.idea-button:hover{border-color:#218838;background:linear-gradient(135deg,#218838,#1e7e34)}.support-icon{font-size:24px;flex-shrink:0}.support-text{color:#fff!important;font-weight:600}@media (prefers-color-scheme: dark){.support-message p{color:var(--text-color-dark, #e0e0e0)}.support-option{background:var(--card-background-dark, #2a2a2a);border-color:var(--border-color-dark, #555);color:var(--text-color-dark, #e0e0e0)}.support-text{color:#fff!important}.issue-button{background:linear-gradient(135deg,#2a1f1f,#2a2a2a)}.issue-button:hover{background:linear-gradient(135deg,#3a2525,#2a1f1f)}.idea-button{background:linear-gradient(135deg,#1f2a1f,#2a2a2a)}.idea-button:hover{background:linear-gradient(135deg,#252a25,#1f2a1f)}}@media (max-width: 768px){.support-content{padding:15px}.support-option{padding:15px 20px;font-size:14px}.support-icon{font-size:20px}}.encyclopedia-overlay{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;background:#fff!important;z-index:2147483647!important;overflow:hidden;display:flex!important;flex-direction:column;border:5px solid red!important;box-shadow:0 0 50px #ff000080!important}.encyclopedia-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0;background:#fff;position:sticky;top:0;z-index:2147483647;min-height:60px}.encyclopedia-back-button{background:#fff9c4;border:2px solid #f0e68c;font-size:16px;color:#333;cursor:pointer;padding:10px 16px;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center;font-weight:500}.encyclopedia-back-button:hover{background-color:#fff3a0;border-color:#daa520}.encyclopedia-title{font-size:20px;font-weight:600;color:#333;margin:0;text-align:center;flex:1}.encyclopedia-breadcrumb{font-size:14px;color:#666;margin:0;text-align:center;flex:1}.encyclopedia-close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:8px;border-radius:8px;transition:background-color .2s}.encyclopedia-close-button:hover{background-color:#f5f5f5}.encyclopedia-content{flex:1;overflow-y:auto;padding:20px;background:#fff;color:#333;line-height:1.6}.encyclopedia-intro{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:20px;margin-bottom:24px}.encyclopedia-intro p{margin:0;color:#4a4a4a;font-size:15px;line-height:1.6;font-style:italic}.types-list{display:flex;flex-direction:column;gap:16px}.type-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s;text-align:left;width:100%}.type-card:hover{border-color:#4a90e2;box-shadow:0 4px 12px #0000001a}.type-card:active{transform:translateY(1px)}.type-header{display:flex;align-items:center;gap:16px;margin-bottom:8px}.type-name{font-size:20px;font-weight:600;color:#333;margin:0;flex:1}.type-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.type-icon img{border-radius:8px;box-shadow:0 2px 4px #0000001a}.type-description{font-size:14px;color:#666;margin:0}.type-detail-content{max-width:100%}.type-overview{margin-bottom:32px}.overview-text{font-size:16px;line-height:1.6;color:#333;margin-bottom:20px}.field-notes{background:#f8f9fa;border-left:4px solid #4a90e2;padding:16px;border-radius:0 8px 8px 0;margin-bottom:20px}.field-notes-title{font-size:16px;font-weight:600;color:#333;margin:0 0 8px}.field-notes-text{font-size:14px;color:#555;margin:0;font-style:italic}.subtypes-section{margin-top:32px}.subtypes-title{font-size:18px;font-weight:600;color:#333;margin:0 0 16px}.subtypes-list{display:flex;flex-direction:column;gap:12px}.subtype-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;text-align:left;width:100%}.subtype-card:hover{background:#e3f2fd;border-color:#4a90e2}.subtype-name{font-size:16px;font-weight:600;color:#333;margin:0 0 4px}.subtype-preview{font-size:14px;color:#666;margin:0}.subtype-detail-content{max-width:100%}.subtype-section{margin-bottom:24px}.section-header{font-size:18px;font-weight:700;color:#333;margin:0 0 12px}.section-content{font-size:16px;line-height:1.6;color:#333;margin:0;white-space:pre-wrap}.encyclopedia-loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:16px;color:#666}.encyclopedia-error{display:flex;flex-direction:column;justify-content:center;align-items:center;height:200px;text-align:center;color:#d32f2f}.error-message{font-size:16px;margin-bottom:12px}.retry-button{background:#4a90e2;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:14px;cursor:pointer;transition:background-color .2s}.retry-button:hover{background:#357abd}.empty-state{display:flex;flex-direction:column;justify-content:center;align-items:center;height:200px;text-align:center;color:#666}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-message{font-size:16px;margin:0}@media (min-width: 768px){.encyclopedia-content{padding:32px;max-width:800px;margin:0 auto}.type-card{padding:24px}.type-name{font-size:24px}.type-description{font-size:16px}.overview-text,.section-content{font-size:18px}}@media (max-width: 767px){.type-card,.subtype-card{min-height:60px;display:flex;flex-direction:column;justify-content:center}.encyclopedia-back-button,.encyclopedia-close-button{min-width:44px;min-height:44px}}.encyclopedia-overlay{animation:slideInFromRight .3s ease-out}@keyframes slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}.encyclopedia-back-button:focus{outline:2px solid #daa520;outline-offset:2px}.encyclopedia-close-button:focus,.type-card:focus,.subtype-card:focus,.retry-button:focus{outline:2px solid #4a90e2;outline-offset:2px}.loremarks-overlay{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;background:#000c!important;backdrop-filter:blur(10px);z-index:999999999!important;display:flex!important;align-items:flex-start;justify-content:center;padding:40px 20px 20px;animation:fadeIn .3s ease-out;overflow-y:auto;box-sizing:border-box!important}.loremarks-container{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border-radius:16px;box-shadow:0 20px 40px #0000004d;width:100%;max-width:500px;max-height:calc(100vh - 80px);min-height:400px;display:flex;flex-direction:column;overflow:hidden;border:2px solid rgba(139,92,246,.3);margin:auto}.loremarks-header{display:flex;justify-content:space-between;align-items:center;padding:24px;background:#0003;border-bottom:1px solid rgba(139,92,246,.3);flex-shrink:0;min-height:80px}.loremarks-title-section{display:flex;align-items:center;gap:16px}.loremarks-icon{width:48px;height:48px;object-fit:cover;border-radius:8px;border:2px solid rgba(139,92,246,.5)}.loremarks-title-text h2{color:#fff;margin:0;font-size:24px;font-weight:700}.loremarks-subtitle{color:#ffffffb3;margin:4px 0 0;font-size:14px}.loremarks-close-button{background:#fff3;border:2px solid rgba(255,255,255,.4);border-radius:50%;width:44px;height:44px;min-width:44px;min-height:44px;color:#fff;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;z-index:10;padding:0;box-sizing:border-box}.loremarks-close-button:hover{background:#ffffff4d;border-color:#fff9;transform:scale(1.1)}.loremarks-progress{padding:20px 24px;background:#0000001a}.progress-bar{background:#ffffff1a;height:8px;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{background:linear-gradient(90deg,#8b5cf6,#667eea);height:100%;border-radius:4px;transition:width .3s ease}.progress-text{color:#fffc;font-size:14px;font-weight:600}.loremarks-content{flex:1;overflow-y:auto;padding:0 24px 20px}.achievements-list{display:flex;flex-direction:column;gap:16px}.achievement-item{background:#ffffff0d;border-radius:12px;padding:20px;border:2px solid transparent;transition:all .3s ease}.achievement-item.completed{background:#22c55e1a;border-color:#22c55e4d}.achievement-item.incomplete{background:#ffffff08;border-color:#ffffff1a}.achievement-main{display:flex;align-items:flex-start;gap:16px}.achievement-checkbox{position:relative;min-width:24px;height:24px}.checkbox-input{opacity:0;position:absolute;width:100%;height:100%}.checkbox-custom{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff0d;color:#fff;font-size:14px;font-weight:700;transition:all .2s ease}.achievement-item.completed .checkbox-custom{background:#22c55e;border-color:#22c55e;color:#fff}.achievement-item.incomplete .checkbox-custom{background:#ffffff1a;border-color:#fff3}.achievement-content{flex:1}.achievement-title{color:#fff;margin:0 0 8px;font-size:18px;font-weight:600}.achievement-item.incomplete .achievement-title{color:#ffffffb3}.achievement-description{color:#fffc;margin:0;font-size:14px;line-height:1.5}.achievement-item.incomplete .achievement-description{color:#ffffff80}.achievements-coming-soon{margin-top:32px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.coming-soon-divider{text-align:center;position:relative}.coming-soon-divider span{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:0 16px;color:#fff9;font-size:14px;font-style:italic}.coming-soon-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#ffffff1a;z-index:-1}.loremarks-footer{padding:20px 24px;background:#0003;border-top:1px solid rgba(139,92,246,.3);text-align:center}.loremarks-footer p{color:#ffffffb3;margin:0;font-size:14px}@media (max-width: 480px){.loremarks-overlay{padding:20px 10px 10px;align-items:flex-start}.loremarks-container{max-height:calc(100vh - 40px);border-radius:12px;min-height:300px}.loremarks-header{padding:20px}.loremarks-icon{width:40px;height:40px}.loremarks-title-text h2{font-size:20px}.loremarks-progress{padding:16px 20px}.loremarks-content{padding:0 20px 16px}.achievement-item{padding:16px}.achievement-main{gap:12px}.achievement-title{font-size:16px}.achievement-description{font-size:13px}.loremarks-footer{padding:16px 20px}}.loremarks-content::-webkit-scrollbar{width:6px}.loremarks-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.loremarks-content::-webkit-scrollbar-thumb{background:#8b5cf680;border-radius:3px}.loremarks-content::-webkit-scrollbar-thumb:hover{background:#8b5cf6b3}.getting-started-overlay{position:fixed;inset:0;background-color:#fff;z-index:10000;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.getting-started-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background-color:#fff;border-bottom:1px solid #ddd;flex-shrink:0}.getting-started-title-section{flex:1;text-align:center;margin:0 16px}.getting-started-title{margin:0;font-size:20px;font-weight:600;color:#333}.getting-started-content{flex:1;overflow-y:auto;padding:20px;background-color:#fff}.getting-started-main{max-width:600px;margin:0 auto}.welcome-header{text-align:center;margin-bottom:20px}.welcome-header h2{font-size:24px;color:#333;margin:0;font-weight:600}.intro-section{margin-bottom:32px}.intro-section p{font-size:16px;line-height:1.6;color:#333;margin:0 0 16px}.intro-section p:last-child{margin-bottom:0}.sections-list{display:flex;flex-direction:column;gap:16px}.section-link{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;text-align:left;cursor:pointer;transition:all .2s ease}.section-link:hover{border-color:#aaa;background-color:#fafafa}.section-title{font-size:18px;font-weight:600;color:#333;margin-bottom:8px}.section-description{font-size:14px;color:#666;line-height:1.4}.section-content{max-width:600px;margin:0 auto}.content-block{margin-bottom:32px}.content-block:last-child{margin-bottom:0}.content-block h3{font-size:18px;font-weight:600;color:#333;margin:0 0 12px}.content-block p{font-size:16px;line-height:1.6;color:#333;margin:0 0 16px}.content-block p:last-child{margin-bottom:0}.rarity-list{margin:16px 0;border:1px solid #ddd;border-radius:6px;overflow:hidden}.rarity-item{display:flex;align-items:flex-start;padding:16px;border-bottom:1px solid #eee}.rarity-item:last-child{border-bottom:none}.rarity-color{width:20px;height:20px;border-radius:50%;margin-right:16px;margin-top:2px;border:1px solid #ccc;flex-shrink:0}.rarity-color.common{background-color:#6b7280}.rarity-color.uncommon{background-color:#eab308}.rarity-color.rare{background-color:#ef4444}.rarity-color.epic{background-color:#8b5cf6}.rarity-color.legendary{background-color:#f59e0b}.rarity-details{flex:1;display:flex;flex-direction:column}.rarity-name{font-size:16px;font-weight:600;color:#333;margin-bottom:4px}.rarity-description{font-size:14px;color:#666;line-height:1.4}.warning-box{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:6px;padding:16px;margin:16px 0}.warning-box p{margin:0;color:#92400e}.nav-tip{background-color:#f0f9ff;border:1px solid #0ea5e9;border-radius:6px;padding:16px;margin-bottom:16px;color:#0c4a6e}@media (max-width: 768px){.getting-started-header{padding:12px 16px}.getting-started-title{font-size:18px}.getting-started-content,.section-link{padding:16px}.section-title{font-size:16px}.section-description{font-size:13px}.content-block h3{font-size:16px}.content-block p{font-size:15px}}@media (max-width: 480px){.getting-started-header{padding:10px 12px}.getting-started-content{padding:12px}}.creature-type-group{margin-bottom:20px}.creature-type-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#4a90e2;border:1px solid #357abd;border-radius:8px;margin-bottom:12px;font-weight:600;color:#fff}.creature-type-header .type-name{font-size:16px;flex:1}.creature-type-header .type-count{font-size:16px;color:#fff;font-weight:600}.creature-type-list{display:flex;flex-direction:column;gap:12px}.back-button{background:#fff9c4!important;border:2px solid #f0e68c!important;font-size:16px!important;color:#333!important;cursor:pointer;padding:10px 16px!important;border-radius:8px!important;transition:all .2s;display:flex;align-items:center;justify-content:center;font-weight:500!important}.back-button:hover{background-color:#fff3a0!important;border-color:#daa520!important}.back-button:focus{outline:2px solid #daa520!important;outline-offset:2px}.creatures-grid .creature-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--color-gray-50);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-align:center;position:relative;width:100%}.creatures-grid .creature-image-container{width:100px;height:67px;border-radius:var(--radius-md);overflow:hidden;background:#fff;border:2px solid var(--color-gray-200);flex-shrink:0}.creatures-grid .creature-image{width:100%;height:100%;object-fit:cover}.creatures-grid .creature-info{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1);width:100%;text-align:center}.creatures-grid .creature-name{font-size:16px;font-weight:600;margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#000}.creatures-grid .creature-info.rarity-common{background:var(--rarity-common)}.creatures-grid .creature-info.rarity-uncommon{background:var(--rarity-uncommon)}.creatures-grid .creature-info.rarity-rare{background:var(--rarity-rare)}.creatures-grid .creature-info.rarity-unique{background:var(--rarity-unique)}.creatures-grid .creature-info.rarity-legendary{background:var(--rarity-legendary)}.creatures-grid .creature-type{font-size:13px;color:#000;margin:0;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.creatures-grid .creature-card:hover{background:var(--color-gray-100);border-color:var(--color-secondary);transform:translateY(-1px)}.creatures-grid .creature-card.selected{background:#8b5cf61a;border-color:var(--color-secondary);box-shadow:0 2px 8px #8b5cf633}.creatures-grid .selected-indicator{position:absolute;top:var(--space-sm);right:var(--space-sm);background:var(--color-secondary);color:#fff;width:20px;height:20px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;box-shadow:0 2px 4px #0000001a}.creatures-grid{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);overflow-y:auto;flex:1;max-height:calc(100vh - 200px);-webkit-overflow-scrolling:touch}.menu-container{background:#fff;border-radius:var(--radius-lg);min-width:280px;max-width:350px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideInRight .3s ease;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;z-index:var(--z-modal);position:relative}.menu-content{display:flex;flex-direction:column;height:100%;overflow:hidden}@media (max-width: 430px){.creatures-grid{padding:10px;gap:6px;max-height:calc(100vh - 180px)}.creatures-grid .creature-card{padding:10px!important;min-height:75px!important}.creatures-grid .creature-image-container{width:56px!important;height:56px!important;align-self:center!important;margin-bottom:5px!important}.creatures-grid .creature-card:hover{transform:none!important;background:var(--color-gray-100)!important;border-color:var(--color-secondary)!important}.creatures-grid .creature-name{font-size:15px}.creatures-grid .creature-type{font-size:12px}.menu-container{max-height:90vh}}@media (max-width: 360px){.creatures-grid .creature-card{padding:var(--space-sm)!important;gap:10px!important;min-height:70px!important}.creatures-grid .creature-name{font-size:14px!important;max-width:12ch!important}.creatures-grid .creature-image-container{width:52px!important;height:52px!important;align-self:center!important;margin-bottom:5px!important}.creatures-grid .creature-card:hover{transform:none!important;background:var(--color-gray-100)!important;border-color:var(--color-secondary)!important}.creatures-grid .creature-name{font-size:14px}}.hamburger-button{background:#ffffff1a;border:none;border-radius:var(--radius-full);width:var(--touch-target-comfortable);height:var(--touch-target-comfortable);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);z-index:var(--z-dropdown);position:relative}.hamburger-button:hover{background:#fff3;transform:scale(1.05)}.hamburger-icon{display:flex;flex-direction:column;justify-content:space-between;width:20px;height:16px}.hamburger-line{height:2px;background:#fff;border-radius:1px;transition:all .3s ease;transform-origin:center}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.menu-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(5px);z-index:9999;display:flex;align-items:flex-start;justify-content:flex-end;padding:20px;animation:fadeIn .3s ease}.menu-container{background:#fff;border-radius:16px;min-width:280px;max-width:350px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideInRight .3s ease;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;z-index:10001;position:relative}.menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb;flex-shrink:0;position:relative}.menu-header h3{position:absolute;left:50%;transform:translate(-50%);margin:0;font-size:20px;font-weight:700;color:#333;text-align:center}.back-button,.close-button{background:none;border:none;font-size:16px;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s ease;color:#666;font-weight:600}.back-button:hover,.close-button:hover{background:#f3f4f6;color:#333}.placeholder-button{width:32px;height:32px;visibility:hidden}.menu-content{display:flex;flex-direction:column;height:100%}.menu-items{display:flex;flex-direction:column;padding:10px;gap:8px}.menu-item{display:flex;align-items:center;gap:12px;padding:16px;background:none;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;position:relative}.menu-item:hover:not(.inactive){background:#f3f4f6;transform:translate(4px)}.menu-item.inactive{opacity:.7;cursor:pointer}.menu-item.inactive:hover{background:#f9fafb;opacity:.9}.menu-icon{font-size:20px;flex-shrink:0}.menu-text{flex:1;font-size:16px;font-weight:600;color:#333}.creature-count{background:#8b5cf6;color:#fff;font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px;min-width:20px;text-align:center}.inactive-badge{background:#e5e7eb;color:#6b7280;font-size:10px;font-weight:600;padding:4px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px}.coming-soon-badge{background:#e5e7eb;color:#6b7280;font-size:10px;font-weight:600;padding:4px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px;animation:subtle-pulse 2s ease-in-out infinite}.creatures-grid{padding:15px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;max-height:calc(100vh - 120px)}.creatures-grid .creature-card{display:flex!important;flex-direction:row!important;align-items:center!important;gap:var(--space-md)!important;padding:var(--space-sm)!important;background:var(--color-gray-50)!important;border:2px solid transparent!important;border-radius:var(--radius-md)!important;cursor:pointer!important;transition:all .2s ease!important;text-align:left!important;position:relative!important;min-height:80px!important;width:100%!important}.creatures-grid .creature-card:hover{background:var(--color-gray-100)!important;border-color:var(--color-secondary)!important;transform:translateY(-1px)!important}@media (max-width: 430px){.creatures-grid .creature-card:hover{transform:none!important}}@media (max-width: 360px){.creatures-grid .creature-card:hover{transform:none!important}}.creatures-grid .creature-card.selected{background:#8b5cf61a!important;border-color:var(--color-secondary)!important;box-shadow:0 2px 8px #8b5cf633!important}.creatures-grid .creature-image-container{width:64px!important;height:64px!important;border-radius:var(--radius-sm)!important;overflow:hidden!important;background:#fff!important;border:2px solid var(--color-gray-200)!important;flex-shrink:0!important;align-self:center!important;margin-bottom:5px!important}.creatures-grid .creature-image{width:100%!important;height:100%!important;object-fit:cover!important}.creatures-grid .creature-info{flex:1!important;min-width:0!important;display:flex!important;flex-direction:column!important;justify-content:center!important;gap:var(--space-xs)!important;padding:var(--space-sm) var(--space-md)!important;border-radius:var(--radius-sm)!important;border:1px solid rgba(0,0,0,.1)!important;align-self:stretch!important}.creatures-grid .creature-name{font-size:16px!important;font-weight:600!important;margin:0!important;line-height:1.2!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;color:#000!important;max-width:14ch!important}.creature-info.rarity-common{background:var(--rarity-common)}.creature-info.rarity-uncommon{background:var(--rarity-uncommon)}.creature-info.rarity-rare{background:var(--rarity-rare)}.creature-info.rarity-unique{background:var(--rarity-unique)}.creature-info.rarity-legendary{background:var(--rarity-legendary)}.creatures-grid .creature-type{font-size:13px!important;color:#000!important;margin:0!important;line-height:1.2!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;max-width:100%!important}.creature-rarity{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0;line-height:1}.rarity-common{color:var(--rarity-common)}.rarity-uncommon{color:var(--rarity-uncommon)}.rarity-rare{color:var(--rarity-rare)}.rarity-unique{color:var(--rarity-unique)}.rarity-legendary{color:var(--rarity-legendary)}.rarity-common-border{border-color:#fff}.rarity-uncommon-border{border-color:#facc15}.rarity-rare-border{border-color:#ef4444}.rarity-unique-border{border-color:#8b5cf6}.rarity-legendary-border{border-color:#fbbf24}.selected-indicator{position:absolute;top:8px;right:8px;background:#8b5cf6;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;box-shadow:0 2px 4px #0000001a}.no-creatures-message{text-align:center;padding:40px 20px;color:#6b7280}.no-creatures-message p{margin:0 0 8px;font-size:14px}.no-creatures-message p:first-child{font-size:16px;font-weight:600;color:#374151}.dev-force-movement-section{margin:16px 20px;padding:16px;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:12px;text-align:center}.dev-section-header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px;font-weight:600;color:#dc2626;font-size:14px}.dev-icon{font-size:16px}.dev-title{text-transform:uppercase;letter-spacing:.5px;font-size:12px}.force-movement-button{background:linear-gradient(45deg,#dc2626,#b91c1c);color:#fff;border:none;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #dc26264d;width:100%;margin-bottom:var(--space-sm);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:var(--touch-target-comfortable)}.force-movement-button:disabled{opacity:.7;cursor:not-allowed;transform:none;background:linear-gradient(45deg,#7f7f7f,#666)}.button-icon,.button-spinner{font-size:16px}.button-spinner{animation:spin 1s linear infinite}.dev-warning-text{margin:0;font-size:11px;color:#dc2626;font-style:italic;line-height:1.3}.about-content{padding:20px;max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.about-header{text-align:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.veilsight-logo-mini{display:flex;flex-direction:column;align-items:center;gap:8px}.logo-icon{font-size:32px;background:linear-gradient(45deg,#667eea,#764ba2);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #667eea4d}.logo-image{width:120px;height:120px;object-fit:contain;border-radius:50%;box-shadow:0 4px 15px #667eea4d}.veilsight-logo-mini h4{margin:0;font-size:18px;font-weight:700;color:#333;background:linear-gradient(45deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-message{margin-bottom:24px;padding:16px;background:#667eea0d;border-radius:12px;border-left:4px solid #667eea}.about-message p{margin:0;font-size:14px;line-height:1.6;color:#374151;text-align:left}.about-contact{margin-bottom:24px;text-align:center}.contact-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.contact-icon{font-size:16px}.contact-text{font-size:14px;color:#374151;font-weight:500}.about-version{text-align:center;margin-bottom:20px;padding:12px;background:linear-gradient(45deg,#667eea1a,#764ba21a);border-radius:8px;border:1px solid rgba(102,126,234,.2)}.version-text{font-size:16px;font-weight:600;color:#667eea;font-family:monospace}.about-footer{text-align:center;padding-top:16px;border-top:1px solid #e5e7eb}.about-footer p{margin:0;font-size:13px;color:#6b7280;font-style:italic}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes subtle-pulse{0%,to{opacity:.8}50%{opacity:1}}@media (max-width: 430px){.menu-overlay{padding:10px}.menu-container{min-width:260px}.creatures-grid{padding:10px;gap:6px}.creature-card{padding:10px;min-height:65px}.creature-image-container{width:55px;height:55px}.creature-name{font-size:15px}.creature-type{font-size:12px}.creature-rarity{font-size:10px}.about-content{padding:16px}.veilsight-logo-mini h4{font-size:16px}.logo-icon{width:50px;height:50px;font-size:28px}.logo-image{width:100px;height:100px}.about-message{padding:12px;margin-bottom:20px}.about-message p{font-size:13px}.contact-item{padding:10px}.contact-text{font-size:13px}.version-text{font-size:14px}.coming-soon-badge{font-size:9px;padding:3px 6px}.about-footer p{font-size:12px}.dev-force-movement-section{margin:12px 16px;padding:12px}.force-movement-button{padding:10px 16px;font-size:13px}.dev-warning-text{font-size:10px}}@media (max-width: 360px){.creature-card{padding:8px;gap:10px}.creature-image-container{width:50px;height:50px}.creature-name{font-size:14px}.about-content{padding:12px}.logo-icon{width:45px;height:45px;font-size:24px}.logo-image{width:90px;height:90px}.veilsight-logo-mini h4{font-size:14px}.about-message p{font-size:12px}}.staff-link-container{margin-top:16px;text-align:center}.staff-link{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block}.staff-link:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.staff-content{padding:20px;max-height:calc(80vh - 120px);overflow-y:auto}.staff-intro{margin-bottom:24px;text-align:center}.staff-intro p{font-size:14px;color:#666;line-height:1.5}.staff-grid{display:flex;flex-direction:column;gap:20px}.staff-member{background:#fffc;border-radius:12px;padding:16px;display:flex;align-items:flex-start;gap:16px;border:2px solid #e0e0e0;transition:all .3s ease}.staff-member:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.staff-portrait{flex-shrink:0}.staff-avatar{width:60px;height:60px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:24px;border:3px solid black;box-shadow:0 4px 15px #0000001a;overflow:hidden}.staff-info{flex:1;min-width:0}.staff-info h4{margin:0 0 4px;font-size:16px;font-weight:700;color:#333}.staff-title{margin:0 0 8px;font-size:12px;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px}.staff-bio{margin:0;font-size:13px;color:#666;line-height:1.4}.staff-footer{margin-top:24px;text-align:center;padding-top:16px;border-top:1px solid #e0e0e0}.staff-footer p{margin:0;font-size:13px;color:#888;font-style:italic}@media (max-width: 430px){.staff-content{padding:16px}.staff-member{padding:12px;gap:12px;flex-direction:column;text-align:center}.staff-avatar{width:50px;height:50px;font-size:20px;align-self:center}.staff-info h4{font-size:15px}.staff-title{font-size:11px}.staff-bio{font-size:12px}.staff-link{padding:10px 20px;font-size:13px}}@media (max-width: 360px){.staff-member{padding:10px;gap:10px}.staff-avatar{width:45px;height:45px;font-size:18px}.staff-info h4{font-size:14px}.staff-bio{font-size:11px}}.department-head{margin-bottom:32px;border-bottom:2px solid #667eea;padding-bottom:24px}.head-researcher{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:3px solid #667eea;box-shadow:0 6px 20px #667eea26}.head-researcher .staff-avatar{background:linear-gradient(135deg,#667eea,#764ba2);width:70px;height:70px;font-size:28px;border:4px solid black;border-radius:14px;overflow:hidden}.head-researcher .staff-info h4{font-size:18px;color:#667eea}.head-researcher .staff-title{font-size:14px;color:#764ba2;font-weight:700}.staff-image{width:100%;height:100%;object-fit:cover;object-position:center 10%}.staff-section{margin-bottom:40px}.section-title{font-size:20px;font-weight:700;color:#333;margin:0 0 20px;padding:12px 0;border-bottom:2px solid #e0e0e0;text-align:center;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:8px;position:relative}.section-title:before{content:"";position:absolute;left:50%;bottom:-2px;width:60px;height:3px;background:linear-gradient(45deg,#667eea,#764ba2);transform:translate(-50%)}@media (max-width: 430px){.head-researcher .staff-avatar{width:60px;height:60px;font-size:24px}.head-researcher .staff-info h4{font-size:16px}.head-researcher .staff-title{font-size:12px}.section-title{font-size:18px;padding:10px 0}.department-head{margin-bottom:24px;padding-bottom:16px}.staff-section{margin-bottom:32px}}@media (max-width: 360px){.head-researcher .staff-avatar{width:55px;height:55px;font-size:22px}.head-researcher .staff-info h4{font-size:15px}.section-title{font-size:16px}}.location-info{background:#fffffff2;border-radius:12px;padding:16px;margin:16px 0;box-shadow:0 4px 12px #0000001a;border:1px solid rgba(139,92,246,.2);backdrop-filter:blur(10px);max-width:100%;overflow:hidden}.location-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid rgba(139,92,246,.1)}.location-header h3{margin:0;font-size:18px;color:#333;font-weight:700}.location-content{display:flex;flex-direction:column;gap:16px}.location-name{text-align:center;margin-bottom:8px}.location-name h4{margin:0 0 8px;font-size:20px;color:#333;font-weight:700;line-height:1.2}.location-badges{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.location-type,.location-country{background:linear-gradient(45deg,#8b5cf6,#667eea);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize}.location-country{background:linear-gradient(45deg,#667eea,#764ba2)}.location-details{display:flex;flex-direction:column;gap:12px}.location-coordinates,.location-region{background:#8b5cf60d;padding:12px;border-radius:8px;border-left:4px solid #8b5cf6}.location-coordinates p,.location-region p{margin:0;font-size:14px;color:#333}.location-coordinates strong,.location-region strong{color:#8b5cf6;font-weight:600}.location-features{background:#ffc1070d;padding:12px;border-radius:8px;border-left:4px solid #ffc107}.location-features p{margin:0 0 8px;font-size:14px;color:#333;font-weight:600}.features-list{display:flex;flex-wrap:wrap;gap:6px}.feature-tag{background:#ffc1071a;color:#d97706;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize;border:1px solid rgba(255,193,7,.2);display:inline-flex;align-items:center;gap:4px}.feature-tag.ancient{background:#8b45131a;color:#8b4513;border-color:#8b451333}.feature-tag.mystical{background:#9333ea1a;color:#9333ea;border-color:#9333ea33}.feature-tag.dangerous{background:#ef44441a;color:#dc2626;border-color:#ef444433}.feature-tag.volcanic{background:#ff45001a;color:#ff4500;border-color:#ff450033}.location-lore{background:#22c55e0d;padding:12px;border-radius:8px;border-left:4px solid #22c55e}.location-lore p{margin:0;font-size:14px;color:#333;line-height:1.5}.location-lore strong{color:#22c55e;font-weight:600}.location-timestamp{text-align:center;padding-top:8px;border-top:1px solid rgba(139,92,246,.1)}.timestamp{margin:0;font-size:12px;color:#666;font-style:italic}.location-loading{text-align:center;padding:24px;color:#666}.loading-spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 12px}.location-loading p{margin:0;font-size:14px;color:#666}.location-error{text-align:center;padding:16px;background:#ef44440d;border-radius:8px;border:1px solid rgba(239,68,68,.2)}.location-error p{margin:0 0 12px;color:#dc2626;font-size:14px}.retry-button{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s ease}.retry-button:hover{background:#b91c1c}.location-unknown{text-align:center;padding:16px;background:#6b72800d;border-radius:8px;border:1px solid rgba(107,114,128,.2)}.location-unknown p{margin:0 0 8px;color:#374151;font-size:14px}.location-mystery{font-style:italic;color:#6b7280;font-size:13px}@media (max-width: 480px){.location-info{padding:12px;margin:12px 0}.location-header h3{font-size:16px}.location-name h4{font-size:18px}.location-badges{gap:6px}.location-type,.location-country{font-size:11px;padding:3px 10px}.location-coordinates,.location-region,.location-features,.location-lore{padding:10px}.features-list{gap:4px}.feature-tag{font-size:10px;padding:3px 6px}}@media (min-width: 481px) and (max-width: 768px){.location-info{max-width:500px;margin:16px auto}.location-details{display:grid;grid-template-columns:1fr 1fr;gap:16px}.location-coordinates{grid-column:1 / -1}}@media (min-width: 769px){.location-info{max-width:600px;margin:20px auto}.location-details{display:grid;grid-template-columns:1fr 1fr;gap:20px}.location-coordinates,.location-features,.location-lore{grid-column:1 / -1}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segui UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;overflow-y:auto}#root{height:100%}.App{min-height:100vh;display:flex;flex-direction:column;background:#0a0a0a;color:#fff;position:relative;overflow-x:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}.app-header{background:#000000e6;backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);padding:var(--space-md) var(--space-lg);z-index:var(--z-sticky);flex-shrink:0;padding-top:max(var(--space-md),env(safe-area-inset-top));padding-left:max(var(--space-lg),env(safe-area-inset-left));padding-right:max(var(--space-lg),env(safe-area-inset-right))}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.app-brand{display:flex;align-items:center;gap:12px}.app-logo{width:var(--touch-target-comfortable);height:var(--touch-target-comfortable);object-fit:contain}.app-title{font-size:20px;font-weight:700;background:linear-gradient(45deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.current-creature{display:flex;align-items:center;gap:10px;background:#ffffff1a;padding:8px 12px;border-radius:var(--radius-xl);backdrop-filter:blur(10px)}.creature-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid rgba(102,126,234,.3);background-color:#667eea1a;background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><text y="50" font-size="40" text-anchor="middle" x="50">🐉</text></svg>');background-size:60%;background-repeat:no-repeat;background-position:center}.creature-name{font-size:14px;font-weight:600;color:#fff}.force-movement-section{padding:16px 20px;background:#dc26261a;border-bottom:2px solid rgba(220,38,38,.3);text-align:center}.force-movement-button{background:linear-gradient(45deg,#dc2626,#b91c1c);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #dc26264d;margin-bottom:8px;min-width:200px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.force-movement-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #dc262666}.force-movement-button:disabled{opacity:.6;cursor:not-allowed;transform:none;background:linear-gradient(45deg,#7f7f7f,#666);box-shadow:none}.force-movement-note{display:block;color:#dc2626;font-size:11px;font-weight:500}.app-main{flex:1;position:relative;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;display:flex;flex-direction:column;padding-bottom:max(0px,env(safe-area-inset-bottom))}.error-screen{position:fixed;inset:0;background:linear-gradient(135deg,#ff6b6b,#ee5a52);display:flex;align-items:center;justify-content:center;padding:20px}.error-container{background:#fffffff2;border-radius:var(--radius-xl);padding:40px;text-align:center;color:#333;max-width:400px;width:100%}.error-container h2{color:#ff6b6b;margin-bottom:15px;font-size:24px}.error-container p{margin-bottom:25px;color:#666;line-height:1.5;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.error-container button{background:#ff6b6b;color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:background .3s ease}.error-container button:hover{background:#ee5a52}.no-creature{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px;text-align:center}.no-creature p{font-size:18px;color:#ffffffb3;margin-bottom:20px;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.no-creature button{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-sm);font-size:16px;cursor:pointer;transition:transform .2s ease}.no-creature button:hover{transform:translateY(-2px)}.debug-panel{position:fixed;bottom:20px;right:20px;background:#000c;color:#fff;padding:10px;border-radius:var(--radius-sm);font-size:12px;z-index:1000;display:flex;flex-direction:column;gap:5px}.debug-panel button{background:#667eea;color:#fff;border:none;padding:5px 10px;border-radius:4px;font-size:10px;cursor:pointer}@media (max-width: 768px){.app-header{padding:calc(var(--space-sm) + 2px) var(--space-md);padding-top:max(calc(var(--space-sm) + 2px),env(safe-area-inset-top));padding-left:max(var(--space-md),env(safe-area-inset-left));padding-right:max(var(--space-md),env(safe-area-inset-right))}.app-title{font-size:calc(var(--base-font-size) * var(--font-scale-lg))}.current-creature{padding:var(--space-xs) calc(var(--space-sm) + 2px)}.creature-avatar{width:28px;height:28px}.creature-name{font-size:calc(var(--base-font-size) * var(--font-scale-xs))}.debug-panel{bottom:var(--space-sm);right:var(--space-sm);font-size:calc(var(--base-font-size) * var(--font-scale-xs))}}@media (max-width: 430px){.app-header{padding:8px 12px;padding-top:max(8px,env(safe-area-inset-top));padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.app-title{font-size:16px}.header-content{gap:10px}.current-creature{padding:4px 8px;min-width:0}.creature-name{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.error-container{padding:30px 20px;margin:20px}.error-container h2{font-size:20px}}@media (max-width: 360px){.app-header{padding:6px 10px;padding-top:max(6px,env(safe-area-inset-top));padding-left:max(10px,env(safe-area-inset-left));padding-right:max(10px,env(safe-area-inset-right))}.app-title{font-size:14px}.current-creature{padding:4px 6px}.creature-avatar{width:24px;height:24px}.creature-name{font-size:10px;max-width:60px}}@media (max-height: 500px) and (orientation: landscape){.app-header{padding:6px 15px;padding-top:max(6px,env(safe-area-inset-top));padding-left:max(15px,env(safe-area-inset-left));padding-right:max(15px,env(safe-area-inset-right))}.app-title{font-size:16px}.current-creature{padding:4px 8px}.creature-avatar{width:24px;height:24px}.debug-panel{bottom:5px;right:5px;padding:5px}}.creature-card-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:flex-end;padding:20px;animation:fadeIn .3s ease-out;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none}.creature-card{position:relative;background:#fffffff2;border-radius:20px 20px 0 0;max-width:500px;width:100%;margin:0 auto;box-shadow:0 -10px 30px #0000004d;overflow:hidden;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;transform:translateZ(0);will-change:transform,opacity;outline:none!important;border:none!important;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.creature-card:focus,.creature-card:focus-visible,.creature-card:active{outline:none!important;border:none!important;box-shadow:0 -10px 30px #0000004d!important;background:#fffffff2!important}.creature-card *,.creature-card-overlay *{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none}.creature-description,.location-description,.error-text,.creature-details p{-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;user-select:text!important}.creature-card-overlay,.creature-card,.creature-card-header,.creature-card-content,.creature-info{-webkit-tap-highlight-color:transparent!important;-webkit-touch-callout:none!important;-webkit-user-select:none!important;-khtml-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.close-button,.share-button{-webkit-user-select:none!important;-moz-user-select:none!important;user-select:none!important;-webkit-tap-highlight-color:rgba(0,0,0,.1)!important;outline:none!important}.close-button:focus,.share-button:focus{outline:2px solid #667eea!important;outline-offset:2px!important}.creature-card-header{display:flex;justify-content:center;align-items:center;padding:20px 24px 16px;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}.close-button{position:absolute;top:16px;right:16px;background:#000000b3;color:#fff;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);z-index:10;box-shadow:0 4px 12px #0000004d}.close-button:hover{background:#ef4444e6;border-color:#ffffff80;transform:scale(1.05)}.close-button:active{transform:scale(.95)}.creature-name-badge{display:inline-block;padding:12px 24px;border-radius:var(--radius-xl);font-size:24px;font-weight:700;margin:0;text-align:center;border:2px solid #000000;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;text-shadow:none}.creature-name-badge:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.rarity-common .creature-name-badge{background:#fff;color:#000;border-color:#000}.rarity-uncommon .creature-name-badge{background:#fbbf24;color:#000;border-color:#000;box-shadow:0 4px 15px #fbbf244d}.rarity-rare .creature-name-badge{background:#dc2626;color:#fff;border-color:#000;box-shadow:0 4px 15px #dc262666}.rarity-unique .creature-name-badge{background:#7c3aed;color:#fff;border-color:#000;box-shadow:0 4px 15px #d9770666}.rarity-legendary .creature-name-badge{background:#d97706;color:#fff;border-color:#000;box-shadow:0 4px 15px #7c3aed66}.creature-card-content{padding:20px 24px 24px;overflow-y:auto;flex:1}.creature-image-section{text-align:center;margin-top:20px;margin-bottom:8px;padding:0 12px}.creature-card-image{width:85%;max-width:350px;aspect-ratio:5 / 3;border-radius:var(--radius-lg);object-fit:cover;object-position:center center;display:block;margin:0 auto;background-color:#8b5cf61a;transition:transform .2s ease,box-shadow .2s ease;border:3px solid rgba(139,92,246,.3);box-shadow:0 8px 25px #00000026}.creature-card-image.rarity-common{border:3px solid rgba(139,92,246,.3);box-shadow:0 8px 25px #00000026}.creature-card-image.rarity-uncommon{border:3px solid #fbbf24;box-shadow:0 8px 25px #00000026,0 0 20px #fbbf2466,0 0 40px #fbbf2433;animation:uncommonGlow 3s ease-in-out infinite}.creature-card-image.rarity-rare{border:3px solid #ef4444;box-shadow:0 8px 25px #00000026,0 0 20px #ef444480,0 0 40px #ef44444d;animation:rareGlow 2.5s ease-in-out infinite}.creature-card-image.rarity-unique{border:3px solid #8b5cf6;box-shadow:0 8px 25px #00000026,0 0 20px #8b5cf699,0 0 40px #8b5cf666;animation:uniqueGlow 2s ease-in-out infinite}.creature-card-image.rarity-legendary{border:3px solid #f59e0b;box-shadow:0 8px 25px #00000026,0 0 25px #f59e0bb3,0 0 50px #f59e0b80,0 0 75px #f59e0b4d;animation:legendaryGlow 1.5s ease-in-out infinite}@keyframes uncommonGlow{0%,to{box-shadow:0 8px 25px #00000026,0 0 20px #fbbf2466,0 0 40px #fbbf2433}50%{box-shadow:0 8px 25px #00000026,0 0 25px #fbbf2499,0 0 50px #fbbf2466}}@keyframes rareGlow{0%,to{box-shadow:0 8px 25px #00000026,0 0 20px #ef444480,0 0 40px #ef44444d}50%{box-shadow:0 8px 25px #00000026,0 0 30px #ef4444b3,0 0 60px #ef444480}}@keyframes uniqueGlow{0%,to{box-shadow:0 8px 25px #00000026,0 0 20px #8b5cf699,0 0 40px #8b5cf666}50%{box-shadow:0 8px 25px #00000026,0 0 35px #8b5cf6cc,0 0 70px #8b5cf699}}@keyframes legendaryGlow{0%,to{box-shadow:0 8px 25px #00000026,0 0 25px #f59e0bb3,0 0 50px #f59e0b80,0 0 75px #f59e0b4d}50%{box-shadow:0 8px 25px #00000026,0 0 40px #f59e0be6,0 0 80px #f59e0bb3,0 0 120px #f59e0b80}}.creature-subtype-badge{width:85%;max-width:350px;margin:8px auto 0;padding:12px 16px;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border-radius:var(--radius-xl);font-size:14px;font-weight:600;text-align:center;text-transform:capitalize;box-shadow:0 4px 15px #667eea4d;transition:all .2s ease}.creature-subtype-badge:hover{transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.creature-badges{display:none}.creature-info-section{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.creature-detail{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05)}.creature-detail .value{color:#333;font-size:14px;text-align:right}.creature-description-section{margin-bottom:24px}.creature-description{margin:0;font-size:14px;line-height:1.6;color:#555;text-align:left;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.creature-actions{margin-top:20px;padding-top:20px;border-top:1px solid rgba(0,0,0,.1)}.share-button{width:100%;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 24px;border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;display:flex;align-items:center;justify-content:center;gap:8px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.value.rarity-common{color:#9ca3af}.value.rarity-uncommon{color:#fbbf24}.value.rarity-rare{color:#ef4444}.value.rarity-unique{color:#a855f7}.value.rarity-legendary{color:#d97706}@media (max-width: 430px){.creature-card-overlay{padding:10px}.creature-card{max-height:85vh}.creature-card-header{padding:16px 20px 12px}.creature-name-badge{font-size:20px;padding:10px 20px;border-width:2px}.creature-card-content{padding:16px 20px 20px}.creature-image-section{padding:0 8px}.creature-card-image{width:80%;max-width:280px;border-radius:var(--radius-md);border-width:2px}.creature-subtype-badge{width:80%;max-width:280px;padding:10px 14px;font-size:13px;margin-top:12px}.creature-detail{padding:6px 0}.creature-detail .label,.creature-detail .value{font-size:13px}.creature-description-section h4{font-size:16px}.creature-description{font-size:13px}.share-button{padding:14px 20px;font-size:15px}.close-button{top:12px;right:12px;width:32px;height:32px;font-size:16px}}@media (max-width: 360px){.creature-name-badge{font-size:18px;padding:8px 16px;border-width:1px}.creature-card-image{width:85%;max-width:250px;border-radius:10px}.creature-subtype-badge{width:85%;max-width:250px;padding:8px 12px;font-size:12px}.share-button{font-size:14px}.close-button{width:28px;height:28px;font-size:14px}}@media (max-width: 360px){.creature-card-image{max-width:220px;height:147px}.creature-name-badge{font-size:16px}.creature-detail .label,.creature-detail .value{font-size:12px}}@media (max-height: 450px) and (orientation: landscape){.creature-card{max-height:90vh;border-radius:var(--radius-md)}.creature-card-image{max-width:200px;height:133px}}input,select,textarea{font-size:16px}button:focus-visible,.close-button:focus-visible{outline:2px solid #667eea;outline-offset:2px}@media (display-mode: standalone){.app-header{padding-top:max(12px,env(safe-area-inset-top) + 8px)}}@media (hover: none) and (pointer: coarse){button,.current-creature{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}.current-creature{min-height:auto;padding:8px 12px}}@media (prefers-color-scheme: dark){.error-container{background:#141414f2;color:#fff}.error-container p{color:#ffffffb3}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-reduced-motion: no-preference){.creature-card{transform:translateZ(0);will-change:transform,opacity}}.current-creature{display:flex;align-items:center;gap:8px;background:#ffffff1a;padding:8px 12px;border-radius:var(--radius-xl);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.creature-count{background:#8b5cf6cc;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(255,255,255,.3);animation:subtle-glow 2s ease-in-out infinite}@keyframes subtle-glow{0%,to{box-shadow:0 0 5px #8b5cf64d}50%{box-shadow:0 0 15px #8b5cf699}}.debug-panel{position:fixed;bottom:10px;left:10px;background:#000c;color:#fff;padding:10px;border-radius:var(--radius-sm);font-size:12px;z-index:1500;display:flex;flex-direction:column;gap:4px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.debug-panel button{background:#8b5cf6;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:10px;cursor:pointer;transition:background-color .2s ease}.debug-panel button:hover{background:#7c3aed}.debug-panel small{font-size:10px;opacity:.8}.rarity-common{color:#9ca3af}.rarity-uncommon{color:#fbbf24}.rarity-rare{color:#ef4444}.rarity-unique{color:#a855f7}.rarity-legendary{color:#d97706}.creature-card{position:relative;overflow:hidden}.creature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6b7280,#10b981,#3b82f6,#8b5cf6,#f59e0b);opacity:.6}.force-movement-section{margin-bottom:20px;padding:16px;background:#8b5cf61a;border-radius:var(--radius-sm);border:1px solid rgba(139,92,246,.2)}.force-movement-button{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s ease;margin-bottom:8px;display:block;width:100%}.force-movement-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.force-movement-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.force-movement-note{color:#ffffffb3;font-style:italic;display:block;text-align:center}.debug-buttons-container{display:flex;flex-direction:column;gap:8px;margin-top:12px;align-items:center}.debug-button{background:#8b5cf6cc;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px;text-align:center;box-shadow:0 2px 4px #0000001a}.debug-button:hover:not(:disabled){background:#8b5cf6;transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.debug-button:active{transform:translateY(0)}.debug-button:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 430px){.debug-buttons-container{gap:6px;margin-top:10px}.debug-button{padding:5px 10px;font-size:10px;min-width:100px}.current-creature{gap:6px;padding:6px 10px}.creature-count{font-size:10px;padding:1px 4px}.debug-panel{bottom:8px;left:8px;padding:8px;gap:3px}.debug-panel{max-width:calc(100vw - 100px)}}@media (prefers-reduced-motion: reduce){.creature-card-image.rarity-uncommon,.creature-card-image.rarity-rare,.creature-card-image.rarity-unique,.creature-card-image.rarity-legendary{animation:none}}.creature-card-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(10px);z-index:var(--z-dropdown);display:flex;align-items:flex-end;padding:var(--space-xl);animation:fadeIn .3s ease-out;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none}.creature-card{position:relative;background:#fffffff2;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:500px;width:100%;margin:0 auto;box-shadow:0 -10px 30px #0000004d;overflow:hidden;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;transform:translateZ(0);will-change:transform,opacity;outline:none!important;border:none!important;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.creature-card-header{display:flex;justify-content:flex-start;align-items:center;padding:20px 24px 16px;background:#fffffff2;border-bottom:1px solid rgba(139,92,246,.2)}.creature-name-badge{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;padding:var(--space-md) var(--space-xxl);border-radius:25px;font-size:22px;font-weight:700;margin:0;box-shadow:0 4px 15px #667eea4d;border:3px solid rgba(255,255,255,.9);text-transform:capitalize;letter-spacing:.5px}.close-button{position:absolute;top:16px;right:16px;background:#ffffffe6;border:none;border-radius:var(--radius-full);width:var(--touch-target-min);height:var(--touch-target-min);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:#666;transition:all .2s ease;z-index:10;box-shadow:0 2px 8px #0000001a}.close-button:hover{background:#fff;transform:scale(1.1);color:#333}.creature-card-content{flex:1;padding:20px 24px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.creature-image-section{display:flex;justify-content:center;padding:0 12px}.creature-card-image{width:90%;max-width:320px;height:auto;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-lg);box-shadow:0 8px 25px #0003;border:3px solid rgba(255,255,255,.9);background:#f8f9fa}.creature-subtype-badge{background:linear-gradient(45deg,#8b5cf6,#667eea);color:#fff;padding:12px 16px;border-radius:20px;font-size:14px;font-weight:600;text-align:center;margin:0 auto;width:85%;max-width:300px;box-shadow:0 4px 12px #8b5cf64d;text-transform:capitalize;letter-spacing:.5px}.creature-details{background:#f8f9facc;border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid rgba(139,92,246,.1)}.creature-detail{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05)}.creature-detail:last-child{border-bottom:none}.creature-detail .label{font-weight:600;color:#666;font-size:14px}.creature-detail .value{color:#333;font-size:14px;text-align:right;font-weight:500}.information-section{background:#f8f9facc;border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid rgba(139,92,246,.1)}.information-section h4{margin:0 0 16px;font-size:18px;color:#1e40af;font-weight:600}.creature-fact{margin-bottom:16px;padding:var(--space-lg);background:#ffffffe6;border-radius:var(--radius-sm);border-left:4px solid #8b5cf6;width:100%;box-sizing:border-box}.fact-text{margin:0;font-size:14px;line-height:1.6;color:#444;font-style:italic;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;user-select:text!important}.fact-loading{display:flex;align-items:center;gap:12px;color:#666}.fact-loading p{margin:0;font-size:14px}.location-placeholder{padding:var(--space-lg);background:#ffffffe6;border-radius:var(--radius-sm);border:2px dashed #ddd;text-align:center}.location-placeholder p{margin:0;font-size:14px;color:#666;font-style:italic}.creature-description-section{background:#f8f9facc;border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid rgba(139,92,246,.1)}.creature-description-section h4{margin:0 0 12px;font-size:18px;color:#333;font-weight:600}.creature-description{margin:0;font-size:14px;line-height:1.6;color:#555;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;user-select:text!important}.creature-actions{margin-top:8px;padding-top:16px;border-top:1px solid rgba(0,0,0,.1)}.share-button{width:100%;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 24px;border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.share-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.share-button:active{transform:translateY(0)}.share-icon{font-size:18px}.loading-spinner{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #8b5cf6;border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 430px){.creature-card-overlay{padding:10px}.creature-card{max-height:85vh;border-radius:16px 16px 0 0}.creature-card-header{padding:16px 20px 12px}.creature-name-badge{font-size:20px;padding:10px 20px;border-width:2px}.creature-card-content{padding:16px 20px 20px;gap:16px}.creature-image-section{padding:0 8px}.creature-card-image{width:80%;max-width:280px;border-radius:var(--radius-md);border-width:2px}.creature-subtype-badge{width:80%;max-width:280px;padding:10px 14px;font-size:13px;margin-top:12px}.creature-detail{padding:6px 0}.creature-detail .label,.creature-detail .value{font-size:13px}.information-section h4,.creature-description-section h4{font-size:16px}.fact-text,.creature-description{font-size:13px}.share-button{padding:14px 20px;font-size:15px}.close-button{top:12px;right:12px;width:var(--touch-target-min);height:var(--touch-target-min);font-size:16px}}@media (max-width: 360px){.creature-name-badge{font-size:18px;padding:8px 16px;border-width:1px}.creature-card-image{width:85%;max-width:250px;border-radius:10px}.creature-subtype-badge{width:85%;max-width:250px;padding:8px 12px;font-size:12px}.share-button{font-size:14px}.close-button{width:var(--touch-target-min);height:var(--touch-target-min);font-size:14px}}@media (max-height: 450px) and (orientation: landscape){.creature-card{max-height:90vh;border-radius:var(--radius-md)}.creature-card-image{max-width:200px;height:auto}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.creature-card-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (prefers-color-scheme: dark){.creature-card{background:#1e1e1ef2;color:#fff}.creature-card-header{background:#1e1e1ef2;border-bottom:1px solid rgba(139,92,246,.3)}.creature-details,.information-section,.creature-description-section{background:#282828cc;border-color:#8b5cf64d}.creature-fact,.location-placeholder{background:#323232e6}.creature-detail .label{color:#ccc}.creature-detail .value{color:#fff}.fact-text,.creature-description{color:#ddd}.location-placeholder p{color:#999}}.close-button:focus-visible,.share-button:focus-visible{outline:2px solid #667eea;outline-offset:2px}@media (hover: none) and (pointer: coarse){.share-button,.close-button{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}}
