:root{--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--gold: #d4af37;--ink: #0f172a;--border: #e2e8f0;--border-2: #cbd5e1;--green: #10b981;--red: #ef4444;--amber: #f59e0b;--blue: #3b82f6;--grad: linear-gradient(135deg, #3b82f6 0%, #10b981 50%, #d4af37 100%);--font-d: "Oswald", "Noto Sans JP", sans-serif;--font-b: "Inter", "Noto Sans JP", sans-serif;--xs: 12px;--sm: 14px;--base: 16px;--md: 18px;--lg: 24px;--xl: 36px;--shadow-sm: 0 4px 12px rgba(15, 23, 42, .05);--shadow: 0 12px 32px rgba(15, 23, 42, .08);--shadow-lg: 0 24px 48px rgba(15, 23, 42, .12);--transition: .3s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s ease;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-b);font-size:var(--base);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-feature-settings:"palt";line-height:1.6;overflow:hidden}#root{height:100%}a{color:inherit}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg);gap:16px}.loading-logo{font-family:var(--font-d);font-size:40px;font-weight:800;letter-spacing:.1em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-message{font-size:var(--sm);color:var(--text-3);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.access-denied-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg);padding:24px}.access-denied-card{text-align:center;background:var(--surface);border-radius:var(--radius-xl);padding:64px 48px;box-shadow:var(--shadow-lg);max-width:480px;width:100%}.access-denied-icon{font-size:64px;margin-bottom:24px}.access-denied-title{font-family:var(--font-d);font-size:var(--xl);font-weight:800;letter-spacing:.1em;color:var(--red);margin-bottom:16px}.access-denied-text{font-size:var(--sm);color:var(--text-2);line-height:1.8}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border:none;border-radius:var(--radius-sm);font-family:var(--font-d);font-size:var(--sm);font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all var(--transition);text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--ink);color:#fff}.btn-primary:hover:not(:disabled){background:#1e293b;box-shadow:var(--shadow);transform:translateY(-2px)}.btn-secondary{background:var(--surface);color:var(--ink);border:1.5px solid var(--border-2);box-shadow:none}.btn-secondary:hover:not(:disabled){border-color:var(--ink);background:var(--surface-2)}.man02-app{height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.man02-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(226,232,240,.5);z-index:100;position:relative;flex-shrink:0}.man02-header-left{display:flex;align-items:baseline;gap:8px}.man02-logo{font-family:var(--font-d);font-size:20px;font-weight:800;letter-spacing:.1em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.man02-logo-sub{font-family:var(--font-d);font-size:12px;font-weight:600;letter-spacing:.15em;color:var(--gold)}.man02-header-right{display:flex;align-items:center;gap:12px}.man02-current-time{font-family:SF Mono,Fira Code,monospace;font-size:var(--sm);font-weight:500;color:var(--text-2);letter-spacing:.02em}.man02-user-chip-container{position:fixed;bottom:24px;left:24px;z-index:90;width:auto}.man02-user-chip{display:flex;align-items:center;gap:14px;padding:10px 20px 10px 10px;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(226,232,240,.8);border-radius:99px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px #0f172a14;text-align:left;outline:none}.man02-user-chip:hover{box-shadow:0 12px 32px #0f172a1f;transform:translateY(-2px);border-color:var(--gold)}.man02-user-chip-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(to top right,#3b82f6,#10b981);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.5);box-shadow:inset 0 2px 4px #0000001a}.man02-user-chip-avatar img{width:100%;height:100%;object-fit:cover}.man02-user-chip-info{display:flex;flex-direction:column;align-items:flex-start;overflow:hidden;padding-right:8px;flex:1}.man02-user-chip-name-row{display:flex;align-items:center;gap:6px;width:100%}.man02-user-chip-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.man02-user-chip-subtitle{font-size:11px;text-transform:uppercase;font-weight:600;letter-spacing:.05em;margin-top:2px;color:var(--text-3)}.man02-user-chip-popup{position:absolute;bottom:calc(100% + 12px);left:0;background:#fffffffa;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:20px;box-shadow:0 12px 48px #0f172a26;border:1px solid rgba(226,232,240,.8);padding:16px;min-width:200px;animation:chipPopup .2s cubic-bezier(.16,1,.3,1)}@keyframes chipPopup{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.man02-user-chip-popup-header{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.man02-user-chip-popup-name{font-size:var(--base);font-weight:700;color:var(--text);text-align:center;margin-bottom:2px}.man02-user-chip-popup-email{font-size:var(--xs);color:var(--text-3);text-align:center}.man02-user-chip-action{display:flex;align-items:center;gap:12px;width:100%;padding:12px;border:none;background:transparent;border-radius:12px;cursor:pointer;font-family:var(--font-b);font-size:var(--sm);font-weight:600;color:var(--text-2);transition:background var(--transition-fast)}.man02-user-chip-action:hover{background:var(--surface-2)}.man02-user-chip-action.danger{color:var(--red)}.man02-user-chip-action.danger:hover{background:#fef2f2}.man02-map-container{flex:1;position:relative;overflow:hidden}.man02-map{width:100%;height:100%}.man02-map-container{background:var(--surface-2)}.man02-no-data-full{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:var(--surface-2);padding:48px;z-index:10}.man02-no-data-full svg{color:var(--text-3);margin-bottom:16px}.man02-no-data-full h2{font-family:var(--font-d);font-size:var(--lg);font-weight:700;letter-spacing:.05em;margin-bottom:8px;color:var(--text)}.man02-no-data-full p{font-size:var(--sm);color:var(--text-2)}.man02-recenter-btn{position:absolute;bottom:200px;right:16px;width:44px;height:44px;border-radius:50%;background:var(--surface);border:none;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--blue);transition:all var(--transition-fast);z-index:50}.man02-recenter-btn:hover{background:var(--blue);color:#fff;transform:scale(1.1)}.man02-info-panel{position:absolute;bottom:0;left:0;right:0;background:#fffffff2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:0 -8px 32px #0f172a1a;z-index:80;transition:all var(--transition);max-height:60vh;overflow-y:auto}.man02-info-panel.collapsed{max-height:40px}.man02-info-toggle{width:100%;padding:12px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.man02-info-handle{width:40px;height:4px;border-radius:2px;background:var(--border-2)}.man02-info-content{padding:0 24px 24px;display:flex;flex-direction:column;gap:20px}.man02-info-section{padding-bottom:16px;border-bottom:1px solid var(--border)}.man02-info-section:last-child{border-bottom:none;padding-bottom:0}.man02-info-section-title{display:flex;align-items:center;gap:8px;font-family:var(--font-d);font-size:var(--xs);font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px}.man02-info-address{font-size:var(--base);font-weight:600;color:var(--text);line-height:1.5}.man02-info-coords{font-size:var(--xs);color:var(--text-3);font-family:SF Mono,Fira Code,monospace;margin-top:4px}.man02-info-battery{width:100%;height:8px;background:var(--surface-2);border-radius:4px;overflow:hidden;margin-bottom:6px}.man02-battery-bar{height:100%;border-radius:4px;transition:width .5s ease}.man02-info-battery-text{font-size:var(--md);font-weight:800;font-family:var(--font-d);letter-spacing:.05em}.man02-info-time{font-size:var(--sm);color:var(--text-2);font-weight:500}@media(min-width:768px){.man02-header{padding:14px 32px}.man02-logo{font-size:24px}.man02-logo-sub{font-size:13px}.man02-info-panel{left:auto;right:24px;bottom:24px;width:380px;border-radius:var(--radius-xl);max-height:calc(100vh - 120px);box-shadow:var(--shadow-lg)}.man02-info-panel.collapsed{max-height:40px}.man02-recenter-btn{bottom:32px;right:420px}.man02-no-data{padding:64px}}@media(min-width:1024px){.man02-header{padding:14px 48px}.man02-info-panel{width:420px;right:32px;bottom:32px}.man02-recenter-btn{right:472px;bottom:40px}}@media(max-width:480px){.man02-header{padding:10px 16px}.man02-logo{font-size:18px}.man02-logo-sub{font-size:10px}.man02-info-content{padding:0 16px 16px}.man02-info-address{font-size:var(--sm)}.man02-no-data{padding:32px 24px;width:calc(100% - 48px)}.man02-no-data h2{font-size:var(--md)}.man02-no-data p{font-size:var(--xs)}.man02-recenter-btn{bottom:180px;right:12px;width:40px;height:40px}.access-denied-card{padding:40px 24px}.access-denied-icon{font-size:48px}.access-denied-title{font-size:28px}}.popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;pointer-events:auto}.popup-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.popup-container{position:relative;background:#fffffff2;border-radius:20px;padding:24px;width:90%;max-width:400px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;display:flex;flex-direction:column;gap:16px;z-index:10}@media(prefers-color-scheme:dark){.popup-container{background:#1e1e1ef2;color:#f3f4f6;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a}}:global(.dark) .popup-container{background:#1e1e1ef2;color:#f3f4f6;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a}.popup-header{display:flex;flex-direction:column;align-items:center;gap:12px}.popup-icon{stroke-width:1.5}.popup-title{font-size:1.25rem;font-weight:700;text-align:center;margin:0;color:inherit}.popup-body{text-align:center}.popup-message{font-size:1rem;line-height:1.5;margin:0;color:#4b5563}@media(prefers-color-scheme:dark){.popup-message{color:#d1d5db}}:global(.dark) .popup-message{color:#d1d5db}.popup-input-container{margin-top:8px}.popup-input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid #d1d5db;background:#f9fafb;font-size:1rem;outline:none;transition:all .2s;box-sizing:border-box}.popup-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}@media(prefers-color-scheme:dark){.popup-input{border-color:#4b5563;background:#374151;color:#f3f4f6}}:global(.dark) .popup-input{border-color:#4b5563;background:#374151;color:#f3f4f6}.popup-actions{display:flex;gap:12px;margin-top:8px;justify-content:center;width:100%}.popup-button{flex:1;padding:12px 20px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;outline:none;display:flex;align-items:center;justify-content:center}.popup-button:active{transform:scale(.97)}.popup-button-cancel{background:#f3f4f6;color:#374151}.popup-button-cancel:hover{background:#e5e7eb}@media(prefers-color-scheme:dark){.popup-button-cancel{background:#374151;color:#f3f4f6}.popup-button-cancel:hover{background:#4b5563}}:global(.dark) .popup-button-cancel{background:#374151;color:#f3f4f6}:global(.dark) .popup-button-cancel:hover{background:#4b5563}.popup-button-confirm{background:linear-gradient(135deg,#6366f1,#3b82f6);color:#fff;box-shadow:0 4px 14px #3b82f663}.popup-button-confirm:hover{background:linear-gradient(135deg,#4f46e5,#2563eb);box-shadow:0 6px 20px #3b82f666}
