:root{--color-bg-sky:linear-gradient(135deg, #e0f2fe 0%, #bae6fd 100%);--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-text-dark:#1e1b4b;--color-text-muted:#4f46e5;--color-card-bg:#ffffffd9;--color-glass-border:#fff9;--color-shadow:#1e1b4b14;--color-shadow-hover:#1e1b4b26;--font-playful:"Fredoka", cursive, sans-serif;--font-readable:"Quicksand", sans-serif;--transition-bouncy:all .4s cubic-bezier(.175, .885, .32, 1.275);--transition-smooth:all .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-readable);color:var(--color-text-dark);background:var(--color-bg-sky);-webkit-user-select:none;user-select:none;min-height:100vh;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000000d;border-radius:999px}::-webkit-scrollbar-thumb{background:#4f46e533;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#4f46e566}#root{width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.app-container{width:100%;height:100%;display:flex;position:relative}.glass-panel{background:var(--color-card-bg);-webkit-backdrop-filter:blur(16px);border:2px solid var(--color-glass-border);box-shadow:0 10px 30px -10px var(--color-shadow);border-radius:24px}.sidebar{z-index:10;width:380px;height:calc(100% - 32px);transition:var(--transition-bouncy);flex-direction:column;margin:16px;display:flex;position:absolute;top:0;left:0}.sidebar-header{text-align:center;padding:24px 20px 16px}.sidebar-title{font-family:var(--font-playful);color:#4f46e5;text-shadow:0 2px 4px #4f46e51a;justify-content:center;align-items:center;gap:8px;font-size:28px;font-weight:700;animation:4s ease-in-out infinite float-slow;display:flex}.sidebar-subtitle{color:#6366f1;margin-top:6px;font-size:14px;font-weight:600}.family-list-container{flex:1;padding:0 16px 16px;overflow-y:auto}.family-card{cursor:pointer;transition:var(--transition-bouncy);background:#fff;border:2px solid #0000;border-radius:18px;margin-bottom:12px;padding:16px;position:relative;overflow:hidden;box-shadow:0 4px 10px #00000005}.family-card:hover{background:#f8faff;transform:translateY(-4px)scale(1.02);box-shadow:0 8px 20px #4f46e51a}.family-card.active{border-color:var(--color-primary);background:#f0f3ff;box-shadow:0 8px 24px #4f46e526}.family-card-header{align-items:center;gap:12px;display:flex}.family-emoji{width:44px;height:44px;transition:var(--transition-smooth);background:#f1f3f9;border-radius:12px;justify-content:center;align-items:center;font-size:24px;display:flex}.family-card:hover .family-emoji{transform:rotate(10deg)scale(1.1)}.family-info{flex:1}.family-name{font-family:var(--font-playful);color:var(--color-text-dark);font-size:18px;font-weight:600}.family-location{color:#6b7280;align-items:center;gap:4px;margin-top:2px;font-size:13px;font-weight:500;display:flex}.family-details-collapsed{max-height:0;transition:max-height .3s;overflow:hidden}.family-details-expanded{border-top:1px dashed #4f46e533;max-height:200px;margin-top:14px;padding-top:12px;transition:max-height .3s}.members-badges{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.member-badge{color:var(--color-primary);background:#4f46e514;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:flex}.fly-button{background:var(--color-primary);color:#fff;font-family:var(--font-playful);cursor:pointer;width:100%;transition:var(--transition-bouncy);border:none;border-radius:12px;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:600;display:flex;box-shadow:0 4px 12px #4f46e533}.fly-button:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #4f46e54d}.fly-button:active{transform:translateY(1px)}.globe-container{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.controls-overlay{z-index:5;flex-direction:column;gap:10px;display:flex;position:absolute;top:20px;right:20px}.round-button{cursor:pointer;width:48px;height:48px;color:var(--color-text-dark);transition:var(--transition-bouncy);background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 12px #00000014}.round-button:hover{color:var(--color-primary);background:#f0f3ff;transform:scale(1.1)rotate(5deg);box-shadow:0 6px 16px #4f46e533}.passport-card{z-index:10;width:480px;max-width:calc(100vw - 420px);transition:var(--transition-bouncy);flex-direction:column;animation:.5s cubic-bezier(.175,.885,.32,1.275) slide-in-up;display:flex;position:absolute;bottom:24px;right:24px;overflow:hidden}.passport-header{color:#fff;background:radial-gradient(circle at 100% 0,#818cf8 0%,#4f46e5 100%);padding:20px 24px;position:relative;overflow:hidden}.passport-stamp{font-family:var(--font-playful);text-transform:uppercase;color:#ffffffe6;pointer-events:none;letter-spacing:1.5px;border:3px double #fff9;border-radius:8px;padding:4px 8px;font-size:11px;font-weight:800;position:absolute;top:10px;right:16px;transform:rotate(15deg)}.passport-close{color:#fff;cursor:pointer;width:28px;height:28px;transition:var(--transition-smooth);background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:20px;left:20px}.passport-close:hover{background:#fff6;transform:scale(1.1)}.passport-header-content{margin-top:10px}.passport-title{font-family:var(--font-playful);font-size:24px;font-weight:700}.passport-loc{opacity:.9;align-items:center;gap:4px;margin-top:2px;font-size:14px;font-weight:600;display:flex}.passport-body{background:#ffffffe6;flex-direction:column;gap:16px;max-height:420px;padding:20px 24px 24px;display:flex;overflow-y:auto}.section-title{font-family:var(--font-playful);color:#4f46e5;text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:6px;margin-bottom:6px;font-size:15px;font-weight:700;display:flex}.synopsis-text{color:#374151;background:#f8fafc;border-left:4px solid #818cf8;border-radius:14px;padding:12px;font-size:14px;line-height:1.5}.favorites-list{flex-direction:column;gap:8px;display:flex}.favorite-item{background:#fff;border:1px solid #4f46e514;border-radius:12px;align-items:center;gap:10px;padding:10px 14px;font-size:13.5px;font-weight:600;display:flex;box-shadow:0 2px 6px #00000003}.favorite-icon{background:#f5f3ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;display:flex}.roster-container{flex-direction:column;gap:8px;display:flex}.roster-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;display:grid}.roster-member-card{text-align:center;transition:var(--transition-bouncy);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;display:flex}.roster-member-card:hover{background:#dcfce7;transform:translateY(-3px)}.roster-avatar{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:24px;display:flex;box-shadow:0 2px 6px #0000000d}.roster-name{font-family:var(--font-playful);color:#166534;font-size:13px;font-weight:600}.action-hello-btn{color:#fff;font-family:var(--font-playful);cursor:pointer;transition:var(--transition-bouncy);background:#10b981;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:16px;font-weight:700;display:flex;box-shadow:0 4px 14px #10b9814d}.action-hello-btn:hover{background:#059669;transform:translateY(-3px)scale(1.02);box-shadow:0 6px 20px #10b98166}.action-hello-btn:active{transform:translateY(1px)}.sidebar-footer{text-align:center;color:#6366f1;letter-spacing:.5px;border-top:1px dashed #4f46e526;padding:16px;font-size:11px;font-weight:600}.custom-marker{cursor:pointer;transition:var(--transition-bouncy);flex-direction:column;align-items:center;display:flex;position:relative}.custom-marker:hover{transform:scale(1.2)}.marker-pin{border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;animation:2s infinite alternate bounce;display:flex;box-shadow:0 4px 10px #0000004d}.marker-label{color:#fff;font-family:var(--font-playful);white-space:nowrap;background:#1e1b4bd9;border-radius:8px;margin-top:6px;padding:3px 8px;font-size:10px;font-weight:700;box-shadow:0 2px 6px #0003}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}@keyframes float-slow{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-4px)rotate(1deg)}}@keyframes slide-in-up{0%{opacity:0;transform:translateY(100px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.welcome-card{z-index:10;flex-direction:column;gap:12px;width:420px;max-width:calc(100vw - 420px);padding:24px;animation:.5s cubic-bezier(.175,.885,.32,1.275) slide-in-up;display:flex;position:absolute;bottom:24px;right:24px}.welcome-title{font-family:var(--font-playful);color:var(--color-primary);align-items:center;gap:8px;font-size:22px;display:flex}.welcome-text{color:#4b5563;font-size:14px;line-height:1.5}.instruction-steps{flex-direction:column;gap:8px;margin-top:8px;display:flex}.instruction-step{color:#374151;align-items:center;gap:10px;font-size:13.5px;font-weight:600;display:flex}.step-num{color:var(--color-primary);background:#4f46e51a;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex}@media (width<=768px){body{overflow-y:auto}#root{flex-direction:column;height:auto;min-height:100vh}.app-container{flex-direction:column;height:auto}.sidebar{width:calc(100% - 32px);height:auto;margin:16px;position:relative}.globe-container{width:100%;height:450px;position:relative}.passport-card,.welcome-card{width:calc(100% - 32px);max-width:none;margin:0 16px 24px;animation:none;position:relative;bottom:0;right:0}.controls-overlay{top:480px}}
