:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--text-xs: clamp(.65rem, 1.8vw, .75rem);--text-sm: clamp(.78rem, 2vw, .875rem);--text-md: clamp(.9rem, 2.2vw, 1rem);--text-lg: clamp(1.05rem, 2.6vw, 1.125rem);--text-xl: clamp(1.2rem, 3.2vw, 1.35rem);--text-hero: clamp(1.45rem, 5vw, 1.9rem);--leading-tight: 1.28;--leading-snug: 1.45;--leading-body: 1.72;--leading-relaxed: 1.85;--bg: #0a0a0f;--bg-card: rgba(22, 24, 38, .94);--bg-veil: rgba(10, 12, 22, .65);--bg-hud-inner: rgba(14, 18, 36, .92);--accent: #4facfe;--accent-soft: rgba(79, 172, 254, .08);--accent-orange: #dd6500;--accent-orange-hover: #ff7700;--text: #f4f6fb;--text-muted: rgba(244, 246, 251, .72);--text-faint: rgba(244, 246, 251, .48);--ring: rgba(79, 172, 254, .28);--card-border: rgba(255, 255, 255, .09);--border-brand: rgba(79, 172, 254, .34);--divider: rgba(255, 255, 255, .07);--safe-top: env(safe-area-inset-top);--safe-bottom: env(safe-area-inset-bottom);--safe-left: env(safe-area-inset-left);--safe-right: env(safe-area-inset-right);--font-primary: "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-card: var(--radius-md);--shadow-card: 0 12px 40px rgba(0, 0, 0, .38);--shadow-hud-inset: inset 0 1px 0 rgba(255, 255, 255, .04);--glow-compass: 0 0 32px rgba(79, 172, 254, .07);--motion-fast: .16s ease;--motion-base: .26s ease;--transition-default: color var(--motion-base), background-color var(--motion-base), border-color var(--motion-base), box-shadow var(--motion-base);--surface-field: var(--bg-hud-inner)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;min-height:100%;-webkit-text-size-adjust:100%;-webkit-touch-callout:default;background-color:var(--bg);background-image:radial-gradient(ellipse 130% 90% at 50% -35%,rgba(45,75,120,.14) 0%,transparent 52%),radial-gradient(ellipse 80% 50% at 100% 100%,rgba(25,40,70,.1) 0%,transparent 45%),radial-gradient(ellipse 90% 55% at 50% 100%,color-mix(in srgb,var(--accent) 10%,transparent) 0%,transparent 55%);background-attachment:fixed}.bg-stars{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.bg-zodiac-chart{position:absolute;left:50%;top:46%;width:min(158vmin,1720px);height:min(158vmin,1720px);transform:translate(-50%,-50%);opacity:.32;pointer-events:none;overflow:visible;font-family:var(--font-primary)}@media (max-width: 480px){.bg-zodiac-chart{width:min(198vmin,1720px);height:min(198vmin,1720px);opacity:.26}}.bg-zodiac-ecliptic{fill:none;stroke:color-mix(in srgb,var(--accent) 45%,transparent);stroke-width:1.5;opacity:.5}.bg-zodiac-earth{fill:color-mix(in srgb,var(--accent) 28%,var(--bg-card));stroke:color-mix(in srgb,var(--text) 20%,transparent);stroke-width:.75}.bg-zodiac-sun{fill:color-mix(in srgb,var(--accent-orange) 65%,var(--accent));stroke:color-mix(in srgb,var(--text) 30%,transparent);stroke-width:.45}.bg-zodiac-equinox{fill:color-mix(in srgb,var(--text) 85%,transparent)}.bg-zodiac-caption{fill:color-mix(in srgb,var(--text-muted) 88%,var(--text));font-size:13px;font-weight:600;opacity:.48}.bg-zodiac-caption--sm{font-size:11px;opacity:.4}.bg-zodiac-line{fill:none;stroke:color-mix(in srgb,var(--text) 40%,var(--accent) 38%);stroke-width:1.05;stroke-linecap:round;stroke-linejoin:round;opacity:.58}.bg-zodiac-star{fill:color-mix(in srgb,var(--text) 75%,var(--accent) 25%);stroke:color-mix(in srgb,var(--accent) 22%,transparent);stroke-width:.35}.bg-zodiac-label{fill:color-mix(in srgb,var(--text-muted) 92%,var(--accent) 8%);font-size:12px;font-weight:500;text-anchor:middle;opacity:.68}@media (prefers-reduced-motion: reduce){.bg-zodiac-chart{opacity:.22}.bg-zodiac-core{filter:none}}.bg-planetarium-dome{position:absolute;top:-25%;right:-10%;bottom:35%;left:-10%;background:radial-gradient(ellipse 85% 70% at 50% 0%,color-mix(in srgb,var(--accent) 14%,transparent) 0%,color-mix(in srgb,var(--accent) 4%,transparent) 38%,transparent 72%);opacity:.55;filter:blur(28px);pointer-events:none}@media (max-width: 480px){.bg-planetarium-dome{opacity:.45;filter:blur(22px)}}.bg-planetarium-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 92% 88% at 50% 45%,transparent 38%,color-mix(in srgb,var(--bg) 72%,transparent) 100%);opacity:.42;pointer-events:none}@media (max-width: 480px){.bg-planetarium-vignette{opacity:.34}}.bg-milkyway-band{position:absolute;top:-18%;right:-18%;bottom:-18%;left:-18%;background:linear-gradient(116deg,transparent 30%,color-mix(in srgb,var(--accent) 11%,transparent) 44%,color-mix(in srgb,var(--text) 14%,transparent) 50%,color-mix(in srgb,var(--accent) 8%,transparent) 56%,transparent 68%);opacity:.68;filter:blur(26px);pointer-events:none}@media (max-width: 480px){.bg-milkyway-band{opacity:.58;filter:blur(22px)}}.bg-star-dust{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.42;background-image:radial-gradient(circle at 7% 14%,color-mix(in srgb,var(--text) 50%,transparent) 0,transparent 1.4px),radial-gradient(circle at 19% 31%,color-mix(in srgb,var(--text) 42%,transparent) 0,transparent 1.2px),radial-gradient(circle at 41% 9%,color-mix(in srgb,var(--text) 38%,transparent) 0,transparent 1px),radial-gradient(circle at 63% 22%,color-mix(in srgb,var(--text) 45%,transparent) 0,transparent 1.3px),radial-gradient(circle at 81% 11%,color-mix(in srgb,var(--text) 40%,transparent) 0,transparent 1.1px),radial-gradient(circle at 93% 28%,color-mix(in srgb,var(--text) 48%,transparent) 0,transparent 1.2px),radial-gradient(circle at 14% 52%,color-mix(in srgb,var(--text) 35%,transparent) 0,transparent 1px),radial-gradient(circle at 28% 68%,color-mix(in srgb,var(--text) 44%,transparent) 0,transparent 1.3px),radial-gradient(circle at 52% 41%,color-mix(in srgb,var(--text) 32%,transparent) 0,transparent 1px),radial-gradient(circle at 71% 58%,color-mix(in srgb,var(--text) 46%,transparent) 0,transparent 1.2px),radial-gradient(circle at 88% 72%,color-mix(in srgb,var(--text) 36%,transparent) 0,transparent 1.1px),radial-gradient(circle at 9% 78%,color-mix(in srgb,var(--text) 42%,transparent) 0,transparent 1.2px),radial-gradient(circle at 36% 91%,color-mix(in srgb,var(--text) 38%,transparent) 0,transparent 1px),radial-gradient(circle at 58% 84%,color-mix(in srgb,var(--text) 44%,transparent) 0,transparent 1.3px),radial-gradient(circle at 76% 93%,color-mix(in srgb,var(--text) 34%,transparent) 0,transparent 1px),radial-gradient(circle at 47% 19%,color-mix(in srgb,var(--accent) 35%,transparent) 0,transparent 1px),radial-gradient(circle at 66% 36%,color-mix(in srgb,var(--accent) 28%,transparent) 0,transparent 1px),radial-gradient(circle at 22% 44%,color-mix(in srgb,var(--accent) 22%,transparent) 0,transparent 1px),radial-gradient(circle at 91% 51%,color-mix(in srgb,var(--accent) 26%,transparent) 0,transparent 1px),radial-gradient(circle at 11% 96%,color-mix(in srgb,var(--accent) 20%,transparent) 0,transparent 1px);pointer-events:none}@media (max-width: 480px){.bg-star-dust{opacity:.36}}.bg-star-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.bg-star{position:absolute;width:2px;height:2px;background:color-mix(in srgb,var(--text) 55%,transparent);border-radius:50%;box-shadow:0 0 6px color-mix(in srgb,var(--accent) 45%,transparent);animation:star-twinkle 4s ease-in-out infinite}.bg-star--tiny{width:1px;height:1px;opacity:.85;box-shadow:0 0 4px color-mix(in srgb,var(--accent) 35%,transparent);animation-duration:5.2s}.bg-star:nth-child(odd){animation-delay:.5s}.bg-star:nth-child(3n){animation-delay:1s}.bg-star:nth-child(4n){animation-delay:1.5s}@keyframes star-twinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.9;transform:scale(1.2)}}.bg-meteor-layer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.bg-meteor{position:absolute;width:0;height:0;pointer-events:none;will-change:transform,opacity;animation:bg-meteor-sweep var(--dur, 14s) linear infinite;animation-delay:var(--del, 0s)}.bg-meteor__streak{position:absolute;left:0;top:0;width:clamp(5.5rem,32vw,15rem);height:1px;border-radius:999px;transform-origin:0 50%;transform:rotate(var(--deg, -35deg));background:linear-gradient(90deg,transparent 0%,transparent 22%,color-mix(in srgb,var(--accent) 18%,transparent) 48%,color-mix(in srgb,var(--text) 45%,transparent) 78%,color-mix(in srgb,var(--text) 75%,transparent) 92%,color-mix(in srgb,var(--accent) 55%,transparent) 100%);box-shadow:0 0 10px color-mix(in srgb,var(--accent) 35%,transparent)}.bg-meteor__streak:after{content:"";position:absolute;right:-.5px;top:50%;width:2.5px;height:2.5px;margin-top:-1.25px;border-radius:50%;background:color-mix(in srgb,var(--text) 92%,transparent);box-shadow:0 0 5px color-mix(in srgb,var(--text) 60%,transparent),0 0 12px color-mix(in srgb,var(--accent) 45%,transparent)}@keyframes bg-meteor-sweep{0%,94%,to{opacity:0;transform:translate3d(calc(var(--mx) * -.14),calc(var(--my) * -.14),0)}94.4%{opacity:1;transform:translate3d(calc(var(--mx) * -.08),calc(var(--my) * -.08),0)}97.2%{opacity:1;transform:translate3d(calc(var(--mx) * .9),calc(var(--my) * .9),0)}98.1%{opacity:0;transform:translate3d(calc(var(--mx) * 1.06),calc(var(--my) * 1.06),0)}}@media (prefers-reduced-motion: reduce){.bg-meteor,.bg-meteor-layer{animation:none!important;opacity:0!important}.bg-star{animation:none;opacity:.55}.bg-star--tiny{opacity:.45}}body{margin:0;min-height:100dvh;font-family:var(--font-primary);color:var(--text);line-height:var(--leading-body);overflow-x:hidden;overscroll-behavior-y:none;background:transparent;-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.app a[href]:focus-visible,.app button:focus-visible,.app summary:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.app{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);padding-left:var(--safe-left);padding-right:var(--safe-right)}a[href]{-webkit-user-select:auto;user-select:auto;-webkit-touch-callout:default;pointer-events:auto}.compass-section .compass-container,.compass-section .compass-container *,.compass-section .compass-toolbar,.compass-section .compass-toolbar *,.bearing-hud,.bearing-hud *,button,.hamburger,input,select,textarea{-webkit-user-select:none;user-select:none}.header{padding:var(--space-4) var(--space-4);position:relative;z-index:200;border-bottom:1px solid var(--divider);background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.header--legal{position:sticky;top:0;z-index:200;background:var(--bg, #0a0a0f);padding-top:max(var(--space-4),env(safe-area-inset-top,0));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-brand-link{display:flex;align-items:center;gap:.6rem;color:inherit;text-decoration:none}.header-brand-link:hover .title,.header-brand-link:focus-visible .title{text-shadow:0 0 22px rgba(79,172,254,.32)}.header--legal .title{font-size:1.05rem;letter-spacing:.02em;line-height:1.2;text-shadow:none}.header--legal .header-logo{height:26px;max-width:110px}.header--legal .header-inner{flex-direction:row;align-items:center;justify-content:space-between}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.header-brand{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;flex:1;min-width:0}.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.locale-switch{display:inline-flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end;max-width:min(100%,220px)}.locale-switch-btn{min-height:40px;min-width:44px;padding:.35rem .55rem;font-size:var(--text-xs);font-family:inherit;font-weight:500;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-default)}.locale-switch-btn:hover,.locale-switch-btn:focus-visible{color:var(--text);border-color:var(--border-brand);outline:none}.locale-switch-btn.is-active{color:var(--accent);border-color:#4facfe8c;background:var(--accent-soft)}html[lang=en]{--font-primary: "Noto Sans", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif}.compass-ring-tick-inner--solo{display:flex;align-items:center;justify-content:center;width:100%;font-size:.62em;font-weight:600}.hamburger{flex-shrink:0;width:44px;height:44px;padding:0;border:none;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:8px;transition:background .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.hamburger:hover{background:#ffffff14}.hamburger-bar{display:block;width:22px;height:2px;background:var(--text-muted);border-radius:1px;transition:transform .3s,opacity .3s}.hamburger[aria-expanded=true] .hamburger-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger[aria-expanded=true] .hamburger-bar:nth-child(2){opacity:0}.hamburger[aria-expanded=true] .hamburger-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:none}.nav-overlay.is-open{display:block}.nav-menu{position:absolute;top:0;right:0;width:min(280px,85vw);height:100%;background:var(--bg-card);padding:calc(var(--safe-top) + 1rem) calc(1.5rem + var(--safe-right)) calc(2rem + var(--safe-bottom)) 1.5rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:-4px 0 24px #0006;border-left:1px solid var(--divider)}.nav-link{display:block;padding:1rem 1.25rem;color:var(--text);text-decoration:none;font-size:1rem;border-radius:10px;transition:background .2s}.nav-link:hover{background:#ffffff14}.nav-close{margin-top:auto;padding:1rem;font-size:.9rem;color:var(--text-muted);background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:10px;cursor:pointer;transition:background .2s}.nav-close:hover{background:#ffffff0d}.guide-toggle{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-4);background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius-lg);cursor:pointer;color:var(--text);font:inherit;margin-bottom:0;transition:var(--transition-default);text-align:left;box-shadow:var(--shadow-card)}.guide-toggle:hover{border-color:var(--border-brand)}.guide-toggle .guide-logo{height:24px;width:auto;object-fit:contain;flex-shrink:0;filter:brightness(0) invert(1);opacity:.8}.guide-toggle-text{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:.15rem}.guide-title-row{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.guide-toggle .guide-title{margin:0;font-size:var(--text-lg);font-weight:600;letter-spacing:.02em}.guide-toggle-hint{font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--text-muted);font-weight:400}.guide-toggle-icon{font-size:.7rem;color:var(--text-muted);transition:transform .3s}.guide-toggle[aria-expanded=true] .guide-toggle-icon{transform:rotate(180deg)}.guide-body{overflow:hidden;transition:max-height .45s ease-out;max-height:0}.guide-body.is-open{max-height:4000px}.guide-body .guide-lead{margin:.65rem 0 0}.guide-body .guide-items{margin-top:.75rem}.header-logo{height:32px;width:auto;max-width:140px;object-fit:contain;opacity:1}@media (min-width: 600px){.header{padding:1rem}.header-inner{flex-direction:column;align-items:center}.header-actions{width:100%;max-width:28rem;justify-content:center;flex-wrap:wrap;gap:.75rem}.header-brand{align-items:center}.hamburger--footer{display:none}.header-logo{height:36px;max-width:160px}}.header-title-wrap{text-align:center}.title{margin:0;font-size:var(--text-hero);font-weight:700;letter-spacing:.06em;line-height:var(--leading-tight);color:var(--accent);text-shadow:0 0 32px color-mix(in srgb,var(--accent) 50%,transparent),0 0 72px color-mix(in srgb,var(--accent) 22%,transparent),0 2px 1px color-mix(in srgb,var(--bg) 65%,transparent)}.subtitle{margin:var(--space-2) auto 0;font-size:var(--text-md);line-height:var(--leading-relaxed);color:color-mix(in srgb,var(--text-muted) 92%,var(--text));max-width:22rem}.main{flex:1;padding:var(--space-5) var(--space-4);padding-top:calc(var(--space-4) + var(--safe-top));display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}.bearing-hud{position:relative;width:min(100%,420px);height:clamp(2.5rem,8vw,3rem);margin:0 auto;flex-shrink:0}.bearing-hud-viewport{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--accent) 40%,var(--card-border));background:var(--bg-hud-inner);box-shadow:var(--shadow-hud-inset),var(--glow-compass),0 0 28px color-mix(in srgb,var(--accent) 18%,transparent)}.bearing-hud-strip{display:flex;flex-direction:row;align-items:stretch;height:100%;will-change:transform;transition:transform .06s linear}.bearing-hud-tick{flex:0 0 3.25rem;width:3.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.05rem;border-right:1px solid var(--divider);color:var(--text-muted);font-size:var(--text-xs);line-height:var(--leading-tight)}.bearing-hud-tick-en{font-weight:600;letter-spacing:.04em;color:#ffffff8c}.bearing-hud-center{position:absolute;left:50%;top:0;bottom:0;width:2px;margin-left:-1px;background:var(--accent);box-shadow:0 0 10px var(--accent);pointer-events:none;z-index:2}.bearing-hud-target{position:absolute;left:50%;top:-2px;margin-left:-.5rem;width:1rem;text-align:center;font-size:.55rem;color:var(--accent-orange);text-shadow:0 0 6px rgba(221,101,0,.8);pointer-events:none;z-index:3;will-change:transform;transition:transform .06s linear}.bearing-hud--no-compass .bearing-hud-strip{opacity:.72}.compass-section{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;overflow:visible}.compass-container{position:relative;width:min(280px,90vw);aspect-ratio:1;overflow:visible;margin:clamp(.75rem,3vw,1.1rem) clamp(.75rem,3vw,1.1rem) clamp(1.6rem,5vw,2.25rem)}@media (max-width: 599px){.compass-container{width:min(300px,92vw)}}.mascot{width:64px;height:auto;object-fit:contain;flex-shrink:0;filter:brightness(1.1) drop-shadow(0 0 12px rgba(255,255,255,.25));animation:gentle-float 5s ease-in-out infinite}.mascot--main{width:72px}@keyframes gentle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@media (max-width: 400px){.mascot{width:56px}}.compass-ring{width:100%;height:100%;border:2px solid var(--border-brand);border-radius:50%;position:relative;transition:transform .08s ease-out;backface-visibility:hidden;-webkit-backface-visibility:hidden;overflow:visible;box-shadow:0 0 0 1px #00000059,var(--glow-compass),inset 0 0 48px #4facfe08}.compass-uncertainty-fan{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;pointer-events:none;transform-origin:center center;will-change:transform;z-index:2;--acc-deg: 0deg;background:conic-gradient(from calc(-1 * var(--acc-deg)),transparent 0deg,rgba(221,101,0,.04) calc(.15 * var(--acc-deg)),rgba(221,101,0,.18) var(--acc-deg),rgba(221,101,0,.04) calc(1.85 * var(--acc-deg)),transparent calc(2 * var(--acc-deg)));-webkit-mask:radial-gradient(circle,transparent 0%,transparent 18%,black 32%,black 96%,transparent 100%);mask:radial-gradient(circle,transparent 0%,transparent 18%,black 32%,black 96%,transparent 100%);transition:opacity .25s ease}.compass-uncertainty-fan[hidden]{display:none}.compass-ring-tick{position:absolute;left:50%;bottom:50%;top:auto;width:0;height:50%;transform-origin:bottom center;pointer-events:none}.compass-ring-tick-inner{position:absolute;left:50%;top:0;transform:translate(-50%,calc(-100% - .35rem));width:max-content;min-width:1.35rem;max-width:2.75rem;text-align:center;font-size:clamp(.54rem,2.1vw,.68rem);line-height:1.08;color:var(--text-muted)}.compass-ring-tick--cardinal .compass-ring-tick-inner{display:flex;flex-direction:column;align-items:center;gap:.14em;color:var(--accent);font-weight:700;font-size:clamp(.68rem,2.8vw,.88rem);letter-spacing:.02em;text-shadow:0 0 8px rgba(79,172,254,.28)}.compass-ring-tick--cardinal .compass-ring-tick-en{font-size:clamp(.58rem,2.4vw,.72rem);color:#a0dcfffa;margin-top:0}.compass-ring-tick-en{display:block;font-size:.46rem;font-weight:600;letter-spacing:.03em;color:#ffffff73;line-height:1;margin-top:.06em}.compass-fuji-stack{position:absolute;top:5%;right:5%;bottom:5%;left:5%;z-index:1;display:flex;align-items:flex-end;justify-content:center;pointer-events:none}.compass-fuji-silhouette{width:94%;max-width:260px;height:auto;color:#96c3ebe0;filter:drop-shadow(0 0 10px rgba(79,172,254,.28));transition:filter .4s ease,color .4s ease}.compass-fuji-silhouette .fuji-silhouette-path{paint-order:stroke fill}.compass-fuji-silhouette.is-diamond-near{color:#ffd778f2;filter:drop-shadow(0 0 14px rgba(255,200,80,.85)) drop-shadow(0 0 28px rgba(255,180,40,.45));animation:fuji-gold-pulse 2.2s ease-in-out infinite}.compass-fuji-silhouette.is-diamond-near .fuji-silhouette-path{stroke:#ffc878f2}@keyframes fuji-gold-pulse{0%,to{opacity:1}50%{opacity:.88}}.compass-sun{position:absolute;left:50%;top:50%;width:1.75rem;height:1.75rem;margin:-.875rem 0 0 -.875rem;display:flex;align-items:center;justify-content:center;font-size:1.35rem;line-height:1;filter:drop-shadow(0 0 6px rgba(255,220,100,.7));will-change:left,top,opacity;transition:left .2s ease-out,top .2s ease-out,opacity .3s ease;pointer-events:none}.compass-sun.is-below-horizon{opacity:.25}.compass-polaris{position:absolute;left:50%;top:50%;width:1.25rem;height:1.25rem;margin:-.625rem 0 0 -.625rem;display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;color:#e8f0ffeb;filter:drop-shadow(0 0 4px rgba(180,210,255,.7));will-change:left,top,opacity;transition:left .2s ease-out,top .2s ease-out,opacity .4s ease;pointer-events:none;animation:polaris-twinkle 3.5s ease-in-out infinite}.compass-polaris[hidden]{display:none}@media (prefers-reduced-motion: reduce){.compass-polaris{animation:none}}@keyframes polaris-twinkle{0%,to{opacity:1}50%{opacity:.65}}.compass-moon{position:absolute;left:50%;top:50%;width:1.5rem;height:1.5rem;margin:-.75rem 0 0 -.75rem;display:flex;align-items:center;justify-content:center;font-size:1.15rem;line-height:1;filter:drop-shadow(0 0 4px rgba(220,230,255,.55));will-change:left,top;transition:left .25s ease-out,top .25s ease-out,opacity .4s ease;pointer-events:none}.compass-moon[hidden]{display:none}.compass-venus{position:absolute;left:50%;top:50%;width:.95rem;height:.95rem;margin:-.475rem 0 0 -.475rem;display:flex;align-items:center;justify-content:center;font-size:.85rem;line-height:1;color:#ffebc8f2;filter:drop-shadow(0 0 4px rgba(255,220,170,.7));will-change:left,top;transition:left .25s ease-out,top .25s ease-out,opacity .4s ease;pointer-events:none;animation:venus-twinkle 2.6s ease-in-out infinite}.compass-venus[hidden]{display:none}@media (prefers-reduced-motion: reduce){.compass-venus{animation:none}}@keyframes venus-twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.92)}}.compass-shootingstar{position:absolute;top:12%;left:12%;width:30%;height:1px;background:linear-gradient(90deg,#fff0,#fffffff2 60%,#fff0);border-radius:999px;filter:drop-shadow(0 0 4px rgba(255,255,255,.85));transform:translateZ(0) rotate(28deg);pointer-events:none;z-index:4}.compass-shootingstar[hidden]{display:none}.compass-shootingstar.is-running{animation:shooting-star-run .9s ease-out forwards}@keyframes shooting-star-run{0%{transform:translate3d(-30%,-30%,0) rotate(28deg) scaleX(.4);opacity:0}20%{opacity:1}to{transform:translate3d(80%,80%,0) rotate(28deg) scaleX(1.2);opacity:0}}@media (prefers-reduced-motion: reduce){.compass-shootingstar.is-running{animation:none;opacity:0}}.display-mode-wrap{display:flex;flex-direction:column;gap:var(--space-2);margin:0}.display-mode-label{display:block;font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.02em}.display-mode-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;padding:var(--space-3) var(--space-8) var(--space-3) var(--space-4);font-size:var(--text-md);line-height:var(--leading-snug);font-family:var(--font-primary);color:var(--text);background-color:var(--surface-field);background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-repeat:no-repeat;background-position:right var(--space-4) top 50%,right var(--space-3) top 50%;background-size:5px 5px,5px 5px;border:1px solid var(--card-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-default)}.display-mode-select:hover{border-color:var(--border-brand);background-color:var(--surface-field)}.display-mode-select:focus-visible{outline:none;border-color:var(--border-brand);box-shadow:0 0 0 2px var(--accent-soft)}.display-mode-hint{margin:0;font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--text-muted)}.fuji-near-panel{display:flex;flex-direction:column;gap:var(--space-2);margin:0;padding:var(--space-4);background:linear-gradient(135deg,color-mix(in srgb,var(--accent-orange) 16%,var(--bg-card)),color-mix(in srgb,var(--accent) 8%,var(--bg-card)));border:1px solid color-mix(in srgb,var(--accent-orange) 32%,var(--card-border));border-radius:var(--radius-md);box-shadow:var(--shadow-hud-inset)}.fuji-near-panel[hidden]{display:none}.fuji-near-distance{display:flex;flex-direction:column;align-items:center;gap:.15rem}.fuji-near-distance-label{font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.05em}.fuji-near-distance-value{font-size:clamp(2.2rem,7vw,3.2rem);font-weight:700;line-height:1.05;color:color-mix(in srgb,var(--accent-orange-hover) 85%,var(--text));text-shadow:0 0 12px color-mix(in srgb,var(--accent-orange) 35%,transparent);letter-spacing:-.01em;font-variant-numeric:tabular-nums}.fuji-near-status{text-align:center;font-size:var(--text-md);font-weight:600;color:color-mix(in srgb,var(--accent-orange) 55%,var(--text-muted));min-height:1.4em}.fuji-near-status[data-threshold=summit]{color:color-mix(in srgb,var(--accent-orange-hover) 40%,var(--text));text-shadow:0 0 8px color-mix(in srgb,var(--accent-orange) 45%,transparent)}.location-info-panel{display:flex;flex-direction:column;gap:var(--space-3);margin:0;padding:var(--space-4) var(--space-5);background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-hud-inset);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.location-info-panel[hidden]{display:none}.location-info-row{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--text-sm)}.location-info-label{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.04em}.location-info-value{font-size:var(--text-md);color:var(--text);font-variant-numeric:tabular-nums}.location-info-value--area{color:color-mix(in srgb,var(--accent-orange) 45%,var(--text));font-weight:600}.location-info-mapbtn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);margin:var(--space-1) 0 var(--space-2);padding:var(--space-2) var(--space-4);background:var(--accent-soft);border:1px solid var(--border-brand);border-radius:var(--radius-sm);color:var(--text);font-size:var(--text-sm);font-weight:600;text-decoration:none;transition:var(--transition-default)}.location-info-mapbtn[hidden]{display:none}.location-info-mapbtn:hover{background:color-mix(in srgb,var(--accent) 22%,var(--bg-card));border-color:var(--accent)}.location-info-mapbtn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.location-info-attribution{margin:var(--space-2) 0 0;font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.02em}.location-info-row--landmarks{margin-top:.2rem}.location-info-landmarks{list-style:none;margin:.25rem 0 0;padding:0;display:flex;flex-direction:column;gap:.2rem}.location-info-landmarks li{display:flex;justify-content:space-between;gap:var(--space-3);font-size:var(--text-sm);color:var(--text);font-variant-numeric:tabular-nums}.location-info-landmarks li>span:last-child{color:var(--text-muted)}.app-mode-nightsky .compass-milkyway{display:block!important;opacity:.85!important}.app-mode-nightsky .compass-starfield{--star-night-boost: .45}.compass-bright-stars,.compass-planets{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;border-radius:inherit;overflow:visible}.compass-bright-stars[hidden],.compass-planets[hidden]{display:none}.compass-bright-star{position:absolute;display:block;border-radius:50%;background:#fffffff2;transform:translate(-50%,-50%);box-shadow:0 0 4px #dcebff8c;pointer-events:none;opacity:.9;animation:bright-star-twinkle 4.2s ease-in-out infinite}@keyframes bright-star-twinkle{0%,to{opacity:.9}50%{opacity:.55}}@media (prefers-reduced-motion: reduce){.compass-bright-star{animation:none}}.compass-planet{position:absolute;display:inline-flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;font-size:.95rem;line-height:1;transform:translate(-50%,-50%);text-shadow:0 0 4px rgba(0,0,0,.55);filter:drop-shadow(0 0 3px rgba(255,220,180,.55));pointer-events:none}@media (prefers-reduced-motion: reduce){.compass-planet{filter:none}}.nightsky-panel{margin:0;padding:var(--space-4) var(--space-5);background:linear-gradient(165deg,color-mix(in srgb,var(--accent) 12%,var(--bg-card)),var(--bg-card));border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-hud-inset);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.nightsky-panel[hidden]{display:none}.nightsky-panel-heading{margin:0 0 var(--space-3);font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;color:var(--text-muted)}.nightsky-panel-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.nightsky-panel-list li{display:grid;grid-template-columns:minmax(0,5.5em) 1fr auto;align-items:baseline;gap:var(--space-2);font-size:var(--text-sm);color:var(--text);font-variant-numeric:tabular-nums}.nightsky-panel-list li.is-below{color:var(--text-faint)}.nightsky-panel-list .nightsky-name{font-weight:600}.nightsky-panel-list .nightsky-bearing{color:color-mix(in srgb,var(--accent-orange) 35%,var(--text))}.nightsky-panel-list li.is-below .nightsky-bearing{color:var(--text-faint)}.nightsky-panel-list .nightsky-altitude{font-size:var(--text-xs);color:var(--text-muted)}.nightsky-panel-empty{margin:0;font-size:var(--text-sm);color:var(--text-muted)}.compass-starfield{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border-radius:inherit;pointer-events:none;z-index:0;--star-night-boost: 0;opacity:calc(.4 + var(--star-night-boost, 0));transition:opacity 1.5s ease;overflow:visible}.compass-starfield circle{transform-origin:center;transform-box:fill-box}.starfield-twinkle-slow circle{animation:starfield-twinkle 7.5s ease-in-out infinite}.starfield-twinkle-med circle{animation:starfield-twinkle 5s ease-in-out infinite;animation-delay:1.4s}.starfield-twinkle-fast circle{animation:starfield-twinkle 3.5s ease-in-out infinite;animation-delay:.7s}@keyframes starfield-twinkle{0%,to{opacity:.65}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.compass-starfield circle{animation:none!important}}.compass-milkyway{position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;background:linear-gradient(115deg,#fff0 38%,#c8d2ff1a 48%,#dcdcff29,#c8d2ff1a 56%,#fff0 66%);filter:blur(8px);opacity:.6;pointer-events:none;z-index:0;border-radius:inherit}.compass-milkyway[hidden]{display:none}.compass-comet{position:absolute;left:50%;top:50%;width:1.25rem;height:1.25rem;margin:-.625rem 0 0 -.625rem;display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;color:#dcebfff2;filter:drop-shadow(0 0 4px rgba(160,200,255,.7));will-change:left,top;transition:left .25s ease-out,top .25s ease-out,opacity .4s ease;pointer-events:none;z-index:3}.compass-comet[hidden]{display:none}.compass-radiant{position:absolute;left:50%;top:50%;width:1.1rem;height:1.1rem;margin:-.55rem 0 0 -.55rem;display:flex;align-items:center;justify-content:center;font-size:.95rem;line-height:1;color:#ffdce6f2;filter:drop-shadow(0 0 5px rgba(255,180,210,.7));pointer-events:none;animation:radiant-twinkle 2.8s ease-in-out infinite;z-index:3}.compass-radiant[hidden]{display:none}@media (prefers-reduced-motion: reduce){.compass-radiant{animation:none}}@keyframes radiant-twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.meteor-shower-banner{position:absolute;left:50%;top:6%;transform:translate(-50%);padding:.25rem .6rem;background:#1419328c;border:1px solid rgba(255,200,220,.35);border-radius:999px;color:#fff0f5f2;font-size:.7rem;white-space:nowrap;pointer-events:none;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.meteor-shower-banner[hidden]{display:none}.elevation-gauge{position:absolute;right:2%;top:50%;transform:translateY(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.2rem;width:1.5rem;pointer-events:none}.elevation-gauge-label{font-size:.55rem;color:var(--text-muted);white-space:nowrap}.elevation-gauge-track{width:6px;height:clamp(3rem,22vw,4.5rem);border-radius:3px;background:#ffffff14;border:1px solid var(--card-border);overflow:hidden;display:flex;flex-direction:column-reverse}.elevation-gauge-fill{width:100%;height:0%;min-height:0;background:linear-gradient(180deg,var(--accent-orange),var(--accent));border-radius:2px;transition:height .25s ease-out}.compass-needle{position:absolute;top:50%;left:50%;width:4px;height:45%;margin-left:-2px;margin-top:-45%;background:var(--accent);border-radius:2px;transform-origin:center bottom;will-change:transform;pointer-events:none;z-index:2;backface-visibility:hidden;-webkit-backface-visibility:hidden;overflow:visible;transition:opacity .2s ease,background var(--motion-base),box-shadow var(--motion-base)}.compass-needle.is-inactive{opacity:.35}.compass-needle.is-on-target{background:linear-gradient(180deg,var(--accent-orange),var(--accent));box-shadow:0 0 12px #dd65008c,0 0 4px #dd6500d9}.compass-fuji-anchor{position:absolute;top:0;left:50%;transform:translate(-50%,-98%);pointer-events:none;backface-visibility:hidden;-webkit-backface-visibility:hidden}.compass-fuji-marker{display:flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;font-size:1.9rem;line-height:1;transform-origin:center center;will-change:transform;pointer-events:none;backface-visibility:hidden;-webkit-backface-visibility:hidden;transition:filter var(--motion-base)}.compass-fuji-marker.is-on-target{filter:drop-shadow(0 0 8px rgba(221,101,0,.85))}@media (prefers-reduced-motion: no-preference){.compass-fuji-marker.is-on-target{animation:fuji-on-target-pulse 1.6s ease-in-out infinite}}@keyframes fuji-on-target-pulse{0%,to{filter:drop-shadow(0 0 6px rgba(221,101,0,.55))}50%{filter:drop-shadow(0 0 14px rgba(221,101,0,.95))}}.compass-calib-hint{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:var(--space-3);padding:.45rem .65rem .45rem .75rem;border:1px solid var(--border-brand);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-muted);font-size:var(--text-sm);line-height:var(--leading-snug);max-width:26rem}.compass-calib-hint[hidden]{display:none}.compass-calib-hint__text{flex:1 1 auto;min-width:0}.compass-calib-hint__action{flex:0 0 auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--accent, #4facfe);background:#4facfe2e;color:var(--text, #f5f9ff);font-size:.82rem;font-weight:600;padding:.32rem .7rem;border-radius:999px;cursor:pointer;transition:background .15s ease,transform .1s ease;white-space:nowrap}.compass-calib-hint__action:hover,.compass-calib-hint__action:focus-visible{background:#4facfe52}.compass-calib-hint__action:active{transform:scale(.97)}.compass-calib-figure8{flex:0 0 auto;width:44px;height:22px;color:var(--accent)}.compass-calib-figure8 path{stroke-dasharray:22 78;stroke-dashoffset:0}@media (prefers-reduced-motion: no-preference){.compass-calib-figure8 path{animation:figure8-trace 2.4s linear infinite}}@keyframes figure8-trace{to{stroke-dashoffset:-100}}.compass-tune-dialog{border:none;background:transparent;padding:0;margin:auto;max-width:min(92vw,28rem);width:100%;color:var(--text, #f5f9ff)}.compass-tune-dialog::backdrop{background:#080c19b8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.compass-tune-dialog__inner{position:relative;background:linear-gradient(155deg,#1c2446f5,#0f162dfa);border:1px solid rgba(180,200,255,.32);border-radius:var(--radius-md, 12px);padding:1.25rem 1.15rem 1.1rem;box-shadow:0 14px 38px #00000080}.compass-tune-dialog__close-x{position:absolute;top:.4rem;right:.5rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#dce6ffa6;font-size:1.5rem;line-height:1;cursor:pointer;border-radius:999px}.compass-tune-dialog__close-x:hover,.compass-tune-dialog__close-x:focus-visible{background:#ffffff14;color:var(--text, #f5f9ff)}.compass-tune-dialog__title{margin:0 0 .45rem;padding-right:1.5rem;font-size:1.08rem;font-weight:700;letter-spacing:.02em}.compass-tune-dialog__desc{margin:0 0 .85rem;font-size:.93rem;line-height:1.55;color:var(--text-muted, rgba(220, 230, 255, .85))}.compass-tune-dialog__visual{display:flex;justify-content:center;align-items:center;margin:0 auto .9rem;padding:.5rem 0}.compass-tune-figure8{width:min(220px,70%);height:auto;color:#78c8fff2;filter:drop-shadow(0 0 10px rgba(79,172,254,.35))}.compass-tune-figure8 path{stroke-dasharray:18 82;stroke-dashoffset:0}.compass-tune-figure8__phone{motion-path:path("M20 30 C20 10 50 10 60 30 C70 50 100 50 100 30 C100 10 70 10 60 30 C50 50 20 50 20 30 Z");offset-path:path("M20 30 C20 10 50 10 60 30 C70 50 100 50 100 30 C100 10 70 10 60 30 C50 50 20 50 20 30 Z");offset-rotate:0deg;fill:#ffebc8f2}@media (prefers-reduced-motion: no-preference){.compass-tune-figure8 path{animation:figure8-trace 3.2s linear infinite}.compass-tune-figure8__phone{animation:figure8-orbit 3.2s linear infinite}}@keyframes figure8-orbit{0%{offset-distance:0%;motion-offset:0%}to{offset-distance:100%;motion-offset:100%}}.compass-tune-dialog__status{margin:.25rem 0 .95rem;padding:.5rem .7rem;font-size:.92rem;line-height:1.4;border-radius:.45rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);text-align:center;min-height:1.3em;transition:background .25s ease,color .25s ease,border-color .25s ease}.compass-tune-dialog__status[data-tone=pending]{color:#dce6ffc7}.compass-tune-dialog__status[data-tone=bad]{color:#ffdcc8f2;background:#ff8a5a1f;border-color:#ff8a5a66}.compass-tune-dialog__status[data-tone=improving]{color:#fff0c8f2;background:#ffdc821f;border-color:#ffdc8266}.compass-tune-dialog__status[data-tone=good]{color:#c8ffdcfa;background:#78f0b42e;border-color:#78f0b48c;font-weight:700}.compass-tune-dialog__actions{display:flex;flex-direction:column;gap:.55rem}.compass-tune-dialog__btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(180,200,255,.35);background:#ffffff0f;color:var(--text, #f5f9ff);font-size:.95rem;font-weight:600;padding:.6rem .8rem;border-radius:.55rem;cursor:pointer;transition:background .15s ease,border-color .15s ease;text-align:center;width:100%}.compass-tune-dialog__btn:hover,.compass-tune-dialog__btn:focus-visible{background:#ffffff1f;border-color:#b4c8ff99}.compass-tune-dialog__btn--alt{background:#4facfe2e;border-color:#4facfe8c}.compass-tune-dialog__btn--alt:hover,.compass-tune-dialog__btn--alt:focus-visible{background:#4facfe52}@media (prefers-reduced-motion: reduce){.compass-tune-figure8 path,.compass-tune-figure8__phone{animation:none!important}}@media (max-width: 540px){.compass-tune-dialog{margin:auto auto 0;max-width:100vw;width:100%}.compass-tune-dialog__inner{border-radius:18px 18px 0 0;padding:1.1rem 1rem 1.4rem}}.compass-label{position:absolute;bottom:-2.65rem;left:50%;transform:translate(-50%);font-size:.78rem;color:var(--text-muted);white-space:nowrap;z-index:4}.section-logo{width:44px;height:auto;object-fit:contain;align-self:center;margin-bottom:var(--space-1);opacity:.92}.section-logo--ginga{opacity:.95}.spot-select-wrap{width:100%;max-width:360px}.spot-select-label{display:block;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-2);letter-spacing:.02em}.spot-select{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-md);font-family:var(--font-primary);background:var(--surface-field);border:1px solid var(--card-border);border-radius:var(--radius-md);color:var(--text);cursor:pointer;transition:var(--transition-default)}.spot-select:hover,.spot-select:focus-visible{border-color:var(--border-brand);outline:none;box-shadow:0 0 0 2px var(--accent-soft)}.spot-select option{background:var(--bg);color:var(--text)}.main-right{display:flex;flex-direction:column;gap:var(--space-4);width:100%;max-width:360px}.main-right-cluster{display:flex;flex-direction:column;gap:var(--space-5);width:100%}.main-right-cluster+.main-right-cluster{margin-top:var(--space-1);padding-top:var(--space-4);border-top:1px solid var(--divider)}.info-panel{width:100%;max-width:360px;background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-5);border:1px solid var(--card-border);box-shadow:var(--shadow-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--divider)}.info-row:last-child{border-bottom:none}.info-label{font-size:var(--text-sm);line-height:var(--leading-snug);color:var(--text-muted)}.info-value{font-weight:600;font-size:var(--text-md);line-height:var(--leading-snug)}.info-value--small{font-size:var(--text-xs);font-weight:400;max-width:60%;text-align:right;word-break:break-all}.info-footnote{margin:calc(-1 * var(--space-1)) 0 var(--space-2);font-size:var(--text-xs);color:var(--text-muted);opacity:.88;line-height:var(--leading-snug)}.info-row--diamond .info-label{align-self:flex-start}.ai-advice-panel{width:100%;max-width:360px;padding:var(--space-5);background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.ai-advice-panel__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.ai-advice-panel__title{margin:0;font-size:var(--text-md);line-height:var(--leading-tight);color:var(--text)}.ai-advice-panel__badge{flex:0 0 auto;max-width:10rem;padding:.14rem .55rem;border:1px solid var(--border-brand);border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:var(--text-xs);font-weight:700;line-height:var(--leading-tight);text-align:center}.ai-advice-panel__text{min-height:4.4rem;margin:0;color:var(--text);font-size:var(--text-sm);line-height:var(--leading-body)}.ai-advice-panel__actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-top:var(--space-3)}.ai-advice-panel__btn{min-height:44px;padding:.65rem .85rem;border:1px solid var(--border-brand);border-radius:var(--radius-sm);background:#4facfe1f;color:var(--text);font-size:var(--text-sm);font-weight:700;line-height:var(--leading-tight);cursor:pointer;transition:var(--transition-default),transform var(--motion-fast)}.ai-advice-panel__btn:hover{background:#4facfe33}.ai-advice-panel__btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.ai-advice-panel__btn:active{transform:scale(.98)}.ai-advice-panel__btn:disabled{cursor:progress;opacity:.62}.ai-advice-panel__source{flex:1 1 12rem;color:var(--text-faint);font-size:var(--text-xs);line-height:var(--leading-snug)}.ai-advice-support{margin-top:var(--space-3);color:var(--text-muted);font-size:var(--text-xs);line-height:var(--leading-snug)}.ai-advice-support summary{cursor:pointer;color:var(--text-muted);font-weight:700}.ai-advice-support ul{margin:var(--space-2) 0 0;padding-left:1.15rem}.ai-advice-support li+li{margin-top:var(--space-2)}.ai-advice-support strong{color:var(--text)}.location-first-view{width:100%;max-width:420px;margin:0 auto;display:flex;flex-direction:column;align-items:stretch;gap:var(--space-3);flex-shrink:0}.location-consent{position:relative;display:flex;width:100%;max-width:100%;flex-direction:column;gap:var(--space-3);padding:var(--space-5);padding-top:calc(var(--space-5) + 4px);overflow:hidden;background:linear-gradient(165deg,color-mix(in srgb,var(--accent) 9%,var(--bg-card)) 0%,var(--bg-card) 42%,color-mix(in srgb,var(--accent-orange) 6%,var(--bg-card)) 100%);border-radius:var(--radius-lg);border:1px solid color-mix(in srgb,var(--accent) 24%,var(--card-border));box-shadow:var(--shadow-card),0 0 56px color-mix(in srgb,var(--accent) 14%,transparent),inset 0 1px color-mix(in srgb,var(--text) 6%,transparent)}.location-consent:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent) 0%,color-mix(in srgb,var(--accent) 40%,var(--accent-orange)) 55%,var(--accent-orange) 100%);pointer-events:none}.location-consent-hero{display:flex;flex-direction:column;gap:var(--space-2);text-align:left}.location-consent-hero-title{margin:0;font-size:clamp(1.5rem,5.8vw,2.05rem);font-weight:700;line-height:var(--leading-tight);color:var(--text);letter-spacing:.03em;text-shadow:0 1px 0 color-mix(in srgb,var(--accent) 15%,transparent)}.location-consent-hero-kicker{margin:0;font-size:var(--text-md);line-height:var(--leading-snug);color:var(--text-muted)}.location-consent-privacy{margin:0;font-size:var(--text-xs);line-height:var(--leading-relaxed);color:var(--text-faint)}.location-consent-privacy a{color:var(--accent);text-decoration:underline}.location-consent-privacy a:hover{color:var(--accent-orange-hover)}.location-rink-stack{display:flex;flex-direction:column;gap:var(--space-2);width:100%;margin-top:var(--space-1)}.location-consent-details{margin:0;padding:0;border-radius:var(--radius-md);border:1px solid var(--card-border);background:#ffffff05}.location-consent-details-summary{cursor:pointer;list-style:none;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:600;color:var(--accent);line-height:var(--leading-snug)}.location-consent-details-summary::-webkit-details-marker{display:none}.location-consent-details-summary:after{content:" ▼";font-size:.75em;opacity:.75}.location-consent-details[open]>.location-consent-details-summary:after{content:" ▲"}.location-consent-details-summary:hover{color:var(--accent-orange-hover)}.location-consent-details-body{padding:0 var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.location-rink-intro{display:flex;flex-direction:row;align-items:flex-start;gap:var(--space-4);width:100%}.location-rink-intro-media{flex-shrink:0}.location-rink-intro-avatar{display:block;width:64px;height:64px;max-width:min(20vw,72px);max-height:min(20vw,72px);object-fit:contain;border-radius:var(--radius-md);background:#ffffff0a}.location-rink-intro-copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-2)}.location-rink-intro-label{margin:0;font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:none;color:var(--accent-cyan, #4facfe)}.location-rink-intro-bubble{margin:0;padding:var(--space-3) var(--space-4);background:linear-gradient(145deg,#4facfe1f,#ffffff0a);border:1px solid rgba(79,172,254,.28);border-radius:var(--radius-md);border-top-left-radius:4px}.location-rink-intro-p{margin:0;font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text)}.location-rink-intro-p+.location-rink-intro-p{margin-top:var(--space-3)}.location-rink-intro-compact{display:block;margin:0;font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-muted)}#locationRinkIntro.is-compact .location-rink-intro-bubble{display:none}@media (max-width: 360px){.location-rink-intro{flex-direction:column;align-items:center;text-align:center}.location-rink-intro-copy{align-items:center}.location-rink-intro-bubble{text-align:left;width:100%}}.location-consent-lead{margin:0;font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text)}.location-consent .location-explanation{margin:0}.location-consent .btn{min-height:44px}.location-first-view .location-actions{margin-top:0}.location-actions{width:100%;max-width:420px;display:flex;justify-content:stretch;margin-top:var(--space-2)}.btn-location-refresh{width:100%;min-height:44px;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-family:inherit;color:var(--text-muted);background:#ffffff0f;border:1px solid var(--card-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-default)}.btn-location-refresh:hover{color:var(--text);border-color:var(--border-brand);background:#ffffff17}.location-explanation{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-muted);padding:var(--space-4);background:#ffffff09;border-radius:var(--radius-md);border:1px solid var(--card-border)}.location-explanation p{margin:0 0 .35rem}.location-explanation p:last-child{margin-bottom:0}.location-explanation-note{font-size:.8rem;opacity:.9}.location-explanation a{color:var(--accent);text-decoration:underline}.location-help{display:none;font-size:.85rem;color:var(--text-muted);padding:.75rem 1rem;margin-top:0;background:#dd650014;border-radius:var(--radius-card);border:1px solid rgba(221,101,0,.25)}.location-help p{margin:0 0 .5rem}.location-help p:last-child{margin-bottom:0}.location-help-title{font-weight:600;color:var(--accent-orange);margin-bottom:.5rem}.location-help-note{font-size:.8rem;opacity:.85}.location-help-note--highlight{margin-top:.5rem;padding:.5rem;background:#dd65001f;border-radius:6px}.location-help-steps{margin:.25rem 0 .5rem 1rem;padding:0}.location-help-steps li{margin-bottom:.35rem}.compass-permission-wrap{margin-top:0;padding:var(--space-4) var(--space-5);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--card-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:var(--space-3)}.compass-permission-title{margin:0;font-size:var(--text-lg);font-weight:700;line-height:var(--leading-snug);color:var(--text)}.compass-permission-msg{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-muted);margin:0}.compass-permission-note{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-relaxed);margin:0}.compass-permission-details{margin:0;border-radius:var(--radius-md);border:1px solid var(--card-border);background:#ffffff05}.compass-permission-details-summary{cursor:pointer;list-style:none;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:600;color:var(--accent);line-height:var(--leading-snug)}.compass-permission-details-summary::-webkit-details-marker{display:none}.compass-permission-details-summary:after{content:" ▼";font-size:.75em;opacity:.75}.compass-permission-details[open]>.compass-permission-details-summary:after{content:" ▲"}.compass-permission-details-summary:hover{color:var(--accent-orange-hover)}.compass-permission-details-body{padding:0 var(--space-4) var(--space-4)}.btn-compass-permit{display:block;width:100%;min-height:44px;padding:var(--space-3) var(--space-4);margin:0;font-size:var(--text-sm);font-weight:600;letter-spacing:.03em;color:#fff;background:var(--accent-orange);border:1px solid rgba(221,101,0,.45);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;box-shadow:0 4px 18px #dd650038;transition:var(--transition-default)}.btn-compass-permit:hover{background:var(--accent-orange-hover);filter:brightness(1.03);box-shadow:0 5px 22px #ff770047}.status-message{font-size:var(--text-sm);line-height:var(--leading-snug);color:var(--text-muted);text-align:center;padding:var(--space-3) var(--space-4)}.status-message--error{color:var(--accent-orange)}.status-message--info{color:var(--accent)}.compass-debug{width:100%;max-width:360px;margin:.25rem auto .75rem;padding:.55rem .7rem;border:1px solid var(--card-border);border-radius:10px;background:#081224bf}.compass-debug-title{margin:0 0 .35rem;font-size:.72rem;color:var(--accent);letter-spacing:.02em}.compass-debug-text{margin:0;font-size:.68rem;line-height:1.35;color:#eaf2ffeb;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.app-version-block{width:100%;max-width:360px;margin:0 auto;padding:var(--space-3) 0 var(--space-2)}.app-version{text-align:center;font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.02em}.release-notes{margin-top:var(--space-2);border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--bg-veil);text-align:left;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.release-notes-summary{padding:.55rem .75rem;font-size:.75rem;font-weight:600;color:var(--text-muted);cursor:pointer;list-style:none;border-left:2px solid transparent;transition:color var(--motion-base),border-color var(--motion-base)}.release-notes-summary:hover,.release-notes[open] .release-notes-summary{color:var(--accent);border-left-color:var(--accent)}.release-notes-summary::-webkit-details-marker{display:none}.release-notes-summary:after{content:" ▼";font-size:.65rem;color:var(--text-muted);font-weight:400}.release-notes[open] .release-notes-summary:after{content:" ▲"}.release-notes-body{padding:0 var(--space-3) var(--space-3);border-top:1px solid var(--divider)}.release-notes-heading{margin:.55rem 0 .25rem;font-size:.68rem;font-weight:600;color:var(--text-muted)}.release-notes-list{margin:.25rem 0 .4rem;padding-left:1.1rem;font-size:.72rem;line-height:1.55;color:var(--text)}.release-notes-list li{margin:.2rem 0}.release-notes-text{margin:.25rem 0 .35rem;font-size:.72rem;line-height:1.6;color:var(--text)}.release-notes-more{margin:.5rem 0 0;font-size:.7rem;line-height:1.45}.release-notes-more a{color:var(--accent)}.bearing-calib-section{margin-top:var(--space-2);border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--bg-veil);text-align:left;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.bearing-calib-summary{padding:.55rem .75rem;font-size:.75rem;font-weight:600;color:var(--text-muted);cursor:pointer;list-style:none;border-left:2px solid transparent;transition:color var(--motion-base),border-color var(--motion-base);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.bearing-calib-summary::-webkit-details-marker{display:none}.bearing-calib-summary:after{content:" ▼";font-size:.65rem;color:var(--text-muted);font-weight:400;margin-left:auto}.bearing-calib-section[open] .bearing-calib-summary:after{content:" ▲"}.bearing-calib-summary:hover,.bearing-calib-section[open] .bearing-calib-summary{color:var(--accent);border-left-color:var(--accent)}.bearing-calib-summary__title{flex:1 1 auto}.bearing-calib-summary__status{font-size:.7rem;font-weight:500;color:var(--accent-orange);white-space:nowrap}.bearing-calib-summary__status:empty{display:none}.bearing-calib-body{padding:0 var(--space-3) var(--space-3);border-top:1px solid var(--divider)}.bearing-calib-desc{margin:.55rem 0 .6rem;font-size:.72rem;line-height:1.6;color:var(--text)}.bearing-calib-anchor-wrap{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.6rem}.bearing-calib-anchor-label{font-size:.7rem;font-weight:500;color:var(--text-muted)}.bearing-calib-anchor{width:100%;padding:.5rem 1.6rem .5rem .6rem;font-size:.85rem;color:var(--text);background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius-sm);-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.bearing-calib-anchor:disabled{opacity:.55;cursor:not-allowed}.bearing-calib-anchor option{color:var(--text);background:var(--bg)}.bearing-calib-anchor option:disabled{color:var(--text-faint)}.bearing-calib-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.bearing-calib-save-btn{flex:1 1 auto;min-height:44px;padding:.5rem .75rem;font-size:.82rem;font-weight:600;color:#fff;background:var(--accent-orange);border:1px solid var(--accent-orange);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--motion-base),box-shadow var(--motion-base)}.bearing-calib-save-btn:hover:not(:disabled){background:var(--accent-orange-hover)}.bearing-calib-save-btn:disabled{opacity:.45;cursor:not-allowed;background:var(--bg-card);border-color:var(--card-border);color:var(--text-muted)}.bearing-calib-reset-btn{min-height:44px;padding:.5rem .75rem;font-size:.78rem;color:var(--text-muted);background:transparent;border:1px solid var(--card-border);border-radius:var(--radius-sm);cursor:pointer;transition:color var(--motion-base),border-color var(--motion-base)}.bearing-calib-reset-btn:hover{color:var(--accent);border-color:var(--accent)}.bearing-calib-message{margin:.55rem 0 0;font-size:.72rem;line-height:1.55;color:var(--text-muted);min-height:1.1em}.bearing-calib-message--success{color:var(--accent-orange)}.bearing-calib-message--warning{color:var(--accent)}.compass-toolbar{display:flex;flex-direction:column;align-items:center;gap:.35rem;margin-top:.4rem}.compass-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:44px;padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:500;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--card-border);border-radius:999px;cursor:pointer;transition:var(--transition-default)}.compass-toolbar-btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.compass-toolbar-btn:hover{color:var(--accent);border-color:var(--accent)}.compass-toolbar-btn[aria-pressed=true]{color:var(--text);background:var(--accent-orange);border-color:var(--accent-orange)}.compass-toolbar-btn[aria-pressed=true]:hover{background:var(--accent-orange-hover);color:var(--text);border-color:var(--accent-orange-hover)}.compass-toolbar-btn__icon{font-size:.95rem;line-height:1}.compass-toolbar-status{font-size:.7rem;color:var(--text-muted);min-height:1em}.compass-toolbar-status:empty{display:none}.compass-lock-needle{position:absolute;top:50%;left:50%;width:4px;height:45%;margin-left:-2px;margin-top:-45%;transform-origin:center bottom;will-change:transform;pointer-events:none;z-index:5}.compass-lock-needle[hidden]{display:none}.compass-lock-marker{position:absolute;top:-.55rem;left:50%;width:1.55rem;height:1.55rem;margin-left:-.775rem;display:flex;align-items:center;justify-content:center;font-size:.95rem;line-height:1;background:var(--accent-orange);color:#fff;border-radius:50%;box-shadow:0 0 0 2px var(--bg-card),0 1px 4px #00000040;pointer-events:none}.compass-drift-warning{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin:var(--space-3) auto 0;max-width:min(100%,22rem);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);line-height:var(--leading-snug);color:var(--text);background:var(--bg-card);border:1px solid var(--border-brand);border-radius:var(--radius-md);box-shadow:var(--shadow-hud-inset)}.compass-drift-warning[hidden]{display:none}.compass-drift-warning__icon{flex:0 0 auto;font-size:.95rem;line-height:1}.compass-drift-warning__text{flex:1 1 auto;min-width:0}.compass-drift-warning__action{flex:0 0 auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--accent);background:var(--accent-soft);color:var(--text);font-size:var(--text-xs);font-weight:600;padding:var(--space-2) var(--space-3);border-radius:999px;cursor:pointer;transition:var(--transition-default),transform var(--motion-fast);white-space:nowrap}.compass-drift-warning__action:hover,.compass-drift-warning__action:focus-visible{background:#4facfe52}.compass-drift-warning__action:active{transform:scale(.97)}.info-row--magnetic .info-value{display:inline-flex;align-items:baseline;gap:.5rem}.magnetic-field-badge{display:inline-flex;align-items:center;padding:.05rem .45rem;font-size:.65rem;line-height:1.4;font-weight:600;border-radius:999px;border:1px solid var(--card-border);color:var(--text-muted);background:var(--bg-card)}.magnetic-field-badge[data-level=weak]{color:var(--text-muted);border-color:var(--card-border)}.magnetic-field-badge[data-level=normal]{color:var(--accent);border-color:var(--accent)}.magnetic-field-badge[data-level=elevated]{color:var(--accent-orange);border-color:var(--accent-orange)}.magnetic-field-badge[data-level=interfered]{color:var(--text);background:var(--accent-orange);border-color:var(--accent-orange)}.actions{width:100%;max-width:360px}.btn{width:100%;min-height:48px;padding:var(--space-4) var(--space-6);font-size:var(--text-md);font-weight:600;font-family:inherit;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-default),transform var(--motion-fast)}.btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(180deg,color-mix(in srgb,var(--accent-orange-hover) 88%,white) 0%,var(--accent-orange) 48%,color-mix(in srgb,var(--accent-orange) 75%,black) 100%);color:var(--text);border:1px solid color-mix(in srgb,var(--accent-orange) 55%,transparent);border-radius:var(--radius-lg);box-shadow:0 4px color-mix(in srgb,var(--accent-orange) 35%,black),0 8px 32px color-mix(in srgb,var(--accent-orange) 42%,transparent)}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,var(--accent-orange-hover) 0%,color-mix(in srgb,var(--accent-orange-hover) 90%,black) 100%);border-color:color-mix(in srgb,var(--accent-orange-hover) 55%,transparent);box-shadow:0 4px color-mix(in srgb,var(--accent-orange-hover) 38%,black),0 12px 40px color-mix(in srgb,var(--accent-orange-hover) 48%,transparent)}.btn-primary:focus-visible:not(:disabled){outline:2px solid var(--ring);outline-offset:2px}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;background:var(--accent-orange);border-color:color-mix(in srgb,var(--accent-orange) 45%,transparent)}.guide{width:100%;max-width:360px;margin-top:var(--space-2)}.guide-header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1rem}.guide-logo{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.8}.guide-title{font-size:var(--text-md);font-weight:600;color:var(--text-muted);margin:0;text-align:center}.guide-lead{font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--text-muted)}.guide-items{display:flex;flex-direction:column;gap:var(--space-4)}.guide-item{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);border:1px solid var(--card-border);box-shadow:var(--shadow-hud-inset)}.guide-item--bubble{background:transparent;border:none;padding:0;box-shadow:none}.guide-bubble-row{display:flex;flex-direction:row;align-items:flex-end;gap:.35rem;width:100%}.guide-bubble-chara{width:52px;height:52px;object-fit:contain;flex-shrink:0}.guide-bubble{position:relative;flex:1;min-width:0;padding:.75rem .95rem .85rem;background:var(--bg-card);border-radius:14px;border:1px solid var(--card-border);box-shadow:0 2px 12px #0000001f}.guide-bubble:before{content:"";position:absolute;left:-7px;bottom:18px;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:9px solid rgba(255,255,255,.12)}.guide-bubble:after{content:"";position:absolute;left:-5px;bottom:19px;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:8px solid var(--bg-card)}.guide-item--main .guide-bubble{border-color:var(--border-brand);background:#ffffff0a}.guide-item--main .guide-bubble:after{border-right-color:#ffffff0a}.guide-bubble-name{display:block;font-size:.8rem;font-weight:600;color:var(--accent);margin-bottom:.2rem}.guide-bubble-role{font-size:.7rem;font-weight:400;color:var(--text-muted)}.guide-bubble p{margin:.45rem 0 0;font-size:.8rem;line-height:1.55;color:var(--text)}.guide-bubble p:first-of-type{margin-top:.15rem}.guide-summary{margin-top:1.25rem}.guide-summary--bubble{padding:0;background:transparent;border:none}.guide-bubble--summary{border-color:var(--card-border);background:var(--bg-veil)}.guide-summary--bubble .guide-bubble--summary:after{border-right-color:var(--bg-veil)}.guide-extra{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--bg-veil)}.guide-extra-summary{cursor:pointer;font-size:var(--text-xs);font-weight:600;color:var(--text-muted);list-style:none}.guide-extra-summary::-webkit-details-marker{display:none}.guide-extra-summary:after{content:" ▼";font-size:.65rem;opacity:.75}.guide-extra[open] .guide-extra-summary:after{content:" ▲"}.guide-extra-body{margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--divider)}.guide-extra-lead{margin:0 0 var(--space-3);font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--text-muted)}.metronome-pendulum{position:relative;width:min(100%,220px);height:clamp(88px,22vw,120px);margin:0 auto var(--space-4);border-radius:var(--radius-md);border:1px solid var(--card-border);background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-veil) 100%);overflow:hidden}.metronome-pendulum__scale{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.35;background:radial-gradient(circle at 50% 10%,var(--accent) 0 1px,transparent 2px),linear-gradient(90deg,transparent 49.5%,var(--divider) 49.5%,var(--divider) 50.5%,transparent 50.5%);pointer-events:none}.metronome-pendulum__pivot{position:absolute;left:50%;top:10%;width:10px;height:10px;margin-left:-5px;border-radius:50%;background:var(--text-muted);box-shadow:0 0 0 2px var(--bg-veil);z-index:2}.metronome-pendulum__arm{position:absolute;left:50%;top:10%;width:4px;margin-left:-2px;height:78%;transform-origin:50% 0;transform:rotate(0);z-index:1;will-change:transform}.metronome-pendulum__rod{display:block;width:100%;height:calc(100% - 14px);margin:0 auto;border-radius:2px;background:linear-gradient(180deg,var(--text-muted),var(--accent));opacity:.9}.metronome-pendulum__bob{display:block;width:18px;height:18px;margin:-2px auto 0;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--accent-soft),var(--accent));border:1px solid var(--border-brand);box-shadow:0 2px 6px #00000040}.metronome-pendulum--active .metronome-pendulum__arm{transition:none}.metronome-pendulum:not(.metronome-pendulum--active) .metronome-pendulum__arm{transition:transform .25s ease-out}.metronome-pendulum__bob--flash{animation:metronome-bob-flash 95ms ease-out}@keyframes metronome-bob-flash{0%{filter:brightness(1.35);box-shadow:0 0 0 0 var(--accent)}to{filter:brightness(1);box-shadow:0 0 0 0 transparent}}@media (prefers-reduced-motion: reduce){.metronome-pendulum__bob--flash{animation:none}}.metronome-row--actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:stretch}.metronome-row--actions .btn-metronome{flex:1 1 140px}.btn-metronome--secondary{border-color:var(--card-border);background:var(--bg-elevated);color:var(--text-muted)}.btn-metronome--secondary:hover:not(:disabled){color:var(--text);border-color:var(--border-brand)}.metronome-sample-credit{margin:.35rem 0 0;font-size:.68rem;line-height:var(--leading-snug);color:var(--text-muted)}.metronome-sample-credit a{color:inherit;text-decoration:underline;text-underline-offset:2px}.metronome-sample-credit a:hover{color:var(--text)}.metronome-kbd-hint{margin:0;font-size:.65rem;line-height:var(--leading-snug);color:var(--text-muted)}.metronome-row--grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}@media (max-width: 380px){.metronome-row--grid{grid-template-columns:1fr}}.metronome-field{display:flex;flex-direction:column;gap:var(--space-2);min-width:0}.metronome-field--full{grid-column:1 / -1}.metronome-select{width:100%;min-height:44px;padding:.4rem .5rem;font-size:var(--text-xs);font-weight:500;color:var(--text);border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--bg-elevated);cursor:pointer}.metronome-select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.metronome-controls{display:flex;flex-direction:column;gap:var(--space-3)}.metronome-vol{display:flex;flex-direction:column;gap:var(--space-2)}.btn-metronome{min-height:44px;padding:.65rem 1rem;font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-md);border:1px solid var(--border-brand);background:var(--accent-soft);color:var(--text);cursor:pointer;transition:opacity var(--motion-fast),transform .08s}.btn-metronome:hover:not(:disabled){opacity:.95}.btn-metronome:active:not(:disabled){transform:scale(.98)}.btn-metronome:disabled{opacity:.45;cursor:not-allowed}.metronome-bpm{display:flex;flex-direction:column;gap:var(--space-2)}.metronome-bpm-label{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-muted)}.metronome-bpm-value{font-variant-numeric:tabular-nums;color:var(--accent);font-weight:600}.metronome-range{width:100%;accent-color:var(--accent);min-height:2rem}.app-stores{margin:var(--space-12) auto var(--space-4);padding:var(--space-6) var(--space-4);max-width:640px;text-align:center;border-top:1px solid var(--divider);border-bottom:1px solid var(--divider)}.app-stores-title{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:600;color:var(--text);letter-spacing:.01em}.app-stores-lead{margin:0 auto var(--space-5);max-width:36rem;font-size:var(--text-sm);line-height:var(--leading-snug);color:var(--text-muted)}.app-stores-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-3)}.app-store-link{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.15rem;min-width:11rem;padding:.65rem 1.1rem;text-align:left;text-decoration:none;background:var(--bg-card);border:1px solid var(--card-border);border-radius:.6rem;color:var(--text);transition:border-color .18s ease,color .18s ease,transform .18s ease}.app-store-link:hover,.app-store-link:focus-visible{border-color:var(--border-brand);color:var(--accent);transform:translateY(-1px)}.app-store-link:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.app-store-link__platform{font-size:var(--text-xs);color:var(--text-faint);letter-spacing:.04em;text-transform:none}.app-store-link__name{font-size:var(--text-md);font-weight:600}@media (min-width: 768px){.app-stores-buttons{gap:var(--space-4)}}.footer{margin-top:auto;padding:var(--space-8) var(--space-4) var(--space-6);text-align:center;font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);border-top:1px solid var(--divider)}.footer-actions{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.5rem}.hamburger--footer{width:40px;height:40px}.footer-share{margin-bottom:0}.share-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border-radius:50%;transition:opacity .2s,transform .1s}.share-btn:hover{opacity:.9;transform:scale(1.05)}.share-icon{width:40px;height:40px;object-fit:contain}.footer-logo{height:24px;width:auto;max-width:100px;object-fit:contain;filter:brightness(0) invert(1);opacity:.6}.footer p{margin:0}.footer-credit{margin-top:.5rem!important;font-size:.7rem;color:var(--text-muted);opacity:.9}.footer-links{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;font-size:.75rem}.footer-links a{color:var(--text-muted);text-decoration:none}.footer-links a:hover{color:var(--accent)}.footer-sep{color:var(--text-muted);opacity:.5}@media (min-width: 600px){.header-logo{height:40px;max-width:180px}.section-logo--ginga{width:48px}.compass-container{width:320px}.guide{max-width:420px}.guide-logo{height:32px}.guide-bubble-chara{width:56px;height:56px}.guide-bubble p{font-size:.85rem}.main{padding:2rem}}@media (min-width: 900px){.app{background:var(--bg)}.header-logo{height:44px;max-width:200px}.main{flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:2rem;padding:2rem;max-width:1000px;margin:0 auto}.location-first-view{order:0;flex:1 1 100%;max-width:720px;width:100%}.bearing-hud{order:1;flex:1 1 100%;width:100%;max-width:720px}.compass-section{order:2;flex:0 0 auto}.compass-container{width:280px}.main-right{order:3;flex:0 0 320px;max-width:none}.guide{order:5;flex:1 1 100%;max-width:720px;margin:.5rem auto 0}.guide-items{gap:1.35rem}.guide-bubble-chara{width:64px;height:64px}.guide-summary{margin-top:1.5rem}.guide-bubble p{font-size:.9rem;line-height:1.6}.footer-logo{height:28px;opacity:.7}}
