@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&display=swap";:root{--bg-dark:#0f172a;--bg-darker:#020617;--glass-bg:#1e293bb3;--glass-border:#ffffff1a;--text-main:#f8fafc;--text-muted:#94a3b8;--accent:#3b82f6;--map-default:#334155;--map-hover:#475569}*{box-sizing:border-box;margin:0;padding:0}body{background:radial-gradient(circle at 50% -20%, var(--bg-dark) 0%, var(--bg-darker) 100%);color:var(--text-main);flex-direction:column;min-height:100vh;font-family:Outfit,sans-serif;display:flex;overflow-x:hidden}.app-container{flex-direction:column;align-items:center;width:100%;max-width:1200px;min-height:100vh;margin:0 auto;padding:2rem;display:flex}header{text-align:center;margin-bottom:2rem;animation:.8s ease-out forwards fadeInDown}h1{background:linear-gradient(135deg,#60a5fa,#a78bfa,#f472b6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:800}.subtitle{color:var(--text-muted);font-size:1.1rem;font-weight:300}.main-content{flex-wrap:wrap;justify-content:center;gap:2rem;width:100%;display:flex}.map-container{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);border-radius:24px;flex:1;justify-content:center;align-items:center;min-width:320px;max-width:800px;padding:1rem;animation:1s ease-out forwards fadeInUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.stats-container{flex-direction:column;gap:1.5rem;width:320px;display:flex}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;animation:.8s ease-out forwards fadeInRight;box-shadow:0 10px 15px -3px #0000001a}.glass-card h2{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.2rem;display:flex}.stat-value{margin-bottom:.2rem;font-size:3.5rem;font-weight:800}.stat-label{color:var(--text-muted);font-size:.9rem}.progress-bar-bg{background:#ffffff1a;border-radius:4px;width:100%;height:8px;margin-top:1rem;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#60a5fa,#a78bfa);border-radius:4px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.recent-visits{flex-direction:column;gap:.8rem;max-height:300px;display:flex;overflow-y:auto}.recent-visits::-webkit-scrollbar{width:6px}.recent-visits::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.visit-item{background:#ffffff08;border-radius:12px;align-items:center;gap:1rem;padding:.8rem;transition:transform .2s,background .2s;display:flex}.visit-item:hover{background:#ffffff14;transform:translate(5px)}.color-dot{border-radius:50%;width:16px;height:16px;box-shadow:0 0 10px}.visit-name{font-size:1rem;font-weight:600}.geography{cursor:pointer;transition:all .4s cubic-bezier(.25,1,.5,1)}.geography:hover,.geography:focus{filter:brightness(1.2)drop-shadow(0 0 8px #ffffff4d);outline:none}.map-tooltip{pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;z-index:100;white-space:nowrap;background:#0f172ae6;border:1px solid #fff3;border-radius:8px;margin-top:-10px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;position:fixed;transform:translate(-50%,-100%);box-shadow:0 4px 6px #0000004d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (width<=900px){.main-content{flex-direction:column}.stats-container{flex-direction:row;width:100%}.glass-card{flex:1}}@media (width<=600px){.stats-container{flex-direction:column}h1{font-size:2.2rem}.app-container{padding:1rem}}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#020617cc;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s ease-out forwards fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{flex-direction:column;width:90%;max-width:800px;height:90vh;max-height:800px;animation:.3s cubic-bezier(.175,.885,.32,1.275) forwards scaleUp;display:flex;position:relative}.modal-close{color:#fff;cursor:pointer;z-index:10;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:#fff3;transform:scale(1.1)}.modal-header{text-align:center;margin-bottom:1rem;padding-top:1rem}.modal-header h2{background:linear-gradient(135deg,#a78bfa,#f472b6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.2rem;font-size:2rem;font-weight:800}.modal-body{background:#0003;border-radius:12px;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.pin-toggle-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:20px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem 1rem;font-family:inherit;font-weight:600;transition:all .2s;display:inline-flex}.pin-toggle-btn:hover{background:#fff3}.pin-toggle-btn.active{color:#0f172a;background:#f472b6;border-color:#f472b6}.pulse-circle{animation:1.5s infinite pulse}@keyframes pulse{0%{r:5;opacity:1}to{r:15;opacity:0}}.marker-form input:focus{outline:2px solid #3b82f6}
