body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#000;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}#root{width:100vw;height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.start-page{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100vw;color:#fff;background:transparent;text-shadow:0 0 10px rgba(255,165,0,.7),0 0 20px rgba(255,165,0,.5)}.start-title{font-size:6rem;font-weight:700;color:#ff6400;margin-bottom:1rem;letter-spacing:.5rem;animation:start-glow 1.5s ease-in-out infinite alternate}.start-subtitle{font-size:1.5rem;color:#ff6400;margin-bottom:3rem}.start-button{font-family:Orbitron,sans-serif;font-size:1.5rem;font-weight:700;color:#000;background-color:#ff6400;border:2px solid #FF6400;border-radius:50px;padding:1rem 3rem;cursor:pointer;transition:all .3s ease;box-shadow:0 0 15px #ffa500cc}.start-button:hover{background-color:#000;color:orange;box-shadow:0 0 25px orange,0 0 5px #ffffff80}@keyframes start-glow{0%{text-shadow:0 0 5px #ffac4d,0 0 10px #ffac4d,0 0 15px #ff7700,0 0 20px #ff7700}to{text-shadow:0 0 10px #ffac4d,0 0 20px #ffac4d,0 0 30px #ff7700,0 0 40px #ff7700}}@media (max-width: 768px){.start-title{font-size:4rem;letter-spacing:.3rem;margin-bottom:.5rem}.start-subtitle{font-size:1.2rem;margin-bottom:2rem;padding:0 20px}.start-button{font-size:1.2rem;padding:.8rem 2.5rem}}@media (max-width: 480px){.start-title{font-size:3rem;letter-spacing:.2rem;margin-bottom:.5rem}.start-subtitle{font-size:1rem;margin-bottom:2rem;padding:0 15px;text-align:center}.start-button{font-size:1rem;padding:.7rem 2rem}}@media (max-width: 320px){.start-title{font-size:2.5rem;letter-spacing:.1rem}.start-subtitle{font-size:.9rem;padding:0 10px}.start-button{font-size:.9rem;padding:.6rem 1.5rem}}.map-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:radial-gradient(circle at center,#14141ecc,#000000fa 70%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:modalFadeIn .4s ease-out}@keyframes modalFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}}.map-modal{background:linear-gradient(145deg,#0a0a12,#1a1a24,#0f0f18);width:90%;max-width:1000px;height:80%;max-height:700px;border-radius:16px;border:1px solid rgba(255,100,0,.4);box-shadow:0 0 40px #ff640033,0 20px 80px #0009,inset 0 1px #ff640026;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .5s cubic-bezier(.16,1,.3,1);position:relative}.map-modal:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,100,0,.04) 50%,transparent 100%),radial-gradient(circle at 20% 20%,rgba(255,100,0,.06) 0%,transparent 30%),radial-gradient(circle at 80% 80%,rgba(255,140,0,.06) 0%,transparent 30%);pointer-events:none}@keyframes modalSlideIn{0%{transform:scale(.8) translateY(50px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.map-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:linear-gradient(90deg,#281400e6,#321900e6);border-bottom:1px solid rgba(255,100,0,.3);color:#ff6400;position:relative;overflow:hidden}.map-modal-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,#FF6400 50%,transparent 100%);opacity:.7}.map-modal-header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,100,0,.15),transparent);animation:headerSweep 3s infinite ease-in-out}@keyframes headerSweep{0%{left:-100%}to{left:100%}}.map-modal-header h3{margin:0;font-size:1.3em;font-weight:300;text-shadow:0 0 15px rgba(255,100,0,.8);letter-spacing:2px;text-transform:uppercase;z-index:1;position:relative;font-family:Courier New,monospace}.close-button{background:#281400cc;border:1px solid rgba(255,100,0,.6);color:#ff6400;font-size:18px;font-weight:300;cursor:pointer;padding:8px;border-radius:4px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative;z-index:1;box-shadow:0 0 20px #ff64004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.close-button:hover{background:#ff64004d;color:#fff;transform:scale(1.05);box-shadow:0 0 30px #ff640080;border-color:#ff6400}.map-modal-content{display:flex;flex:1;overflow:hidden}.map-container{flex:1;position:relative;background:#0a0a12;border:1px solid rgba(255,100,0,.25);border-radius:0 0 0 15px;overflow:hidden}.map-container:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0px,rgba(255,100,0,.025) 1px,transparent 2px,transparent 50px),repeating-linear-gradient(0deg,transparent 0px,rgba(255,100,0,.025) 1px,transparent 2px,transparent 50px);pointer-events:none;z-index:1}.memories-section{width:320px;background:linear-gradient(180deg,#0f0f18,#0a0a12);border-left:1px solid rgba(255,100,0,.35);display:flex;flex-direction:column;position:relative}.memories-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,100,0,.04) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(255,140,0,.04) 0%,transparent 50%);pointer-events:none}.memories-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,100,0,.25);background:linear-gradient(90deg,#3c19004d,#280f004d);position:relative;z-index:1}.memories-header h4{margin:0;color:#ff6400;font-size:1.1em;font-weight:300;text-shadow:0 0 10px rgba(255,100,0,.5);letter-spacing:1px;text-transform:uppercase;font-family:Courier New,monospace}.add-memory-btn{background:#3c190099;color:#ff6400;border:1px solid rgba(255,100,0,.5);padding:8px 14px;border-radius:4px;cursor:pointer;font-size:.85em;font-weight:300;transition:all .3s ease;box-shadow:0 4px 20px #ff640040;text-transform:uppercase;letter-spacing:1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-family:Courier New,monospace}.add-memory-btn:hover{transform:translateY(-1px);background:#ff640026;box-shadow:0 8px 30px #ff640066;border-color:#ff6400;color:#fff}.add-memory-form{padding:20px;border-bottom:1px solid rgba(255,100,0,.2);background:linear-gradient(180deg,#3c19001a,#280f001a);position:relative;z-index:1}.memory-input{width:100%;padding:10px 12px;border:1px solid rgba(255,100,0,.35);border-radius:4px;margin-bottom:12px;font-size:.85em;background:#280f0080;color:#ff6400;transition:all .3s ease;font-family:Courier New,monospace}.memory-input:focus{outline:none;border-color:#ff6400;box-shadow:0 0 15px #ff64004d;background:#3c1900b3;color:#fff}.memory-input::placeholder{color:#ff640099}.memory-textarea{width:100%;padding:10px 12px;border:1px solid rgba(255,100,0,.35);border-radius:4px;margin-bottom:12px;height:80px;resize:vertical;font-size:.85em;font-family:Courier New,monospace;background:#280f0080;color:#ff6400;transition:all .3s ease}.memory-textarea:focus{outline:none;border-color:#ff6400;box-shadow:0 0 15px #ff64004d;background:#3c1900b3;color:#fff}.memory-textarea::placeholder{color:#ff640099}.photo-upload{margin-bottom:10px}.photo-input{display:none}.photo-label{display:inline-block;padding:8px 16px;background:#3c190099;color:#ff6400;border:1px solid rgba(255,100,0,.5);border-radius:4px;cursor:pointer;font-size:.8em;font-weight:300;transition:all .3s ease;box-shadow:0 4px 15px #ff640040;text-transform:uppercase;letter-spacing:1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-family:Courier New,monospace}.photo-label:hover{background:#ff640026;transform:translateY(-1px);box-shadow:0 8px 25px #ff640066;border-color:#ff6400;color:#fff}.save-memory-btn{width:100%;background:#3c1900cc;color:#ff6400;border:1px solid rgba(255,100,0,.6);padding:10px;border-radius:4px;cursor:pointer;font-weight:300;transition:all .3s ease;box-shadow:0 4px 20px #ff640059;text-transform:uppercase;letter-spacing:1px;font-size:.85em;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-family:Courier New,monospace}.save-memory-btn:hover{background:#ff640040;transform:translateY(-1px);box-shadow:0 8px 30px #ff640080;border-color:#ff6400;color:#fff}.memories-list{flex:1;overflow-y:auto;padding:20px;position:relative;z-index:1}.memories-list::-webkit-scrollbar{width:6px}.memories-list::-webkit-scrollbar-track{background:#ff64000f;border-radius:3px}.memories-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#ff6400b3,#ff8c00b3);border-radius:3px}.memories-list::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#ff6400e6,#ff8c00e6)}.memory-card{margin-bottom:20px;padding:14px;background:linear-gradient(135deg,#3c190033,#280f0033);border:1px solid rgba(255,100,0,.15);border-radius:6px;transition:all .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.memory-card:hover{transform:translateY(-1px);box-shadow:0 8px 30px #ff640033;border-color:#ff640059}.memory-photo{position:relative;display:flex;align-items:flex-start;gap:12px}.memory-photo img{width:80px;height:80px;object-fit:cover;border-radius:50%;border:3px solid #fff;box-shadow:0 4px 8px #0000001a}.speech-bubble{position:relative;background:linear-gradient(135deg,#280f00b3,#3c1900e6);padding:12px 16px;border-radius:8px;box-shadow:0 4px 25px #ff640026;max-width:180px;border:1px solid rgba(255,100,0,.25);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px)}.speech-bubble:before{content:"";position:absolute;left:-8px;top:20px;width:0;height:0;border-top:8px solid transparent;border-right:8px solid rgba(60,25,0,.9);border-bottom:8px solid transparent;filter:drop-shadow(0 0 8px rgba(255,100,0,.25))}.memory-content h5{margin:0 0 8px;color:#ff6400;font-size:.9em;font-weight:300;text-shadow:0 0 8px rgba(255,100,0,.4);font-family:Courier New,monospace;letter-spacing:.5px}.memory-content p{margin:0 0 8px;color:#fffc;font-size:.8em;line-height:1.4}.memory-date{color:#ff6400b3;font-size:.7em;text-shadow:0 0 5px rgba(255,100,0,.3);font-family:Courier New,monospace}.memory-text-only{margin-left:20px}.speech-bubble-text{background:linear-gradient(135deg,#ff6400d9,#ff8c00d9);color:#000;padding:12px 16px;border-radius:8px;position:relative;max-width:220px;box-shadow:0 4px 25px #ff640066;border:1px solid rgba(255,100,0,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.speech-bubble-text:before{content:"";position:absolute;left:-8px;top:20px;width:0;height:0;border-top:8px solid transparent;border-right:8px solid rgba(255,100,0,.85);border-bottom:8px solid transparent;filter:drop-shadow(0 0 10px rgba(255,100,0,.5))}.speech-bubble-text h5{margin:0 0 8px;color:#000;font-size:.9em;font-weight:500;text-shadow:0 0 3px rgba(0,0,0,.3);font-family:Courier New,monospace;letter-spacing:.5px}.speech-bubble-text p{margin:0 0 8px;color:#000000e6;font-size:.8em;line-height:1.4}.speech-bubble-text .memory-date{color:#000000b3;font-size:.7em;font-family:Courier New,monospace}@media (max-width: 1024px){.map-modal{width:95%;height:85%;max-width:900px}.memories-section{width:280px}.map-modal-header h3{font-size:1.1em}.close-button{width:32px;height:32px;font-size:16px}}@media (max-width: 768px){.map-modal{width:98%;height:90%;max-width:none;border-radius:12px}.map-modal-content{flex-direction:column}.map-container{height:45%;min-height:250px;border-radius:0}.memories-section{width:100%;height:55%;border-left:none;border-top:1px solid rgba(255,100,0,.35)}.map-modal-header{padding:16px 20px}.map-modal-header h3{font-size:1em;letter-spacing:1px}.memories-header,.add-memory-form,.memories-list{padding:16px}.speech-bubble{max-width:200px}.speech-bubble-text{max-width:240px}}@media (max-width: 480px){.map-modal{width:100%;height:100%;border-radius:0;max-height:none}.map-modal-overlay{padding:0}.map-container{height:40%;min-height:200px}.memories-section{height:60%}.map-modal-header{padding:12px 16px}.map-modal-header h3{font-size:.9em;letter-spacing:.5px}.close-button{width:28px;height:28px;font-size:14px}.memories-header{padding:12px 16px}.memories-header h4{font-size:1em}.add-memory-btn{font-size:.8em;padding:6px 10px}.add-memory-form{padding:12px 16px}.memory-input,.memory-textarea{font-size:.8em;padding:8px 10px}.memory-textarea{height:60px}.save-memory-btn{font-size:.8em;padding:8px}.memories-list{padding:12px 16px}.memory-card{padding:10px;margin-bottom:16px}.memory-photo{flex-direction:column;align-items:center;gap:8px}.memory-photo img{width:60px;height:60px}.speech-bubble{max-width:100%;width:100%;margin-top:8px}.speech-bubble:before{left:50%;top:-8px;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid rgba(60,25,0,.9);border-top:none}.speech-bubble-text{max-width:100%;width:100%}.memory-text-only{margin-left:0}.speech-bubble-text:before{display:none}.memory-content h5,.speech-bubble-text h5{font-size:.85em}.memory-content p,.speech-bubble-text p{font-size:.75em}.memory-date{font-size:.65em}}@media (max-width: 320px){.map-modal-header h3{font-size:.8em}.close-button{width:24px;height:24px;font-size:12px}.memory-input,.memory-textarea{font-size:.75em}.memory-textarea{height:50px}.add-memory-btn,.save-memory-btn{font-size:.75em}}@media (hover: none) and (pointer: coarse){.close-button,.add-memory-btn,.save-memory-btn,.photo-label{min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.memory-input,.memory-textarea{min-height:44px;-webkit-appearance:none;border-radius:8px}.memory-input:focus,.memory-textarea:focus{transform:scale(1.02);transition:transform .2s ease}}.loading-message{text-align:center;color:#ff6400b3;font-family:Courier New,monospace;font-size:.9em;padding:20px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}@media (max-width: 768px){.memories-list::-webkit-scrollbar{width:4px}.memories-list::-webkit-scrollbar-track{background:#ff64000a}.memories-list::-webkit-scrollbar-thumb{background:#ff640080;border-radius:2px}}.globe-ui-panel{position:absolute;top:20px;left:20px;background:#280f00e6;border:1px solid rgba(255,100,0,.5);border-radius:8px;padding:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #ff64004d;z-index:100}.globe-controls{display:flex;flex-direction:column;gap:12px}.globe-control-section{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.globe-button{background:#3c1900cc;color:#ff6400;border:1px solid rgba(255,100,0,.6);padding:8px 12px;border-radius:4px;cursor:pointer;font-size:.85em;font-weight:300;transition:all .3s ease;box-shadow:0 4px 15px #ff640040;text-transform:uppercase;letter-spacing:1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-family:Courier New,monospace;min-height:36px;display:flex;align-items:center;justify-content:center}.globe-button:hover{background:#ff640026;transform:translateY(-1px);box-shadow:0 8px 25px #ff640066;border-color:#ff6400;color:#fff}.globe-input{background:#280f00b3;color:#ff6400;border:1px solid rgba(255,100,0,.5);padding:6px 8px;border-radius:4px;font-size:.8em;font-family:Courier New,monospace;width:80px}.globe-input:focus{outline:none;border-color:#ff6400;box-shadow:0 0 10px #ff64004d;background:#3c1900cc;color:#fff}.globe-radio-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.globe-radio-label{display:flex;align-items:center;gap:6px;cursor:pointer;color:#ff6400;font-size:.8em;font-family:Courier New,monospace;text-transform:uppercase;letter-spacing:.5px}.globe-radio{accent-color:#FF6400}.globe-fieldset{border:1px solid #FF6400;border-radius:6px;padding:8px;margin:0;background:#3c19004d}.globe-legend{padding:0 6px;font-size:12px;color:#ff6400;font-family:Courier New,monospace;text-transform:uppercase}.globe-filter-group{display:flex;flex-direction:column;gap:4px}@media (max-width: 768px){.globe-ui-panel{top:10px;left:10px;right:10px;padding:12px;position:absolute;width:auto}.globe-control-section{flex-direction:column;align-items:stretch;gap:8px}.globe-radio-group{justify-content:space-between}.globe-button{font-size:.8em;padding:6px 10px;min-height:40px}.globe-input{width:100%;min-height:40px;font-size:.85em}.globe-radio-label{font-size:.75em}}@media (max-width: 480px){.globe-ui-panel{top:5px;left:5px;right:5px;padding:10px}.globe-controls{gap:8px}.globe-control-section{gap:6px}.globe-button{font-size:.75em;padding:5px 8px;min-height:44px}.globe-input{min-height:44px;font-size:.8em}.globe-radio-group{flex-direction:column;align-items:stretch;gap:6px}.globe-radio-label{font-size:.7em;padding:8px;border:1px solid rgba(255,100,0,.3);border-radius:4px;background:#3c190033;justify-content:center}.globe-fieldset{padding:6px}.globe-legend{font-size:10px}}
