.view-container{height:100%;width:100%;position:relative}.map-actions{position:absolute;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-end;z-index:10}.btn-locate{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-main);box-shadow:var(--shadow-md);transition:all .2s}.btn-locate:hover{transform:scale(1.05)}.btn-checkin{background:var(--primary);color:#fff;border:none;padding:1rem 1.5rem;border-radius:2rem;font-weight:700;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;box-shadow:0 10px 25px -5px #6366f180,0 8px 10px -6px #6366f14d;transition:all .2s}.btn-checkin:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 12px 28px -5px #6366f199,0 8px 10px -6px #6366f14d}.btn-checkin:active{transform:translateY(0)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-content{width:100%;max-width:500px;background:var(--bg-color);padding:2rem;border-radius:1rem;max-height:90vh;overflow-y:auto}.modal-content h2{margin-bottom:1.5rem}.timeline-view{padding:1.5rem 1.5rem 5rem;max-width:800px;margin:0 auto;min-height:100vh}.timeline-header{margin-bottom:2rem;text-align:center}.timeline-group{margin-bottom:3rem;position:relative}.timeline-date-badge{display:inline-block;background:var(--primary);color:#fff;padding:.5rem 1rem;border-radius:2rem;font-weight:700;font-size:.875rem;margin-bottom:1.5rem;box-shadow:var(--shadow-md);position:sticky;top:1rem;z-index:10}.timeline-items{border-left:2px solid var(--glass-border);margin-left:1rem;padding-left:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.timeline-card{position:relative;transition:transform .2s;overflow:hidden;padding:0}.timeline-card:hover{transform:translateY(-2px)}.timeline-card:before{content:"";position:absolute;left:-1.85rem;top:1.25rem;width:.75rem;height:.75rem;background:var(--primary);border-radius:50%;box-shadow:0 0 0 4px var(--bg-color)}.card-content{padding:1.25rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.time-label{font-size:.875rem;color:var(--text-muted);font-family:monospace;font-weight:600}.place-tag{display:inline-flex;align-items:center;gap:.25rem;background:#6366f11a;color:var(--primary);padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;margin-bottom:1rem}.memo-text{font-size:1rem;line-height:1.5;color:var(--text-main);white-space:pre-wrap;margin-bottom:1rem}.checkin-photo{width:100%;max-height:300px;object-fit:cover;border-bottom:1px solid var(--glass-border);background-color:#f1f5f9}:root{--primary: #6366f1;--primary-hover: #4f46e5;--bg-color: #f8fafc;--text-main: #0f172a;--text-muted: #64748b;--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(255, 255, 255, .5);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}@media(prefers-color-scheme:dark){:root{--bg-color: #0f172a;--text-main: #f8fafc;--text-muted: #94a3b8;--glass-bg: rgba(30, 41, 59, .85);--glass-border: rgba(255, 255, 255, .1)}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh}h1{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:2rem}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:1rem;box-shadow:var(--shadow-lg)}.btn-primary{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.input-group{margin-bottom:1.25rem}.input-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--text-muted)}.input-group input{width:100%;padding:.75rem 1rem;border-radius:.5rem;border:1px solid var(--glass-border);background:transparent;color:var(--text-main);font-family:inherit;font-size:1rem;transition:border-color .2s}.input-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #6366f133}.error-message{padding:.75rem;background-color:#ef44441a;color:#ef4444;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(circle at top left,rgba(99,102,241,.15),transparent 40%),radial-gradient(circle at bottom right,rgba(236,72,153,.1),transparent 40%)}.login-card{width:100%;max-width:400px;padding:2.5rem 2rem;text-align:center}.login-form{text-align:left}.auth-btn{width:100%;margin-top:1rem}.toggle-auth-btn{background:transparent;border:none;color:var(--primary);font-size:.875rem;margin-top:1.5rem;cursor:pointer;text-decoration:underline;text-underline-offset:4px}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{flex:1;overflow-y:auto;position:relative}.bottom-nav{display:flex;justify-content:space-around;align-items:center;padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--glass-border)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;color:var(--text-muted);text-decoration:none;font-size:.75rem;font-weight:500;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s ease}.nav-item.active{color:var(--primary)}.nav-item:hover{background:#6366f11a;color:var(--primary)}.nav-icon{width:1.5rem;height:1.5rem}.logout-btn{color:#ef4444}.logout-btn:hover{background:#ef44441a;color:#ef4444}.loading-screen{height:100vh;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--text-muted)}
