:root{--color-luck-5: #00c853;--color-luck-4: #00c2cc;--color-luck-3: #fbbf24;--color-luck-2: #f97316;--color-luck-1: #ba1a1a;--color-bg: #f8fafc;--color-surface-lowest: #ffffff;--color-surface-low: #f1f5f9;--color-surface: #e2e8f0;--color-surface-high: #cbd5e1;--color-surface-highest: #94a3b8;--color-on-surface: #0f172a;--color-on-surface-variant: #475569;--color-outline: #64748b;--color-outline-variant: #cbd5e1;--color-text: var(--color-on-surface);--color-muted: var(--color-on-surface-variant);--color-border: var(--color-outline-variant);--color-primary: #4f46e5;--color-primary-container: #e0e7ff;--color-on-primary: #ffffff;--color-secondary: #0ea5e9;--color-secondary-container: #e0f2fe;--color-on-secondary: #ffffff;--color-tertiary: #ec4899;--color-tertiary-container: #fce7f3;--color-on-tertiary: #ffffff;--color-error: #dc2626;--color-surface-tint: #6366f1;--glass-bg: rgba(255, 255, 255, .72);--glass-bg-dark: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .55);--glass-blur: 18px;--glass-shadow: 0 4px 28px rgba(0, 0, 0, .06), inset 0 1px 0 rgba(255, 255, 255, .9);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: .25rem;--radius-md: .75rem;--radius-lg: 1.25rem;--radius-xl: 1.5rem;--radius-full: 9999px;--font-sans: "Manrope", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-4xl: 2rem;--text-6xl: 3rem;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--leading-tight: 1.1;--leading-snug: 1.3;--leading-normal: 1.6;--tracking-tight: -.04em;--tracking-wide: .06em;--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .6s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--bp-sm: 480px;--bp-md: 768px;--bp-lg: 1024px}[data-theme=dark]{--color-bg: #0f172a;--color-surface-lowest: #020617;--color-surface-low: #0f172a;--color-surface: #1e293b;--color-surface-high: #334155;--color-surface-highest: #475569;--color-on-surface: #f8fafc;--color-on-surface-variant: #94a3b8;--color-outline: #64748b;--color-outline-variant: #334155;--color-text: var(--color-on-surface);--color-muted: var(--color-on-surface-variant);--color-border: var(--color-outline-variant);--color-primary: #818cf8;--color-primary-container: #4f46e5;--color-secondary: #38bdf8;--color-secondary-container: #0284c7;--color-surface-tint: #818cf8;--glass-bg: rgba(30, 32, 36, .8);--glass-border: rgba(255, 255, 255, .07);--glass-shadow: 0 4px 28px rgba(0, 0, 0, .45), inset 0 1px 0 rgba(255, 255, 255, .05)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);font-size:var(--text-base);background-color:var(--color-bg);color:var(--color-text);line-height:var(--leading-normal)}body{min-height:100vh}.skip-link{position:absolute;top:-100px;left:var(--space-md);background:var(--color-surface);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);z-index:100;color:var(--color-text);text-decoration:none;font-weight:600}.skip-link:focus{top:var(--space-md)}:root{--header-height: 60px;--side-nav-width: 280px}.app-shell{display:grid;grid-template-rows:var(--header-height) 1fr;min-height:100dvh}.app-body{margin:var(--header-height) 0 0 var(--side-nav-width);display:flex;align-items:start;min-height:calc(100dvh - var(--header-height))}.side-panel{position:fixed;top:var(--header-height);height:calc(100dvh - var(--header-height));width:var(--side-nav-width);overflow-y:auto;scrollbar-width:thin;padding:var(--space-xl) var(--space-lg);border-right:1px solid var(--color-outline-variant);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));display:flex;flex-direction:column;gap:var(--space-lg)}.panel-section{display:flex;flex-direction:column;gap:var(--space-lg)}.panel-section-label{font-size:var(--text-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-muted)}.panel-divider{border:none;border-top:1px solid var(--color-outline-variant);margin:0}.panel-toggle{display:none;align-items:center;justify-content:center;background:none;border:1px solid var(--color-outline-variant);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;min-height:44px;min-width:44px;padding:var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out)}.panel-toggle:hover{border-color:var(--color-primary-container);background:var(--color-surface-low)}.panel-overlay{display:none;position:fixed;inset:0;background:#0b0b1480;z-index:49;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.panel-overlay.active{display:block}.content-area{padding:var(--space-xl) var(--space-2xl);min-width:100%;display:grid;gap:var(--space-xl);align-content:start;min-height:calc(100dvh - var(--header-height));grid-template-rows:1fr auto}#today-view,#range-view{display:grid;gap:var(--space-lg)}[hidden]{display:none!important}.mobile-view-tabs{display:none;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-outline-variant);position:sticky;top:var(--header-height);z-index:20}.mobile-view-tabs button{background:none;border:none;border-radius:var(--radius-md);color:var(--color-muted);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--fw-medium);min-height:36px;padding:var(--space-xs) var(--space-md);transition:all var(--duration-fast) var(--ease-out)}.mobile-view-tabs button[aria-selected=true]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-container) 100%);color:var(--color-on-primary);font-weight:var(--fw-semibold)}.site-footer{border-top:1px solid var(--color-outline-variant);color:var(--color-muted);font-size:var(--text-sm);padding:var(--space-xl) 0;text-align:center}.site-footer a{color:var(--color-primary);text-decoration:none;font-weight:var(--fw-medium)}.disclaimer{margin-top:var(--space-xs);font-style:italic}.site-header{grid-area:header;display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--space-xl);position:fixed;width:100%;top:0;z-index:40;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--glass-bg);border-bottom:1px solid var(--color-outline-variant);transition:background var(--duration-normal) var(--ease-out)}[data-theme=dark] .site-header{background:#1e1b2ecc;border-bottom-color:#4a445699}.site-logo{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-xl);font-weight:var(--fw-extrabold);text-decoration:none;color:var(--color-on-surface);letter-spacing:var(--tracking-tight)}.site-logo-text{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.site-logo-icon{flex-shrink:0}.header-start{display:flex;align-items:center;gap:var(--space-sm)}.controls{display:flex;flex-direction:column;gap:var(--space-md)}@media(max-width:768px){.controls{flex-direction:column}.pill-group{flex-wrap:wrap}}.control-group{display:flex;flex-direction:column;gap:var(--space-sm)}.control-group label,.control-group legend{font-size:var(--text-sm);color:var(--color-muted);font-weight:500}.select-wrapper{position:relative}.select-wrapper select{appearance:none;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-outline-variant);border-radius:var(--radius-md);color:var(--color-text);padding:var(--space-sm) var(--space-lg) var(--space-sm) var(--space-sm);font-size:var(--text-sm);font-family:var(--font-sans);font-weight:var(--fw-medium);cursor:pointer;width:100%;transition:border-color var(--duration-fast) var(--ease-out)}.select-wrapper select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e533}.select-wrapper select:hover{border-color:var(--color-outline);background:var(--color-surface-low)}.select-wrapper:after{content:"▾";position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--color-muted)}fieldset{border:none}.pill-group{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.pill{background:var(--glass-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--color-outline-variant);border-radius:var(--radius-full);color:var(--color-text);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-sans);font-weight:var(--fw-medium);min-height:44px;min-width:44px;padding:var(--space-sm) var(--space-md);position:relative;overflow:hidden;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.pill[aria-pressed=true],.pill.active{background:var(--color-primary);border-color:transparent;color:var(--color-on-primary);font-weight:var(--fw-semibold);box-shadow:0 2px 8px #4f46e54d}.pill:hover{border-color:var(--color-primary);background:var(--color-surface);color:var(--color-text)}.pill:hover:not([aria-pressed=true]){background:var(--color-surface);color:var(--color-text)}.view-toggle{display:flex;gap:var(--space-xs);background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-outline-variant);border-radius:var(--radius-lg);padding:var(--space-xs)}.view-toggle button{background:none;border:none;border-radius:var(--radius-md);color:var(--color-muted);cursor:pointer;flex:1;font-size:var(--text-sm);min-height:40px;padding:var(--space-sm) var(--space-md);transition:all var(--duration-fast) var(--ease-out)}.view-toggle button[aria-selected=true]{background:var(--color-primary);color:var(--color-on-primary);font-weight:var(--fw-semibold);box-shadow:0 2px 8px #4f46e54d}.luck-score{display:flex;gap:var(--space-xl);align-items:center;flex-wrap:wrap;padding:var(--space-lg);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow)}.score-ring{position:relative;width:200px;height:200px;flex-shrink:0}.score-ring svg{width:100%;height:100%}.score-ring .track{fill:none;stroke:var(--color-surface-low);stroke-width:8}.score-ring .fill{fill:none;stroke:var(--color-luck-3);stroke-width:8;stroke-linecap:round;transform:rotate(-90deg);transform-origin:center}.score-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs)}.score-number{font-size:var(--text-4xl);font-weight:var(--fw-extrabold);line-height:1;letter-spacing:var(--tracking-tight)}.score-emoji{font-size:var(--text-xl)}.score-meta{display:flex;flex-direction:column;gap:var(--space-sm)}.score-label{font-size:var(--text-2xl);font-weight:var(--fw-extrabold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight)}.score-rating{font-size:var(--text-lg)}.score-tip{color:var(--color-muted);font-size:var(--text-sm)}.score-flavor{color:var(--color-muted);font-size:var(--text-sm);font-style:italic}@media(max-width:480px){.score-ring{width:140px;height:140px}.luck-score{flex-direction:column;align-items:flex-start}}.pulse-glow{animation:pulseGlow 2s ease-in-out infinite}.best-time-strip{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);padding:var(--space-lg);transition:opacity .25s ease,transform .25s ease}#today-view.is-loading .best-time-strip{opacity:.3;transform:translateY(4px);pointer-events:none}.best-time-strip h3{font-size:var(--text-lg);font-weight:var(--fw-bold);margin-bottom:var(--space-md);letter-spacing:var(--tracking-tight)}.time-slots{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.time-slot{display:flex;gap:var(--space-md);align-items:center;padding:var(--space-sm) var(--space-md);background:var(--color-surface-lowest);border:1px solid var(--color-outline-variant);border-radius:var(--radius-md);font-size:var(--text-sm);transition:background var(--duration-fast) var(--ease-out)}[data-theme=dark] .time-slot{background:var(--color-surface-low);border-color:var(--color-outline-variant)}.time-slot:hover{background:var(--color-surface-low)}.slot-time{font-family:var(--font-mono);font-weight:600;min-width:120px}.slot-score{color:var(--color-text);font-weight:var(--fw-bold);margin-left:auto}.slot-label{color:var(--color-text);font-weight:var(--fw-medium)}.slot-rank{font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--color-muted);min-width:1.5rem;text-align:center}.slot-rank-badge{font-size:var(--text-xs);font-weight:var(--fw-bold);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-container) 100%);color:var(--color-on-primary);border-radius:var(--radius-full);padding:2px var(--space-sm);white-space:nowrap;letter-spacing:.03em}.time-slot--top{background:#4f46e50f;border-color:#4f46e533}[data-theme=dark] .time-slot--top{background:#4f46e51f;border-color:#4f46e566}.rating-stars{display:inline-flex;align-items:center;gap:2px}.rating-star--filled{color:var(--color-luck-3)}.rating-star--empty{color:var(--color-outline)}.time-slot--empty{color:var(--color-muted)}.time-slot[data-rating="5"]{border-left:3px solid var(--color-luck-5)}.time-slot[data-rating="4"]{border-left:3px solid var(--color-luck-4)}.time-slot[data-rating="3"]{border-left:3px solid var(--color-luck-3)}.time-slot[data-rating="2"]{border-left:3px solid var(--color-luck-2)}.time-slot[data-rating="1"]{border-left:3px solid var(--color-luck-1)}.telemetry-panel{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);overflow:hidden;transition:opacity .25s ease,transform .25s ease}#today-view.is-loading .telemetry-panel{opacity:.3;transform:translateY(4px);pointer-events:none}.telemetry-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-outline-variant)}.telemetry-title{font-size:var(--text-sm);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-muted)}.telemetry-overall{font-size:var(--text-sm);color:var(--color-muted)}.telemetry-overall strong{color:var(--color-primary);font-size:var(--text-lg);font-weight:var(--fw-extrabold);letter-spacing:var(--tracking-tight);font-family:var(--font-mono)}.telemetry-list{list-style:none;padding:0;margin:0}.telemetry-row{border-top:1px solid var(--color-outline-variant)}.telemetry-row:first-child{border-top:none}.telemetry-summary{display:grid;grid-template-columns:1.25rem 1.5rem 10rem 1fr 3.5rem 9rem;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);background:none;border:none;cursor:pointer;font-family:var(--font-sans);text-align:left;transition:background var(--duration-fast) var(--ease-out);min-height:52px}.telemetry-summary:hover{background:#640ce608}.telemetry-summary[aria-expanded=true]{background:#640ce60a}.telemetry-chevron{color:var(--color-muted);flex-shrink:0;transition:transform var(--duration-fast) var(--ease-out)}.telemetry-summary[aria-expanded=true] .telemetry-chevron{transform:rotate(90deg)}.telemetry-icon{color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg)}.telemetry-name{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.telemetry-bar-track{height:6px;background:var(--color-surface-low);border-radius:var(--radius-full);overflow:hidden}.telemetry-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out)}.telemetry-score{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-primary);text-align:right;white-space:nowrap}.telemetry-label{font-size:var(--text-sm);color:var(--color-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-left:var(--space-xs)}.telemetry-body{overflow:hidden;max-height:0;transition:max-height var(--duration-slow) var(--ease-out)}.telemetry-body-inner{padding:var(--space-md) var(--space-lg) var(--space-lg);background:#640ce605;border-top:1px solid var(--color-outline-variant)}[data-theme=dark] .telemetry-body-inner{background:#ffffff08}.telemetry-explanation{font-size:var(--text-sm);color:var(--color-muted);line-height:var(--leading-normal);margin-bottom:var(--space-md)}.telemetry-about-toggle{background:none;border:1px solid var(--color-outline-variant);border-radius:var(--radius-md);color:var(--color-muted);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--fw-medium);padding:var(--space-xs) var(--space-sm);transition:all var(--duration-fast) var(--ease-out)}.telemetry-about-toggle:hover{color:var(--color-text);border-color:var(--color-primary-container)}.telemetry-about-body{overflow:hidden;max-height:0;transition:max-height var(--duration-slow) var(--ease-out);font-size:var(--text-sm);color:var(--color-muted);line-height:var(--leading-normal);padding-top:0}.telemetry-skeleton{margin:0;padding:var(--space-md) var(--space-lg);height:52px;background:linear-gradient(90deg,var(--color-surface) 0%,var(--color-surface-high) 50%,var(--color-surface) 100%);background-size:200% auto}[data-skeleton] .telemetry-skeleton{animation:shimmer 1.4s linear infinite}.score-color-1{background:var(--color-luck-1)}.score-color-2{background:var(--color-luck-2)}.score-color-3{background:var(--color-luck-3)}.score-color-4{background:var(--color-luck-4)}.score-color-5{background:var(--color-luck-5)}.heatmap-wrapper{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);overflow:visible;padding:var(--space-lg)}.heatmap-skeleton{display:none;height:300px;background:var(--color-surface);border-radius:var(--radius-md);animation:pulseGlow 1.5s infinite}.heatmap-skeleton-inner{padding:2rem;text-align:center;color:var(--color-muted);font-family:var(--font-mono);font-size:var(--text-sm);height:100%;display:flex;align-items:center;justify-content:center}.heatmap-wrapper.is-loading .heatmap-skeleton{display:block}.heatmap-wrapper.is-loading .heatmap-table{visibility:hidden}.heatmap-legend{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-md)}.heatmap-legend span{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--fw-semibold);padding:3px var(--space-sm);color:#0f172a;border:1px solid rgba(0,0,0,.1);backdrop-filter:blur(4px)}.heatmap-legend span[data-tier=luck-5]{background:var(--color-luck-5)}.heatmap-legend span[data-tier=luck-4]{background:var(--color-luck-4)}.heatmap-legend span[data-tier=luck-3]{background:var(--color-luck-3)}.heatmap-legend span[data-tier=luck-2]{background:var(--color-luck-2)}.heatmap-legend span[data-tier=luck-1]{background:var(--color-luck-1);color:#fff}.heatmap-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.heatmap-table{border-collapse:collapse;border-spacing:0;width:100%}.heatmap-table th{font-size:var(--text-sm);color:var(--color-muted);padding:var(--space-xs) var(--space-sm);white-space:nowrap;font-weight:var(--fw-medium)}.heatmap-date-col{width:1%;white-space:nowrap}.heatmap-cell{width:36px;height:36px;border:1px solid var(--color-surface);border-radius:0;cursor:pointer;opacity:0;transform:scale(.8);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out);position:relative}.heatmap-cell-score{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:var(--fw-bold);color:#ffffffd9;line-height:1;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.3)}.heatmap-cell[data-rating="3"] .heatmap-cell-score,.heatmap-cell[data-rating="4"] .heatmap-cell-score,.heatmap-cell[data-rating="5"] .heatmap-cell-score{color:#000000b3;text-shadow:none}.heatmap-cell.visible{opacity:1;transform:scale(1)}.heatmap-cell:hover{transform:scale(1.2);z-index:1}.heatmap-cell[data-rating="5"]{background-color:var(--color-luck-5)}.heatmap-cell[data-rating="4"]{background-color:var(--color-luck-4)}.heatmap-cell[data-rating="3"]{background-color:var(--color-luck-3)}.heatmap-cell[data-rating="2"]{background-color:var(--color-luck-2)}.heatmap-cell[data-rating="1"]{background-color:var(--color-luck-1)}.heatmap-cell[data-rating="5"]:not(:hover){box-shadow:inset 0 0 0 1px #ffffff59,0 0 6px #00c85340}.heatmap-cell[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--glass-shadow);padding:var(--space-xs) var(--space-sm);white-space:pre;font-size:var(--text-xs);pointer-events:none;z-index:10;min-width:180px;color:var(--color-text)}.heatmap-mobile{display:none;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}.heatmap-mobile-card{border:1px solid var(--color-outline-variant);border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface-lowest)}.heatmap-mobile-card[data-rating="5"]{border-left:3px solid var(--color-luck-5)}.heatmap-mobile-card[data-rating="4"]{border-left:3px solid var(--color-luck-4)}.heatmap-mobile-card[data-rating="3"]{border-left:3px solid var(--color-luck-3)}.heatmap-mobile-card[data-rating="2"]{border-left:3px solid var(--color-luck-2)}.heatmap-mobile-card[data-rating="1"]{border-left:3px solid var(--color-luck-1)}.heatmap-mobile-card-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);width:100%;background:none;border:none;cursor:pointer;font-family:var(--font-sans);color:var(--color-text);text-align:left;min-height:56px;transition:background var(--duration-fast) var(--ease-out)}.heatmap-mobile-card-header:hover{background:var(--color-surface-low)}.heatmap-mobile-card-date{display:flex;flex-direction:column;align-items:center;min-width:36px;flex-shrink:0}.heatmap-mobile-day{font-size:var(--text-xs);color:var(--color-muted);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em}.heatmap-mobile-date-num{font-size:var(--text-xl);font-weight:var(--fw-extrabold);line-height:1}.heatmap-mobile-month{font-size:var(--text-xs);color:var(--color-muted);font-weight:var(--fw-medium)}.heatmap-mobile-card-info{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.heatmap-mobile-best-label{font-size:var(--text-xs);color:var(--color-muted);font-weight:var(--fw-medium)}.heatmap-mobile-best-time{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--fw-semibold)}.heatmap-mobile-avg{font-size:var(--text-xs);color:var(--color-muted)}.heatmap-mobile-card-score{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:var(--fw-extrabold);min-width:2.5rem;text-align:right;flex-shrink:0}.heatmap-mobile-chevron{flex-shrink:0;color:var(--color-muted);transition:transform var(--duration-fast) var(--ease-out)}.heatmap-mobile-chevron.rotated{transform:rotate(180deg)}.heatmap-mobile-card-slots{border-top:1px solid var(--color-outline-variant);padding:var(--space-sm) var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.heatmap-mobile-slot{display:grid;grid-template-columns:3rem 1fr auto 5rem;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0}.heatmap-mobile-slot-time{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);font-weight:var(--fw-medium)}.heatmap-mobile-slot-bar{height:6px;background:var(--color-surface-highest);border-radius:var(--radius-full);overflow:hidden}.heatmap-mobile-slot-fill{display:block;height:100%;border-radius:var(--radius-full)}.heatmap-mobile-slot-score{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--color-primary);min-width:2rem;text-align:right}.heatmap-mobile-slot-label{font-size:var(--text-xs);color:var(--color-muted);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.heatmap-day-cell{aspect-ratio:1;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:var(--fw-semibold);color:#ffffffe6;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out);position:relative}.heatmap-day-cell:hover{transform:scale(1.1);z-index:1}.heatmap-day-cell[data-rating="5"]{background:var(--color-luck-5);color:#0f172a}.heatmap-day-cell[data-rating="4"]{background:var(--color-luck-4);color:#0f172a}.heatmap-day-cell[data-rating="3"]{background:var(--color-luck-3);color:#0f172a}.heatmap-day-cell[data-rating="2"]{background:var(--color-luck-2)}.heatmap-day-cell[data-rating="1"]{background:var(--color-luck-1)}.heatmap-day-cell.empty{background:var(--color-surface-high);color:var(--color-muted)}.best-slot-banner{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);transition:opacity .25s ease,transform .25s ease}.best-slot-banner-inner{display:flex;align-items:center;gap:var(--space-md);background:transparent;border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg)}.banner-icon{width:52px;height:52px;border-radius:var(--radius-md);background:var(--color-surface-low);border:1px solid var(--color-outline-variant);display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-size:var(--text-xl);flex-shrink:0}.banner-content{flex:1;min-width:0}.banner-label{font-size:var(--text-sm);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-primary);margin-bottom:var(--space-xs)}#range-view.is-loading .best-slot-banner{opacity:.3;transform:translateY(4px);pointer-events:none}.banner-slot{font-weight:var(--fw-extrabold);font-size:var(--text-xl);letter-spacing:var(--tracking-tight);line-height:var(--leading-snug)}.banner-score{font-family:var(--font-mono);color:var(--color-luck-5);font-weight:var(--fw-bold);font-size:var(--text-base);margin-top:var(--space-xs)}.date-range-picker{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:flex-end;padding:var(--space-md);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow)}.date-input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.date-input-group label{font-size:var(--text-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-muted);display:flex;align-items:center;gap:var(--space-xs)}.date-input-group input[type=date]{appearance:none;background:var(--color-surface-lowest);border:1px solid var(--color-outline-variant);border-radius:var(--radius-md);color:var(--color-text);padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);font-family:var(--font-sans);min-height:44px;transition:border-color var(--duration-fast) var(--ease-out)}[data-theme=dark] .date-input-group input[type=date]{background:var(--color-surface-low)}.date-input-group input[type=date]:focus{outline:none;border-color:var(--color-secondary-container);box-shadow:0 0 0 3px #00c2cc26}.range-error{color:var(--color-luck-1);font-size:var(--text-sm);width:100%}.share-btn{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:none;border-radius:var(--radius-md);color:var(--color-on-primary);cursor:pointer;display:flex;font-size:var(--text-sm);font-family:var(--font-sans);font-weight:var(--fw-semibold);gap:var(--space-xs);min-height:44px;min-width:44px;padding:var(--space-sm) var(--space-md);position:relative;overflow:hidden;box-shadow:0 2px 16px #640ce647;transition:box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.share-btn:hover{box-shadow:0 4px 24px #640ce666;transform:translateY(-1px)}.share-toast{background:var(--color-luck-5);border-radius:var(--radius-md);color:#0f172a;font-size:var(--text-sm);font-weight:600;padding:var(--space-sm) var(--space-md);position:fixed;bottom:var(--space-xl);left:50%;transform:translate(-50%);z-index:50;animation:fadeIn var(--duration-fast) var(--ease-out)}#theme-toggle{background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-size:var(--text-base);padding:var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out)}#theme-toggle:hover{border-color:var(--color-primary-container);background:var(--color-surface-low)}.pill,.expand-btn{position:relative;overflow:hidden}.ripple{position:absolute;border-radius:50%;background:#ffffff40;animation:ripple-anim .6s ease-out forwards;pointer-events:none}::view-transition-old(root),::view-transition-new(root){animation-duration:var(--duration-normal);animation-timing-function:var(--ease-out)}::view-transition-old(root){animation-name:fade-out}::view-transition-new(root){animation-name:fade-in}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #7d3cff00}50%{box-shadow:0 0 0 10px #7d3cff26}}@keyframes ripple-anim{0%{transform:scale(0);opacity:1}to{transform:scale(2.5);opacity:0}}.cosmos-loader{display:none;flex-direction:column;align-items:center;gap:var(--space-sm);position:absolute;inset:0;justify-content:center;pointer-events:none}.is-loading .cosmos-loader{display:flex;pointer-events:auto}.is-loading .score-number,.is-loading .score-emoji{opacity:0;transition:opacity .15s ease}.is-updating{opacity:.55;pointer-events:none;transition:opacity .2s var(--ease-out)}.orbit-rings{position:relative;width:64px;height:64px}.orbit-ring{position:absolute;border:2px solid transparent;border-radius:50%}.orbit-ring--a{inset:0;border-top-color:var(--color-primary);animation:orbit-a 1.2s linear infinite}.orbit-ring--b{inset:10px;border-top-color:var(--color-secondary-container);animation:orbit-b 1.8s linear infinite}.orbit-ring--c{inset:20px;border-top-color:var(--color-tertiary-container);animation:orbit-a 2.6s linear infinite}.cosmos-phase-text{font-size:var(--text-xs);color:var(--color-muted);letter-spacing:var(--tracking-wide);text-transform:uppercase;animation:cosmos-pulse .6s ease-in-out infinite;text-align:center;max-width:160px}.is-loading .score-meta{opacity:.25;transition:opacity .15s ease}.score-high{animation:goldGlow 2s ease-in-out infinite}@keyframes orbit-a{to{transform:rotate(360deg)}}@keyframes orbit-b{to{transform:rotate(-360deg)}}@keyframes cosmos-pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes shimmer{to{background-position:200% center}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes goldGlow{0%,to{box-shadow:0 0 #00c2cc00}50%{box-shadow:0 0 0 12px #00c2cc33,0 0 0 4px #7d3cff26}}@media(max-width:1023px){.app-body{grid-template-columns:1fr}.panel-toggle,.mobile-view-tabs{display:flex}.side-panel{position:fixed;left:-280px;top:0;height:100dvh;width:280px;z-index:50;transition:left var(--duration-normal) var(--ease-out);box-shadow:4px 0 32px #0003}.side-panel.panel-open{left:0}.panel-overlay.active{display:block}.content-area{padding:var(--space-lg) var(--space-md)}.telemetry-summary{grid-template-columns:1.25rem 1.5rem 1fr 3.5rem 7rem}}@media(max-width:767px){.heatmap-desktop{display:none}.heatmap-mobile{display:flex}.score-ring{width:min(180px,60vw);height:min(180px,60vw)}.luck-score{flex-direction:column;align-items:stretch}.best-slot-banner{margin-top:var(--space-md)}}@media(max-width:479px){.telemetry-summary{grid-template-columns:1.25rem 1.5rem 1fr 3rem}.telemetry-label,.telemetry-bar-track{display:none}.site-header{padding:0 var(--space-md)}}@media(max-width:360px){.site-logo-text{display:none}.content-area{padding:var(--space-md) var(--space-sm)}}.mobile-intercept{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-xl);width:100vw;height:100vh}.mobile-intercept-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center;max-width:320px;background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);padding:var(--space-xl)}.mobile-intercept-icon{font-size:3rem;line-height:1}.mobile-intercept-title{font-size:var(--text-xl);font-weight:var(--fw-extrabold);color:var(--color-text);margin:0}.mobile-intercept-body{font-size:var(--text-sm);color:var(--color-text-secondary, var(--color-muted));margin:0;line-height:1.6}
