@import"https://fonts.googleapis.com/css2?family=Creepster&family=Cinzel:wght@400;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;--color-bg-dark: #0d0d0d;--color-bg-purple: #1a0a2e;--color-purple: #9d4edd;--color-purple-light: #e0aaff;--color-orange: #ff6b35;--color-orange-dark: #8b2500;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease;color-scheme:dark;color:#ffffffe6;background-color:var(--color-bg-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--color-bg-dark)}a{color:var(--color-purple-light);text-decoration:none}a:hover{color:var(--color-purple)}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}button{border-radius:var(--radius-md);border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1e1e1ecc;color:inherit;cursor:pointer;transition:all var(--transition-normal)}button:hover:not(:disabled){border-color:var(--color-purple)}button:focus-visible{outline:2px solid var(--color-purple);outline-offset:2px}button:disabled{cursor:not-allowed;opacity:.5}input,select{font-family:inherit}*:focus-visible{outline:2px solid var(--color-purple);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body.reduced-motion *,body.reduced-motion *:before,body.reduced-motion *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.skip-to-main{position:absolute;top:-40px;left:0;background:var(--color-purple);color:#fff;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;z-index:10000;font-weight:600;border-radius:0 0 var(--radius-sm) 0}.skip-to-main:focus{top:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{background:var(--color-purple);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-purple-light)}#root{width:100%;height:100vh;margin:0;padding:0;overflow:hidden}.app-container{position:relative;width:100%;height:100vh;background:radial-gradient(ellipse at top,#1a0a2e,#0d0d0d,#000);overflow:hidden}.app-container:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20px 30px,#fff,transparent),radial-gradient(2px 2px at 40px 70px,rgba(255,255,255,.8),transparent),radial-gradient(1px 1px at 90px 40px,#fff,transparent),radial-gradient(2px 2px at 160px 120px,rgba(255,255,255,.9),transparent),radial-gradient(1px 1px at 230px 80px,#fff,transparent),radial-gradient(2px 2px at 300px 150px,rgba(255,255,255,.7),transparent);background-size:350px 200px;opacity:.4;pointer-events:none;z-index:0;animation:twinkle 8s ease-in-out infinite}@keyframes twinkle{0%,to{opacity:.4}50%{opacity:.6}}.texture-overlay,.fog-layer{display:none}.app-content{position:relative;width:100%;height:100vh;z-index:10;display:flex;flex-direction:column;padding:.75rem 1.5rem 1rem;box-sizing:border-box;overflow:hidden}.app-header{text-align:center;margin-bottom:.75rem;flex-shrink:0}.app-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:700;color:#ff6b35;text-shadow:0 0 20px rgba(255,107,53,.8),0 0 40px rgba(255,107,53,.5),0 0 60px rgba(255,107,53,.3),0 4px 0 #8b2500;margin:0;letter-spacing:.05em;font-family:Creepster,Cinzel,Georgia,serif;animation:glow-pulse 3s ease-in-out infinite}@keyframes glow-pulse{0%,to{text-shadow:0 0 20px rgba(255,107,53,.8),0 0 40px rgba(255,107,53,.5),0 0 60px rgba(255,107,53,.3),0 4px 0 #8b2500}50%{text-shadow:0 0 30px rgba(255,107,53,1),0 0 60px rgba(255,107,53,.7),0 0 80px rgba(255,107,53,.5),0 4px 0 #8b2500}}.app-subtitle{font-size:clamp(.9rem,2vw,1.1rem);color:#9d4edd;text-shadow:0 0 15px rgba(157,78,221,.6);margin:.5rem 0 0;font-style:italic;font-family:Cinzel,Georgia,serif}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem;min-height:0;overflow-y:auto;overflow-x:hidden}.search-container{width:100%;max-width:480px;z-index:200;flex-shrink:0}.main-grid{display:grid;grid-template-columns:1fr 340px;gap:1.5rem;width:100%;max-width:1300px;flex:1;min-height:0;overflow:hidden}.globe-panel{display:flex;flex-direction:column;gap:.5rem;min-height:0;overflow:hidden}.controls-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}.coordinates-display{background:linear-gradient(135deg,#9d4edd26,#0d0d0de6);border:1px solid rgba(157,78,221,.4);border-radius:8px;padding:.75rem 1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fade-in .3s ease-out}.coordinates-display p{margin:0;color:#e0aaff;font-size:.9rem;font-family:JetBrains Mono,Courier New,monospace;letter-spacing:.03em}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.main-grid{grid-template-columns:1fr;max-width:650px;overflow-y:auto}.controls-panel{max-height:350px}}@media(max-width:768px){.app-content{padding:.75rem}.main-grid{gap:1rem}}@media(max-width:480px){.app-content{padding:.5rem}.app-header{margin-bottom:.5rem}}.candlelight-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.candlelight{position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,var(--color-red-crimson) 0%,var(--color-red-blood) 30%,transparent 70%);opacity:.15;filter:blur(20px)}.candlelight-top-left{top:-50px;left:-50px;animation:flicker-1 2s ease-in-out infinite}.candlelight-top-right{top:-50px;right:-50px;animation:flicker-2 2.3s ease-in-out infinite}.candlelight-bottom-left{bottom:-50px;left:-50px;animation:flicker-3 1.8s ease-in-out infinite}.candlelight-bottom-right{bottom:-50px;right:-50px;animation:flicker-4 2.1s ease-in-out infinite}@keyframes flicker-1{0%,to{opacity:.15;transform:scale(1)}10%{opacity:.12;transform:scale(.95)}20%{opacity:.18;transform:scale(1.05)}30%{opacity:.14;transform:scale(.98)}50%{opacity:.16;transform:scale(1.02)}70%{opacity:.13;transform:scale(.96)}85%{opacity:.17;transform:scale(1.03)}}@keyframes flicker-2{0%,to{opacity:.14;transform:scale(1)}15%{opacity:.17;transform:scale(1.04)}35%{opacity:.12;transform:scale(.94)}55%{opacity:.16;transform:scale(1.01)}75%{opacity:.13;transform:scale(.97)}90%{opacity:.15;transform:scale(1.02)}}@keyframes flicker-3{0%,to{opacity:.16;transform:scale(1)}12%{opacity:.13;transform:scale(.96)}28%{opacity:.18;transform:scale(1.06)}45%{opacity:.14;transform:scale(.99)}65%{opacity:.17;transform:scale(1.03)}82%{opacity:.15;transform:scale(1.01)}}@keyframes flicker-4{0%,to{opacity:.15;transform:scale(1)}18%{opacity:.18;transform:scale(1.05)}32%{opacity:.13;transform:scale(.95)}48%{opacity:.16;transform:scale(1.02)}68%{opacity:.14;transform:scale(.98)}88%{opacity:.17;transform:scale(1.04)}}@media(prefers-reduced-motion:reduce){.candlelight{animation:none;opacity:.15}}.jack-o-lantern-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3;overflow:hidden}.jack-glow{position:absolute;border-radius:50%;background:radial-gradient(circle,var(--color-red-crimson) 0%,var(--color-red-blood) 20%,transparent 60%);filter:blur(40px);opacity:.2}.jack-glow-1{width:300px;height:300px;top:10%;left:15%;animation:pulse-glow-1 3s ease-in-out infinite}.jack-glow-2{width:250px;height:250px;top:60%;right:20%;animation:pulse-glow-2 3.5s ease-in-out infinite;animation-delay:.5s}.jack-glow-3{width:200px;height:200px;bottom:15%;left:25%;animation:pulse-glow-3 4s ease-in-out infinite;animation-delay:1s}.jack-glow-4{width:280px;height:280px;top:30%;right:10%;animation:pulse-glow-4 3.2s ease-in-out infinite;animation-delay:1.5s}.jack-glow-5{width:220px;height:220px;bottom:25%;right:35%;animation:pulse-glow-5 3.8s ease-in-out infinite;animation-delay:2s}@keyframes pulse-glow-1{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.25;transform:scale(1.1)}}@keyframes pulse-glow-2{0%,to{opacity:.12;transform:scale(1)}50%{opacity:.22;transform:scale(1.15)}}@keyframes pulse-glow-3{0%,to{opacity:.18;transform:scale(1)}50%{opacity:.28;transform:scale(1.08)}}@keyframes pulse-glow-4{0%,to{opacity:.14;transform:scale(1)}50%{opacity:.24;transform:scale(1.12)}}@keyframes pulse-glow-5{0%,to{opacity:.16;transform:scale(1)}50%{opacity:.26;transform:scale(1.1)}}@media(prefers-reduced-motion:reduce){.jack-glow{animation:none;opacity:.15}}.api-key-settings{position:fixed;top:80px;right:20px;z-index:1000}.api-key-settings-toggle{background:#1a1a1ae6;border:2px solid var(--color-orange-pumpkin, #ff6600);border-radius:50%;width:50px;height:50px;font-size:24px;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 0 15px #ff660080;display:flex;align-items:center;justify-content:center}.api-key-settings-toggle.configured{border-color:var(--color-green-phosphor, #39ff14);box-shadow:0 0 15px #39ff1480}.api-key-settings-toggle:hover{background:#f603;box-shadow:0 0 25px #f60c;transform:scale(1.1)}.api-key-settings-toggle.configured:hover{background:#39ff1433;box-shadow:0 0 25px #39ff14cc}.api-key-settings-toggle:focus-visible{outline:3px solid var(--color-orange-pumpkin, #ff6600);outline-offset:4px}.api-key-settings-panel{position:absolute;top:60px;right:0;background:#1a1a1af2;border:2px solid var(--color-orange-pumpkin, #ff6600);border-radius:var(--radius-md);padding:var(--spacing-lg);min-width:320px;box-shadow:0 0 30px #f609,inset 0 0 20px #00000080;animation:slide-in .3s ease}@keyframes slide-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.api-key-settings-panel h3{margin:0 0 var(--spacing-lg) 0;color:var(--color-orange-pumpkin, #ff6600);font-size:1.2rem;text-align:center;text-shadow:0 0 10px rgba(255,102,0,.5)}.api-key-description{color:var(--color-gray-light, #e0e0e0);font-size:.9rem;margin-bottom:var(--spacing-md);line-height:1.4}.input-group{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.input-group input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:#00000080;border:1px solid rgba(255,102,0,.4);border-radius:var(--radius-sm);color:var(--color-gray-light, #e0e0e0);font-size:.9rem}.input-group input:focus{outline:none;border-color:var(--color-orange-pumpkin, #ff6600);box-shadow:0 0 10px #ff66004d}.input-group input::placeholder{color:#fff6}.save-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-orange-pumpkin, #ff6600);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.save-btn:hover:not(:disabled){background:#ff8533;box-shadow:0 0 15px #f609}.save-btn:disabled{opacity:.5;cursor:not-allowed}.api-key-hint{font-size:.8rem;color:#fff9;margin:0}.api-key-hint a{color:var(--color-orange-pumpkin, #ff6600);text-decoration:none}.api-key-hint a:hover{text-decoration:underline}.api-key-configured{display:flex;flex-direction:column;gap:var(--spacing-md)}.current-key{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#39ff141a;border:1px solid rgba(57,255,20,.3);border-radius:var(--radius-sm)}.key-label{color:var(--color-green-phosphor, #39ff14);font-size:.85rem;white-space:nowrap}.key-value{flex:1;color:var(--color-gray-light, #e0e0e0);font-family:monospace;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;word-break:break-all}.toggle-visibility{background:none;border:none;cursor:pointer;font-size:1rem;padding:2px;opacity:.7;transition:opacity var(--transition-fast)}.toggle-visibility:hover{opacity:1}.api-key-actions{display:flex;justify-content:flex-end}.clear-btn{padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid rgba(255,100,100,.5);border-radius:var(--radius-sm);color:#ff6464;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.clear-btn:hover{background:#ff646433;border-color:#ff6464}@media(max-width:768px){.api-key-settings{top:70px;right:15px}.api-key-settings-toggle{width:45px;height:45px;font-size:20px}.api-key-settings-panel{min-width:280px;padding:var(--spacing-md)}}@media(max-width:480px){.api-key-settings{top:60px;right:10px}.api-key-settings-toggle{width:40px;height:40px;font-size:18px}.api-key-settings-panel{min-width:260px;right:-10px}}.reduced-motion .api-key-settings-toggle,.reduced-motion .api-key-settings-panel{animation:none;transition:none}.globe-container{width:100%;flex:1;min-height:400px;position:relative;border-radius:12px;background:radial-gradient(ellipse at center,#1a0a2e,#0a0a0a 60%,#000);box-shadow:0 8px 32px #0009,inset 0 0 80px #9d4edd1a,0 0 1px #9d4edd4d;overflow:hidden;transition:box-shadow .3s ease}.globe-container:hover{box-shadow:0 12px 40px #000000b3,inset 0 0 100px #9d4edd26,0 0 2px #9d4edd80}.globe-container canvas{display:block;width:100%;height:100%;touch-action:none}.globe-lock-indicator{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#0d0d0de6;border:1px solid rgba(255,107,53,.5);border-radius:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fade-in-up .3s ease-out}.lock-icon{font-size:1rem}.lock-text{font-size:.8rem;color:#ff6b35;font-weight:500;letter-spacing:.02em}@keyframes fade-in-up{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:768px){.globe-container{min-height:250px}}@media(max-width:480px){.globe-container{min-height:220px;border-radius:10px}}.image-display-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);margin:var(--spacing-xl) auto;max-width:900px;width:100%}.image-frame{position:relative;width:100%;max-width:800px;background:linear-gradient(135deg,var(--color-black-deep) 0%,var(--color-purple-dark) 50%,var(--color-black-deep) 100%);border:4px solid var(--color-red-blood);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 0 30px #8b000080,0 0 60px #8b00004d,inset 0 0 30px #000c;overflow:hidden}.frame-corner{position:absolute;width:40px;height:40px;border:3px solid var(--color-green-phosphor);z-index:10;pointer-events:none}.frame-corner-tl{top:0;left:0;border-right:none;border-bottom:none;border-top-left-radius:var(--radius-lg)}.frame-corner-tr{top:0;right:0;border-left:none;border-bottom:none;border-top-right-radius:var(--radius-lg)}.frame-corner-bl{bottom:0;left:0;border-right:none;border-top:none;border-bottom-left-radius:var(--radius-lg)}.frame-corner-br{bottom:0;right:0;border-left:none;border-top:none;border-bottom-right-radius:var(--radius-lg)}.generated-image{width:100%;height:auto;display:block;border-radius:var(--radius-md);transition:opacity var(--transition-slow)}.generated-image.loading{opacity:0;display:none}.generated-image.loaded{opacity:1;animation:fade-in .8s ease-in}@keyframes fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.image-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-green-phosphor);text-align:center}.loading-spinner{margin-bottom:var(--spacing-lg)}.spinner-symbol{font-size:3rem;display:inline-block;animation:spin-and-pulse 2s linear infinite;filter:drop-shadow(0 0 20px var(--color-green-glow))}@keyframes spin-and-pulse{0%{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(180deg) scale(1.2);opacity:.7}to{transform:rotate(360deg) scale(1);opacity:1}}.image-loading p{margin:0;font-size:1.1rem;font-style:italic;text-shadow:0 0 10px var(--color-green-glow)}.image-error{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--color-red-crimson);text-align:center}.image-error p{margin:0;font-size:1.1rem;text-shadow:0 0 10px var(--color-red-glow)}.image-description{width:100%;max-width:800px;background:#0a0a0af2;border:2px solid var(--color-orange-pumpkin, #ff6600);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:0 0 20px #ff66004d,inset 0 0 20px #00000080}.description-title{margin:0 0 var(--spacing-md) 0;color:var(--color-orange-pumpkin, #ff6600);font-size:1.3rem;text-align:center;text-shadow:0 0 10px rgba(255,102,0,.5);font-family:Georgia,serif}.description-text{margin:0;color:var(--color-gray-light, #e0e0e0);font-size:1rem;line-height:1.7;font-family:Georgia,serif;text-align:justify;white-space:pre-wrap}.image-metadata{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%;max-width:800px;background:#0a0a0ae6;border:2px solid var(--color-purple-medium);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:0 0 20px #4a2c5e66,inset 0 0 20px #00000080}.metadata-section{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid rgba(74,44,94,.3)}.metadata-section:last-child{border-bottom:none}.metadata-label{color:var(--color-green-phosphor);font-weight:600;font-size:.95rem;text-shadow:0 0 5px var(--color-green-glow)}.metadata-value{color:var(--color-gray-light);font-size:.95rem;text-align:right;font-family:Courier New,monospace}.image-actions{display:flex;gap:var(--spacing-md);justify-content:center;width:100%;max-width:800px}.action-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);font-size:1rem;font-weight:600;border:2px solid var(--color-purple-medium);border-radius:var(--radius-md);background:linear-gradient(135deg,#0a0a0af2,#2d1b3df2);color:var(--color-green-phosphor);cursor:pointer;transition:all var(--transition-normal);box-shadow:0 0 15px #4a2c5e4d,inset 0 0 15px #00000080;text-shadow:0 0 5px var(--color-green-glow);flex:1;max-width:200px}.action-button:hover{border-color:var(--color-green-phosphor);box-shadow:0 0 25px #39ff1480,0 0 35px #39ff144d,inset 0 0 15px #00000080;transform:translateY(-2px);text-shadow:0 0 10px var(--color-green-glow)}.action-button:active{transform:translateY(0);box-shadow:0 0 15px #39ff144d,inset 0 0 15px #000000b3}.action-button .button-icon{font-size:1.2rem}.action-button .button-label{letter-spacing:.05em}.action-button:focus-visible{outline:3px solid var(--color-green-neon);outline-offset:4px}@media(max-width:768px){.image-display-container{padding:var(--spacing-lg)}.image-frame{padding:var(--spacing-md)}.frame-corner{width:30px;height:30px}.image-metadata{padding:var(--spacing-md)}.metadata-section{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.metadata-value{text-align:left}.image-actions{flex-direction:column}.action-button{max-width:100%}}@media(max-width:480px){.image-display-container{padding:var(--spacing-md)}.image-frame{padding:var(--spacing-sm)}.frame-corner{width:20px;height:20px;border-width:2px}.spinner-symbol{font-size:2rem}.metadata-label,.metadata-value{font-size:.85rem}.action-button{font-size:.9rem;padding:var(--spacing-sm) var(--spacing-md)}}.error-display-container{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl);margin:var(--spacing-xl) auto;max-width:600px;width:100%;animation:shake-in .5s ease-out}@keyframes shake-in{0%{transform:translate(-10px);opacity:0}25%{transform:translate(10px)}50%{transform:translate(-5px)}75%{transform:translate(5px)}to{transform:translate(0);opacity:1}}.error-frame{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);width:100%;background:linear-gradient(135deg,#8b000033,#0a0a0af2,#8b000033);border:3px solid var(--color-red-blood);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 0 30px #dc143c80,0 0 60px #dc143c4d,inset 0 0 30px #000c;position:relative;overflow:hidden}.error-frame:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(220,20,60,.1) 0%,transparent 70%);animation:pulse-error 2s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes pulse-error{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.error-icon{position:relative;z-index:1}.skull-symbol{font-size:4rem;display:inline-block;animation:float-skull 3s ease-in-out infinite;filter:drop-shadow(0 0 20px var(--color-red-glow))}@keyframes float-skull{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-10px) rotate(5deg)}}.error-content{text-align:center;position:relative;z-index:1}.error-title{margin:0 0 var(--spacing-md) 0;color:var(--color-red-crimson);font-size:1.5rem;font-weight:700;text-shadow:0 0 10px var(--color-red-glow),0 0 20px var(--color-red-glow);letter-spacing:.05em}.error-message{margin:0;color:var(--color-gray-light);font-size:1rem;line-height:1.6;max-width:500px}.error-actions{display:flex;gap:var(--spacing-md);justify-content:center;width:100%;position:relative;z-index:1}.error-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);font-size:1rem;font-weight:600;border:2px solid var(--color-red-blood);border-radius:var(--radius-md);background:linear-gradient(135deg,#0a0a0af2,#8b00004d);color:var(--color-red-crimson);cursor:pointer;transition:all var(--transition-normal);box-shadow:0 0 15px #dc143c4d,inset 0 0 15px #00000080;text-shadow:0 0 5px var(--color-red-glow);min-width:140px}.error-button:hover{border-color:var(--color-red-crimson);box-shadow:0 0 25px #dc143c99,0 0 35px #dc143c66,inset 0 0 15px #00000080;transform:translateY(-2px);text-shadow:0 0 10px var(--color-red-glow)}.error-button:active{transform:translateY(0);box-shadow:0 0 15px #dc143c66,inset 0 0 15px #000000b3}.retry-button .button-icon{animation:spin-retry 2s linear infinite}@keyframes spin-retry{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-button .button-icon{font-size:1.2rem}.error-button .button-label{letter-spacing:.05em}.dismiss-button{background:linear-gradient(135deg,#0a0a0af2,#3a3a3a80);border-color:var(--color-gray-stone);color:var(--color-gray-light);text-shadow:none}.dismiss-button:hover{border-color:var(--color-gray-light);box-shadow:0 0 15px #5a5a5a66,inset 0 0 15px #00000080}.error-button:focus-visible{outline:3px solid var(--color-red-crimson);outline-offset:4px}@media(max-width:768px){.error-display-container,.error-frame{padding:var(--spacing-lg)}.skull-symbol{font-size:3rem}.error-title{font-size:1.3rem}.error-message{font-size:.95rem}.error-actions{flex-direction:column}.error-button{width:100%}}@media(max-width:480px){.error-display-container,.error-frame{padding:var(--spacing-md)}.skull-symbol{font-size:2.5rem}.error-title{font-size:1.1rem}.error-message{font-size:.9rem}.error-button{font-size:.9rem;padding:var(--spacing-sm) var(--spacing-md);min-width:120px}}.location-search{position:relative;width:100%;max-width:480px;margin:0 auto;z-index:200}.search-input-container{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:.875rem 2.75rem .875rem 1.25rem;background:#0d0d0de6;border:1px solid rgba(157,78,221,.4);border-radius:10px;color:#e0aaff;font-size:.95rem;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-input::placeholder{color:#9d4edd80;font-style:italic}.search-input:focus{outline:none;border-color:#9d4edd;box-shadow:0 0 0 3px #9d4edd26,0 4px 20px #0000004d}.search-input:hover:not(:focus){border-color:#9d4edd99}.clear-button{position:absolute;right:.875rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#ff6b35;font-size:1.1rem;cursor:pointer;padding:.25rem;transition:all .2s ease;opacity:.8}.clear-button:hover{opacity:1;transform:translateY(-50%) scale(1.1)}.clear-button:focus{outline:2px solid #9d4edd;outline-offset:2px;border-radius:4px}.search-loading-indicator{position:absolute;right:2.5rem;top:50%;transform:translateY(-50%)}.loading-spinner{width:18px;height:18px;border:2px solid rgba(157,78,221,.2);border-top-color:#9d4edd;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#0d0d0dfa;border:1px solid rgba(157,78,221,.4);border-radius:10px;max-height:280px;overflow-y:auto;list-style:none;margin:0;padding:.5rem 0;box-shadow:0 8px 32px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;animation:dropdown-appear .2s ease-out}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.search-dropdown::-webkit-scrollbar{width:6px}.search-dropdown::-webkit-scrollbar-track{background:#0000004d;border-radius:3px}.search-dropdown::-webkit-scrollbar-thumb{background:#9d4edd;border-radius:3px}.search-suggestion{padding:.875rem 1.25rem;cursor:pointer;transition:all .15s ease;border-left:2px solid transparent;display:flex;flex-direction:column;gap:.2rem}.search-suggestion:hover,.search-suggestion.selected{background:#9d4edd1a;border-left-color:#9d4edd}.suggestion-name{color:#e0aaff;font-size:.95rem;font-weight:500}.suggestion-coords{color:#9d4eddb3;font-family:JetBrains Mono,monospace;font-size:.8rem}.search-error{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#8b2500e6;border:1px solid #ff6b35;border-radius:8px;padding:.875rem 1rem;color:#ffb399;font-size:.85rem;text-align:center;animation:dropdown-appear .2s ease-out;z-index:1000}@media(max-width:768px){.search-input{padding:.75rem 2.5rem .75rem 1rem;font-size:.9rem}.search-dropdown{max-height:240px}.search-suggestion{padding:.75rem 1rem}}@media(max-width:480px){.search-input{padding:.7rem 2.25rem .7rem .875rem;font-size:.85rem}}.time-selector{position:relative;background:linear-gradient(135deg,#1a0a2ee6,#0d0d0df2);border:1px solid rgba(157,78,221,.3);border-radius:12px;padding:1.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden}.time-selector:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(157,78,221,.5),transparent)}.time-selector-header{text-align:center;margin-bottom:.75rem}.time-selector-title{font-family:Cinzel,Georgia,serif;font-size:1.1rem;color:#e0aaff;margin:0 0 .25rem;letter-spacing:1px}.time-selector-subtitle{font-family:Georgia,serif;font-size:.85rem;color:#ff6b35;font-style:italic;margin:0;opacity:.9}.time-selector-content{display:flex;flex-direction:column;gap:1rem}.era-toggle-container{display:flex;flex-direction:column;gap:.4rem}.era-label,.control-label{font-size:.75rem;color:#9d4edd;text-transform:uppercase;letter-spacing:1px;font-weight:500}.era-toggle{display:flex;gap:.5rem;background:#0006;padding:.25rem;border-radius:8px;border:1px solid rgba(157,78,221,.2)}.era-button{flex:1;padding:.6rem 1rem;background:transparent;border:1px solid transparent;border-radius:6px;color:#b8b8b8;font-size:.9rem;cursor:pointer;transition:all .2s ease}.era-button:hover{background:#9d4edd1a;color:#e0aaff}.era-button.active{background:linear-gradient(135deg,#9d4edd4d,#9d4edd26);border-color:#9d4edd80;color:#fff}.year-control-container,.month-control-container,.day-control-container{display:flex;flex-direction:column;gap:.4rem}.year-input-group{display:flex;align-items:center;gap:.5rem}.year-input{flex:1;padding:.6rem .75rem;background:#00000080;border:1px solid rgba(157,78,221,.3);border-radius:6px;color:#e0aaff;font-family:JetBrains Mono,monospace;font-size:1rem;text-align:center;transition:all .2s ease}.year-input:focus{outline:none;border-color:#9d4edd;box-shadow:0 0 0 2px #9d4edd33}.era-indicator{font-size:.9rem;color:#ff6b35;font-weight:600;min-width:2.5rem;text-align:center}.year-slider{width:100%;height:6px;background:linear-gradient(to right,#ff6b354d,#9d4edd4d);border-radius:3px;outline:none;-webkit-appearance:none;cursor:pointer}.year-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#9d4edd;border-radius:50%;cursor:pointer;box-shadow:0 0 10px #9d4edd99;transition:transform .2s ease}.year-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.year-slider::-moz-range-thumb{width:16px;height:16px;background:#9d4edd;border:none;border-radius:50%;cursor:pointer;box-shadow:0 0 10px #9d4edd99}.slider-labels{display:flex;justify-content:space-between;font-size:.7rem;color:#9d4edd99;padding:0 .25rem}.month-select,.day-select{padding:.6rem .75rem;background:#00000080;border:1px solid rgba(157,78,221,.3);border-radius:6px;color:#e0aaff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.month-select:focus,.day-select:focus{outline:none;border-color:#9d4edd;box-shadow:0 0 0 2px #9d4edd33}.month-select option,.day-select option{background:#1a0a2e;color:#e0aaff}.time-display{margin-top:.75rem;padding:1rem;background:linear-gradient(135deg,#ff6b351a,#0006);border:1px solid rgba(255,107,53,.3);border-radius:8px;text-align:center}.time-display-label{font-size:.7rem;color:#ff6b35;text-transform:uppercase;letter-spacing:1px;margin-bottom:.25rem}.time-display-value{font-family:Cinzel,Georgia,serif;font-size:1.2rem;color:#fff;text-shadow:0 0 10px rgba(255,107,53,.4)}.wisp{display:none}@media(max-width:768px){.time-selector{padding:1rem}.time-selector-title{font-size:1rem}}.event-randomizer{position:relative;background:linear-gradient(135deg,#1a0a2ee6,#0d0d0df2);border:1px solid rgba(255,107,53,.3);border-radius:12px;padding:1.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden}.event-randomizer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,107,53,.5),transparent)}.event-randomizer-header{text-align:center;margin-bottom:.75rem}.event-randomizer-title{font-family:Cinzel,Georgia,serif;font-size:1.1rem;color:#ff6b35;margin:0 0 .25rem;letter-spacing:1px}.event-randomizer-subtitle{font-size:.85rem;color:#9d4edd;font-style:italic;margin:0}.event-randomizer-content{display:flex;flex-direction:column;gap:1rem}.randomize-button{padding:.875rem 1.25rem;background:linear-gradient(135deg,#ff6b3533,#8b25004d);border:1px solid rgba(255,107,53,.5);border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.randomize-button:hover:not(:disabled){background:linear-gradient(135deg,#ff6b354d,#8b250066);border-color:#ff6b35;transform:translateY(-1px);box-shadow:0 4px 12px #ff6b354d}.randomize-button:active:not(:disabled){transform:translateY(0)}.randomize-button:disabled{opacity:.5;cursor:not-allowed}.randomize-button.animating{animation:pulse .5s ease}.button-icon{font-size:1.2rem}.button-text{letter-spacing:.5px}.button-glow{display:none}.event-display{background:#0006;border:1px solid rgba(157,78,221,.2);border-radius:8px;padding:1rem;animation:fadeIn .3s ease-out}.event-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.event-tag{padding:.2rem .6rem;background:#9d4edd26;border:1px solid rgba(157,78,221,.3);border-radius:12px;color:#e0aaff;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.event-name{font-family:Cinzel,Georgia,serif;font-size:1.25rem;color:#ff6b35;margin:0 0 .75rem}.event-description{font-size:.9rem;line-height:1.5;color:#ccc;margin:0 0 1rem}.event-details{display:flex;flex-direction:column;gap:.75rem;padding-top:.75rem;border-top:1px solid rgba(157,78,221,.2)}.event-detail{display:flex;flex-direction:column;gap:.15rem}.detail-label{font-size:.7rem;color:#9d4edd;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:.95rem;color:#fff}.event-placeholder{padding:1.5rem;text-align:center;border:1px dashed rgba(255,107,53,.3);border-radius:8px}.placeholder-text{font-size:.9rem;color:#ff6b35b3;font-style:italic;margin:0}.pentagram,.mist{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@media(max-width:768px){.event-randomizer{padding:1rem}.event-randomizer-title{font-size:1rem}.event-name{font-size:1.1rem}}.generation-control-panel{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#1a0a2ee6,#0d0d0df2);border:1px solid rgba(157,78,221,.3);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.generate-button{position:relative;width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid #9d4edd;border-radius:8px;background:linear-gradient(135deg,#9d4edd40,#9d4edd1a);color:#fff;cursor:pointer;transition:all .25s ease;text-shadow:0 0 10px rgba(157,78,221,.5)}.generate-button.enabled:hover{background:linear-gradient(135deg,#9d4edd66,#9d4edd33);border-color:#b8a0ff;transform:translateY(-2px);box-shadow:0 8px 24px #9d4edd66}.generate-button.enabled:active{transform:translateY(0);box-shadow:0 4px 12px #9d4edd4d}.generate-button.disabled{border-color:#444;color:#666;cursor:not-allowed;opacity:.5;text-shadow:none;background:#1e1e1e80}.button-content{display:flex;align-items:center;justify-content:center;gap:.75rem}.button-icon{font-size:1.3rem}.button-text{letter-spacing:.05em}.loading-indicator{display:inline-block;animation:spin 1.5s linear infinite}.pentagram{font-size:1.3rem;color:#9d4edd}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hint-text{margin:0;color:#ff6b35;font-size:.8rem;font-style:italic;text-align:center;opacity:.9}.generate-button:focus-visible{outline:2px solid #9d4edd;outline-offset:3px}@media(max-width:768px){.generation-control-panel{padding:1rem}.generate-button{padding:.875rem 1.25rem;font-size:.95rem}}.controls-tabs{display:flex;flex-direction:column;height:100%;background:linear-gradient(135deg,#1a0a2ee6,#0d0d0df2);border:1px solid rgba(157,78,221,.3);border-radius:12px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tabs-nav{display:flex;border-bottom:1px solid rgba(157,78,221,.2);background:#0000004d}.tab-button{flex:1;padding:.875rem .5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:#888;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tab-button:hover{color:#e0aaff;background:#9d4edd1a}.tab-button.active{color:#fff;border-bottom-color:#9d4edd;background:#9d4edd26}.tab-button:focus-visible{outline:2px solid #9d4edd;outline-offset:-2px}.tabs-content{flex:1;overflow-y:auto;overflow-x:hidden}.tab-panel{display:none;padding:1rem}.tab-panel.active{display:block;animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.tab-panel .time-selector,.tab-panel .event-randomizer{background:transparent;border:none;padding:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.tab-panel .time-selector:before,.tab-panel .event-randomizer:before{display:none}.generate-section{padding:1rem;border-top:1px solid rgba(157,78,221,.2);background:#0003}.generate-section .generation-control-panel{background:transparent;border:none;padding:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.tabs-content::-webkit-scrollbar{width:4px}.tabs-content::-webkit-scrollbar-track{background:transparent}.tabs-content::-webkit-scrollbar-thumb{background:#9d4edd66;border-radius:2px}.tabs-content::-webkit-scrollbar-thumb:hover{background:#9d4edd99}@media(max-width:480px){.tab-button{padding:.75rem .25rem;font-size:.8rem}.tab-panel,.generate-section{padding:.75rem}}*{cursor:none!important}.custom-cursor{position:fixed;top:0;left:0;width:32px;height:32px;pointer-events:none;z-index:9999;transform:translate(0);background-size:contain;background-repeat:no-repeat;background-position:center;transition:transform .1s ease,opacity .2s ease;will-change:transform}.custom-cursor.hovering{width:40px;height:40px}.custom-cursor.cursor-clicked{transform:scale(.9)}.custom-cursor.hidden{opacity:0}
