:root{--bg: #EEF1F5;--panel: #FFFFFF;--panel-alt: #F4F6FA;--border: #D3DAE3;--border-soft: #E2E7EE;--ink: #0B1626;--ink-muted: #47556A;--ink-dim: #8895A8;--cyan: #0891B2;--cyan-dark: #0E7490;--cyan-soft: #E0F2F7;--success: #0D9488;--danger: #DC2626;--amber: #D97706;--font: "Inter", -apple-system, system-ui, "Noto Sans JP", sans-serif;--mono: "JetBrains Mono", "SF Mono", "Roboto Mono", ui-monospace, monospace;--panel-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 2px 8px rgba(11,22,38,.05);--input-shadow: inset 0 1px 2px rgba(11,22,38,.05);--btn-primary-bg: linear-gradient(180deg, var(--cyan), var(--cyan-dark));--btn-primary-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 2px 4px rgba(8,145,178,.3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--ink);height:100dvh;overflow:hidden;-webkit-text-size-adjust:100%}#app{height:100dvh;display:flex;flex-direction:column}.app{height:100%;display:flex;flex-direction:column}.header{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-alt) 100%);border-bottom:1px solid var(--border);box-shadow:inset 0 -1px #fffc;color:var(--ink);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:1000}.header-left{display:flex;align-items:center;gap:8px;position:relative;flex:1;min-width:0}.header h1{font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.3px;line-height:1}.header-sub{font-size:11px;color:var(--ink-muted);margin-top:3px;font-family:var(--mono);letter-spacing:0}.sync-status{font-size:11px;color:var(--ink-muted);font-family:var(--mono);flex:1;text-align:right;margin-right:8px}.hamburger-btn{width:42px;height:42px;border-radius:8px;border:1px solid var(--border);background:var(--panel);display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;box-shadow:0 1px #ffffffe6 inset,0 1px 2px #0b16260d;color:var(--ink);font-size:18px;line-height:1;flex-shrink:0}.hamburger-btn:active{background:var(--panel-alt)}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.menu-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--panel);border-radius:10px;box-shadow:0 8px 24px #0b162626;z-index:100;min-width:180px;border:1px solid var(--border);overflow:hidden}.menu-item{display:block;width:100%;padding:12px 16px;border:none;background:none;text-align:left;font-size:14px;font-weight:500;color:var(--ink);text-decoration:none;cursor:pointer;font-family:var(--font)}.menu-item:hover{background:var(--cyan-soft)}.menu-item:active{background:#d0eaf0}.menu-item+.menu-item{border-top:1px solid var(--border-soft)}.menu-item-child+.menu-item-child{border-top:none}.menu-section+.menu-item{border-top:1px solid var(--border-soft)}.menu-section-header{padding:8px 14px 4px;font-size:11px;font-weight:700;color:#6b7280;letter-spacing:1px;text-transform:uppercase;background:#f8fafc;border-top:1px solid var(--border-soft)}.menu-item-child{padding-left:28px}.reload-btn{width:42px;height:42px;border-radius:8px;border:1px solid var(--border);background:var(--panel);display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;box-shadow:0 1px #ffffffe6 inset,0 1px 2px #0b16260d;color:var(--ink);font-size:16px;flex-shrink:0}.reload-btn:active{background:var(--panel-alt)}.clock-panel{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px;flex-shrink:0;box-sizing:border-box}.clock-item{background:var(--panel);border-radius:10px;padding:8px 12px;border:1px solid var(--border);box-shadow:var(--panel-shadow);overflow:hidden;min-width:0;text-align:center}.clock-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-dim);font-weight:800}.clock-time{font-size:24px;font-weight:800;color:var(--ink);font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.5px;margin-top:2px}.map-wrapper{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;margin:0 10px 10px;border-radius:12px;border:1px solid var(--border);overflow:hidden;box-shadow:inset 0 1px 3px #0b16261a}.map-container{flex:1;min-height:0}.map-error{flex:1;display:flex;align-items:center;justify-content:center;color:var(--danger);font-size:14px;padding:16px}.map-controls{position:absolute;top:10px;right:10px;z-index:10;display:flex;flex-direction:column;gap:6px}.map-ctrl-btn{width:38px;height:38px;background:var(--panel);border:1px solid var(--border);border-radius:8px;color:var(--ink);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px #ffffffe6 inset,0 2px 4px #0b162626;transition:background .15s}.map-ctrl-btn:active{background:var(--panel-alt)}.stats-panel{position:absolute;bottom:calc(40px + env(safe-area-inset-bottom,0px));left:20px;z-index:10;background:linear-gradient(180deg,var(--panel),var(--panel-alt));border:1px solid var(--border);border-radius:10px;padding:10px 14px;min-width:240px;box-shadow:0 2px 8px #0b16261a;pointer-events:none}@media(max-width:600px){.stats-panel{bottom:calc(70px + env(safe-area-inset-bottom,0px));left:10px;padding:10px 14px;min-width:200px}}.gm-bundled-control{display:none!important}.stats-title{display:flex;align-items:center;gap:6px;margin-bottom:7px;font-size:11px;font-weight:800;color:var(--ink-muted);letter-spacing:1.5px;text-transform:uppercase}.stats-title:before{content:"";display:inline-block;width:6px;height:6px;border-radius:3px;background:var(--cyan);box-shadow:0 0 5px var(--cyan)}.stats-row{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0;font-size:14px;gap:16px}.stats-label{color:var(--ink-muted);font-size:13px;white-space:nowrap}.stats-value{color:var(--ink);font-weight:700;font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:right;font-size:14px}.stats-value-emph{color:var(--danger);font-weight:800}.center-message{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;font-size:15px;color:var(--ink-dim)}.center-message.error{color:var(--danger)}.login-link{color:var(--cyan);font-size:15px;text-decoration:none;padding:10px 24px;border:1px solid var(--cyan);border-radius:8px;font-weight:600}.login-link:active{background:var(--cyan-soft)}.retry-btn{background:none;border:1px solid var(--danger);color:var(--danger);padding:10px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.retry-btn:active{background:#fef2f2}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0b162673;z-index:2000}.settings-panel{position:fixed;top:40px;left:10px;right:10px;bottom:40px;z-index:2001;background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 60px #0b16264d;overflow:hidden;display:flex;flex-direction:column;max-width:400px;margin:0 auto}.settings-panel h2{background:linear-gradient(180deg,var(--panel),var(--panel-alt));padding:14px 18px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.3px;margin:0}.settings-close-btn{width:28px;height:28px;border-radius:7px;background:var(--panel);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-muted);padding:0;flex-shrink:0}.settings-close-btn:active{background:var(--panel-alt)}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.settings-body-loading{opacity:.55;pointer-events:none}.settings-loading-banner{font-size:12px;color:var(--cyan-dark, #0E7490);background:#0891b21a;border:1px solid rgba(8,145,178,.25);border-radius:6px;padding:8px 10px;text-align:center;font-weight:600;pointer-events:auto}.settings-label{display:block;font-size:10px;color:var(--ink-muted);font-weight:800;letter-spacing:1.5px;text-transform:uppercase}.settings-input{display:block;width:100%;height:44px;padding:0 12px;background:var(--panel);border:1px solid var(--border);border-radius:8px;color:var(--ink);font-size:16px;font-weight:600;font-family:var(--mono);outline:none;box-shadow:var(--input-shadow);transition:border-color .15s}.settings-input:focus{border-color:var(--cyan);box-shadow:0 0 0 2px #0891b226}.settings-actions{display:flex;gap:8px;justify-content:flex-end;padding:14px;border-top:1px solid var(--border-soft);background:var(--panel-alt)}.settings-btn{height:46px;padding:0 20px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .15s}.settings-btn-cancel{background:var(--panel);color:var(--ink);border:1px solid var(--border)}.settings-btn-cancel:active{background:var(--panel-alt)}.settings-btn-save{background:var(--btn-primary-bg);color:#fff;border:none;font-weight:800;letter-spacing:1px;padding:0 26px;box-shadow:var(--btn-primary-shadow)}.settings-btn-save:active{opacity:.9}.settings-section{margin-top:2px;padding-top:14px;border-top:1px solid var(--border-soft)}.settings-section-title{font-size:10px;font-weight:800;color:var(--cyan-dark);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px}.public-url-active{display:flex;flex-direction:column;gap:10px}.public-url-text{font-size:12px;font-family:var(--mono);color:var(--ink);word-break:break-all;line-height:1.4;background:var(--panel-alt);padding:10px 12px;border-radius:8px;border:1px solid var(--border-soft)}.public-url-actions{display:flex;gap:8px}.settings-btn-copy{height:42px;padding:0 16px;border-radius:8px;border:1px solid var(--border);background:var(--panel);font-size:14px;font-weight:700;color:var(--ink);cursor:pointer;font-family:var(--font)}.settings-btn-copy:active{background:var(--panel-alt)}.settings-btn-delete{height:42px;padding:0 16px;border-radius:8px;background:#fef2f2;color:var(--danger);border:1px solid rgba(220,38,38,.4);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font)}.settings-btn-delete:active{background:#fee2e2}.public-url-setup{display:flex;flex-direction:column;gap:10px}.public-url-custom{display:flex;gap:8px;align-items:flex-end}.public-url-custom .settings-input{flex:1}.public-url-custom .settings-btn-save{flex-shrink:0;height:44px;padding:0 14px}.qso-card{position:absolute;transform:translate(-50%,-100%) translateY(-16px);min-width:180px;border-radius:10px;padding:10px 14px;box-shadow:0 4px 16px #0b162626;pointer-events:auto;font-family:var(--font);z-index:10000}.qso-card-active{background:#fef3c7;border:1px solid #F59E0B;border-left:4px solid #D97706;box-shadow:0 6px 18px #f59e0b4d,0 2px 4px #0b16261a;animation:fadeInUp .5s ease-out,flashBorder 1.5s ease-in-out .5s infinite}.qso-card-past{background:var(--panel);border:1px solid var(--border);border-left:4px solid var(--cyan);box-shadow:0 2px 6px #0b16261f}.qso-card-call{font-size:18px;font-weight:800;color:var(--ink);font-family:var(--mono);letter-spacing:.3px}.qso-card-loc{font-size:11px;color:var(--ink-muted);margin-top:2px;display:flex;justify-content:space-between;align-items:baseline}.qso-card-time{font-family:var(--mono);font-size:10px;color:var(--ink-dim);margin-left:6px;white-space:nowrap}.qso-card-info{display:flex;gap:8px;align-items:center;margin-top:6px}.qso-card-dist{font-weight:800;color:var(--danger);font-size:13px;font-family:var(--mono);font-variant-numeric:tabular-nums}.qso-card-band{font-weight:800;color:#fff;font-size:11px;background:var(--cyan-dark);padding:2px 7px;border-radius:4px;font-family:var(--mono)}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,-100%) translateY(-6px) scale(.9)}to{opacity:1;transform:translate(-50%,-100%) translateY(-16px) scale(1)}}@keyframes flashBorder{0%,to{box-shadow:0 0 8px 2px #f59e0b33}50%{box-shadow:0 0 8px 2px #f59e0b99}}.grid-view-map{flex:1;min-height:0}
