.toast-region{position:fixed;bottom:var(--space-md);right:var(--space-md);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-sm);max-width:360px;width:calc(100vw - 2 * var(--space-md));pointer-events:none}.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-card);box-shadow:var(--shadow-card-hover);pointer-events:all;animation:toast-in var(--duration-normal) var(--ease-out-expo) both}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast--info{background:var(--color-info-bg);color:var(--color-info-fg);border:1px solid oklch(from var(--color-info-fg) l c h / .25)}.toast--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid oklch(from var(--color-success) l c h / .25)}.toast--warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid oklch(from var(--color-warning) l c h / .25)}.toast--error{background:var(--color-error-bg);color:var(--color-error);border:1px solid oklch(from var(--color-error) l c h / .25)}.toast__body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.toast__title{font-size:var(--text-base);font-weight:700;line-height:1.3}.toast__description{font-size:var(--text-xs);opacity:.85;line-height:1.4;word-break:break-word}.toast__actions{display:flex;align-items:flex-start;gap:var(--space-xs);flex-shrink:0}.toast__action-btn{font-size:var(--text-xs);font-weight:700;padding:2px var(--space-xs);background:transparent;border:1.5px solid currentColor;border-radius:var(--radius-badge);cursor:pointer;color:inherit;transition:opacity var(--duration-fast);white-space:nowrap}.toast__action-btn:hover{opacity:.75}.toast__action-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.toast__close{font-size:1rem;line-height:1;background:transparent;border:none;cursor:pointer;color:inherit;opacity:.6;padding:0;transition:opacity var(--duration-fast);flex-shrink:0}.toast__close:hover{opacity:1}.toast__close:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:2px}.stale-badge{font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);letter-spacing:.02em;white-space:nowrap}.stale-badge--warning{color:var(--color-warning)}.stale-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--color-warning-bg);border-bottom:1px solid oklch(from var(--color-warning) l c h / .3);z-index:var(--z-banner);position:relative}.stale-banner__text{font-size:var(--text-xs);font-weight:600;color:#5b3b00;color:oklch(38% .14 75);flex:1}.stale-banner__text code{font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:.85em;background:#ffdfb4;background:oklch(92% .08 75);padding:1px 4px;border-radius:3px}.stale-banner__dismiss{font-size:1rem;line-height:1;background:transparent;border:none;cursor:pointer;color:#5b3b00;color:oklch(38% .14 75);opacity:.7;padding:0;transition:opacity var(--duration-fast);flex-shrink:0}.stale-banner__dismiss:hover{opacity:1}.stale-banner__dismiss:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:2px}.common-header{position:sticky;top:0;z-index:var(--z-header);height:var(--header-height);background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-card);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.common-header__inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:100%;max-width:var(--max-content-width);margin-inline:auto;padding-inline:var(--space-md);gap:var(--space-md)}.common-header__left{display:flex;align-items:center}.common-header__title-link{font-size:var(--text-lg);font-weight:800;letter-spacing:-.03em;color:var(--color-accent);text-decoration:none;transition:color var(--duration-fast) var(--ease-out-expo),opacity var(--duration-fast)}.common-header__title-link:hover{color:var(--color-accent-hover);opacity:.85}.common-header__title-link:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-badge)}.common-header__center{display:flex;align-items:center;justify-content:center}.common-header__right{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm)}.last-week-banner{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);background:var(--color-warning-bg);color:#694500;color:oklch(42% .16 75);border:1px solid oklch(82% .12 75);border-radius:var(--radius-card);font-size:var(--text-base);font-weight:500;line-height:1.5}.last-week-banner__icon{font-size:1.1em;flex-shrink:0}.last-week-banner__em{font-weight:700}.scrape-error-panel{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background:var(--color-error-bg);border:1.5px solid oklch(from var(--color-error) l c h / .3);border-radius:var(--radius-card);margin-block:var(--space-md)}.scrape-error-panel__main{font-size:var(--text-base);color:#800613;margin:0;line-height:1.55}.scrape-error-panel__hint{font-size:var(--text-xs);color:#963d3a;margin:0}.scrape-error-panel__details{font-size:var(--text-xs);color:var(--color-text-muted)}.scrape-error-panel__details-summary{cursor:pointer;font-weight:600;-webkit-user-select:none;-moz-user-select:none;user-select:none}.scrape-error-panel__code{display:block;margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-badge);font-family:ui-monospace,Cascadia Code,Fira Code,monospace;word-break:break-all}.scrape-error-panel__retry{align-self:flex-start;padding:var(--space-xs) var(--space-md);font-size:var(--text-xs);font-weight:700;color:var(--color-surface-raised);background:var(--color-error);border:none;border-radius:var(--radius-badge);cursor:pointer;transition:opacity var(--duration-fast)}.scrape-error-panel__retry:hover:not(:disabled){opacity:.85}.scrape-error-panel__retry:focus-visible{outline:none;box-shadow:var(--focus-ring)}.scrape-error-panel__retry:disabled{opacity:.55;cursor:not-allowed}.recommendation-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md);margin-top:var(--space-md)}.recommendation-card{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background:var(--color-surface-raised);border:1.5px solid oklch(78% .08 252);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:box-shadow var(--duration-normal) var(--ease-out-expo),transform var(--duration-normal) var(--ease-out-expo)}.recommendation-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.recommendation-card__header{display:flex;align-items:baseline;gap:var(--space-xs)}.recommendation-card__star{font-size:var(--text-lg);color:var(--color-warning);flex-shrink:0}.recommendation-card__horse-no{font-size:var(--text-xs);font-weight:700;color:var(--color-text-muted);letter-spacing:.05em;white-space:nowrap}.recommendation-card__horse-name{font-size:var(--text-lg);font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.recommendation-card__meta{display:flex;gap:var(--space-md);flex-wrap:wrap}.recommendation-card__meta-item{display:flex;flex-direction:column;gap:1px}.recommendation-card__meta-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;letter-spacing:.04em}.recommendation-card__meta-value{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.recommendation-card__meta-value--accent{color:var(--color-accent);font-size:var(--text-lg);font-weight:700}.recommendation-card__stats{display:flex;gap:var(--space-md);padding:var(--space-xs) var(--space-sm);background:#eaeff5;border-radius:var(--radius-badge)}.recommendation-card__stat{display:flex;flex-direction:column;align-items:center;gap:1px}.recommendation-card__stat-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;letter-spacing:.04em}.recommendation-card__stat-value{font-size:var(--text-base);font-weight:700;color:var(--color-text)}.recommendation-card__stake{display:flex;flex-direction:column;gap:2px;padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.recommendation-card__stake-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;letter-spacing:.04em}.recommendation-card__stake-amount{font-size:clamp(1.25rem,1rem + 1vw,1.5rem);font-weight:700;color:var(--color-success);letter-spacing:-.01em}.recommendation-card__stake-annotation{font-size:var(--text-xs);color:var(--color-text-muted)}.no-bet-message{padding:var(--space-lg);background:#f9f4ee;border:1.5px solid oklch(85% .05 75);border-radius:var(--radius-card);display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-md)}.no-bet-message__heading{font-size:var(--text-lg);font-weight:700;color:var(--color-warning);margin:0}.no-bet-message__body{font-size:var(--text-base);color:var(--color-text-muted);margin:0;line-height:1.7}.odds-timestamp{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-badge);flex-wrap:wrap}.odds-timestamp__info{display:flex;align-items:baseline;gap:var(--space-sm);flex-wrap:wrap}.odds-timestamp__label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;letter-spacing:.04em}.odds-timestamp__time{font-size:var(--text-base);font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.odds-timestamp__note{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.odds-timestamp__refetch{padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:600;color:var(--color-accent);background:transparent;border:1.5px solid var(--color-accent);border-radius:var(--radius-badge);cursor:pointer;white-space:nowrap;transition:background var(--duration-fast) var(--ease-out-expo),color var(--duration-fast) var(--ease-out-expo),opacity var(--duration-fast)}.odds-timestamp__refetch:hover:not(:disabled){background:var(--color-accent);color:var(--color-surface-raised)}.odds-timestamp__refetch:focus-visible{outline:none;box-shadow:var(--focus-ring)}.odds-timestamp__refetch:disabled{opacity:.5;cursor:not-allowed}.race-detail-page{padding:var(--space-md) var(--space-lg);max-width:900px;margin:0 auto}.race-detail-page__header{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:2px solid var(--color-border)}.race-detail-page__back{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--text-xs);font-weight:600;color:var(--color-accent);background:transparent;border:none;padding:0;cursor:pointer;transition:opacity var(--duration-fast);margin-bottom:var(--space-xs)}.race-detail-page__back:hover{opacity:.75}.race-detail-page__back:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-badge)}.race-detail-page__header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.race-detail-page__title{font-size:var(--text-hero);font-weight:700;letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.15}.race-detail-page__post-time{font-size:clamp(1.5rem,1rem + 2.5vw,2.25rem);font-weight:700;color:var(--color-accent);letter-spacing:-.01em;line-height:1}.race-detail-page__meta{display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:center;margin-top:var(--space-xs)}.race-detail-page__meta-badge{font-size:var(--text-xs);font-weight:600;padding:2px var(--space-xs);border-radius:var(--radius-badge);color:var(--color-text-muted);background:var(--color-border);letter-spacing:.03em}.race-detail-page__cta-section{margin-bottom:var(--space-md)}.race-detail-page__cta{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--text-lg);font-weight:700;color:var(--color-surface-raised);background:var(--color-accent);border:none;border-radius:var(--radius-card);cursor:pointer;transition:background var(--duration-fast) var(--ease-out-expo),transform var(--duration-fast) var(--ease-out-expo),opacity var(--duration-fast);letter-spacing:-.01em;box-shadow:0 2px 8px #0075d24d;box-shadow:0 2px 8px oklch(56% .18 252 / .3)}.race-detail-page__cta:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #0075d266;box-shadow:0 4px 16px oklch(56% .18 252 / .4)}.race-detail-page__cta:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #0075d240;box-shadow:0 2px 8px oklch(56% .18 252 / .25)}.race-detail-page__cta:focus-visible{outline:none;box-shadow:var(--focus-ring),0 2px 8px #0075d24d;box-shadow:var(--focus-ring),0 2px 8px oklch(56% .18 252 / .3)}.race-detail-page__cta:disabled{opacity:.6;cursor:not-allowed;transform:none}.race-detail-page__pending{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) 0;color:var(--color-text-muted);font-size:var(--text-base)}.race-detail-page__spinner{width:1.25rem;height:1.25rem;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin var(--duration-slow) linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.race-detail-page__error{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);background:#fff1f0;background:oklch(97% .02 25);border:1px solid oklch(85% .06 25);border-radius:var(--radius-card);margin-bottom:var(--space-md)}.race-detail-page__error-message{color:var(--color-danger);font-size:var(--text-base);margin:0}.race-detail-page__error-retry{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs);font-weight:600;color:var(--color-surface-raised);background:var(--color-danger);border:none;border-radius:var(--radius-badge);cursor:pointer;transition:opacity var(--duration-fast)}.race-detail-page__error-retry:hover{opacity:.85}.race-detail-page__error-retry:focus-visible{outline:none;box-shadow:var(--focus-ring)}.race-detail-page__skeleton-header{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.race-detail-page__skeleton-line{height:1.2rem;border-radius:var(--radius-badge);background:var(--color-border)}.race-detail-page__skeleton-line--title{height:2.5rem;width:60%}.race-detail-page__skeleton-btn{height:2.5rem;width:14rem;border-radius:var(--radius-card);background:var(--color-border)}.race-detail-page__predict-error{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:#fff1f0;background:oklch(97% .02 25);border:1px solid oklch(85% .06 25);border-radius:var(--radius-card);margin-top:var(--space-sm)}.race-detail-page__predict-error-text{color:var(--color-danger);font-size:var(--text-base);margin:0}.race-detail-page__predict-error-hint{font-size:var(--text-xs);color:var(--color-text-muted)}.race-detail-page__result{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md)}.result-header-badge{display:inline-block;font-size:var(--text-xs);font-weight:700;padding:3px var(--space-sm);border-radius:var(--radius-badge);letter-spacing:.04em}.result-header-badge--confirmed{color:var(--color-success);background:var(--color-success-bg)}.result-header-badge--pending{color:var(--color-warning);background:var(--color-warning-bg)}.recommendation-outcome{padding:var(--space-md);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:var(--space-xs)}.recommendation-outcome__header{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.recommendation-outcome__star{color:var(--color-warning);font-size:var(--text-lg)}.recommendation-outcome__horse-no{font-size:var(--text-xs);font-weight:700;color:var(--color-text-muted)}.recommendation-outcome__horse{font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.recommendation-outcome__jockey{font-size:var(--text-xs);color:var(--color-text-muted)}.recommendation-outcome__meta{display:flex;gap:var(--space-md);font-size:var(--text-xs);color:var(--color-text-muted)}.recommendation-outcome__stake{font-weight:600}.recommendation-outcome__divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-xs) 0}.recommendation-outcome__result{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.recommendation-outcome__finish{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.recommendation-outcome__verdict{font-size:var(--text-base);font-weight:700}.recommendation-outcome__verdict--hit{color:var(--color-success)}.recommendation-outcome__verdict--miss{color:var(--color-danger)}.recommendation-outcome__payout{font-size:var(--text-base);color:var(--color-text)}.recommendation-outcome__pnl{font-size:var(--text-base);font-weight:700}.recommendation-outcome__pnl--positive{color:var(--color-success)}.recommendation-outcome__pnl--negative{color:var(--color-danger)}.recommendation-outcome__pending{display:flex;align-items:center}.recommendation-outcome__pending-badge{font-size:var(--text-xs);font-weight:700;padding:3px var(--space-sm);border-radius:var(--radius-badge);color:var(--color-warning);background:var(--color-warning-bg)}.entries-table-wrapper{width:100%;overflow-x:auto}.entries-table{width:100%;border-collapse:collapse;font-size:var(--text-xs)}.entries-table__th{padding:var(--space-xs) var(--space-sm);text-align:left;font-weight:700;color:var(--color-text-muted);border-bottom:2px solid var(--color-border);white-space:nowrap}.entries-table__th--star{width:1.5rem}.entries-table__td{padding:var(--space-xs) var(--space-sm);color:var(--color-text);border-bottom:1px solid var(--color-border);white-space:nowrap}.entries-table__td--star{text-align:center;width:1.5rem}.entries-table__star{color:var(--color-warning);font-size:.9em}.entries-table__row--recommended{background:#fff3e4;background:oklch(97% .04 75)}.entries-table__row:last-child .entries-table__td{border-bottom:none}.race-result-page{padding:var(--space-md) var(--space-lg);max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-lg)}.race-result-page__header{display:flex;flex-direction:column;gap:var(--space-xs);padding-bottom:var(--space-md);border-bottom:2px solid var(--color-border)}.race-result-page__header-top{display:flex;align-items:flex-start;gap:var(--space-sm);flex-wrap:wrap}.race-result-page__title{font-size:var(--text-hero);font-weight:700;letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.15;flex:1}.race-result-page__meta{display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:center;margin-top:var(--space-xs)}.race-result-page__meta-badge{font-size:var(--text-xs);font-weight:600;padding:2px var(--space-xs);border-radius:var(--radius-badge);color:var(--color-text-muted);background:var(--color-border);letter-spacing:.03em}.race-result-page__section{display:flex;flex-direction:column;gap:var(--space-md)}.race-result-page__section-heading{font-size:var(--text-lg);font-weight:700;color:var(--color-text);margin:0;padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.race-result-page__outcomes{display:flex;flex-direction:column;gap:var(--space-md)}.race-result-page__summary{padding:var(--space-md);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card)}.race-result-page__summary-inner{display:flex;align-items:baseline;gap:var(--space-sm);margin-bottom:var(--space-xs)}.race-result-page__summary-label{font-size:var(--text-base);font-weight:600;color:var(--color-text-muted)}.race-result-page__summary-pnl{font-size:clamp(1.75rem,1.2rem + 2.5vw,2.5rem);font-weight:700;letter-spacing:-.02em;line-height:1}.race-result-page__summary-pnl--positive{color:var(--color-success)}.race-result-page__summary-pnl--negative{color:var(--color-danger)}.race-result-page__summary-details{display:flex;flex-wrap:wrap;gap:var(--space-md);font-size:var(--text-xs);color:var(--color-text-muted)}.race-result-page__footer{padding-top:var(--space-md);border-top:1px solid var(--color-border);text-align:center}.race-result-page__footer-link{font-size:var(--text-base);color:var(--color-text-muted);text-decoration:none;opacity:.6;pointer-events:none;cursor:default}.race-result-page__skeleton{display:flex;flex-direction:column;gap:var(--space-md)}.race-result-page__skeleton-line{height:1.2rem;border-radius:var(--radius-badge);background:var(--color-border)}.race-result-page__skeleton-line--title{height:2.5rem;width:60%}.race-result-page__skeleton-card{height:8rem;border-radius:var(--radius-card);background:var(--color-border)}.race-result-page__error{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);background:#fff1f0;background:oklch(97% .02 25);border:1px solid oklch(85% .06 25);border-radius:var(--radius-card)}.race-result-page__error-message{color:var(--color-danger);font-size:var(--text-base);margin:0}.race-result-page__error-retry{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs);font-weight:600;color:var(--color-surface-raised);background:var(--color-danger);border:none;border-radius:var(--radius-badge);cursor:pointer;transition:opacity var(--duration-fast)}.race-result-page__error-retry:hover{opacity:.85}.race-result-page__error-retry:focus-visible{outline:none;box-shadow:var(--focus-ring)}:root{--color-surface: oklch(97% .005 90);--color-surface-raised: oklch(99% .003 90);--color-text: oklch(18% .01 250);--color-text-muted: oklch(48% .01 250);--color-accent: oklch(56% .18 252);--color-accent-hover: oklch(50% .2 252);--color-success: oklch(55% .15 145);--color-warning: oklch(72% .18 75);--color-danger: oklch(55% .2 25);--color-border: oklch(88% .01 250);--text-xs: clamp(.75rem, .7rem + .2vw, .8125rem);--text-base: clamp(.9375rem, .88rem + .25vw, 1rem);--text-lg: clamp(1.125rem, 1rem + .5vw, 1.25rem);--text-hero: clamp(1.75rem, 1rem + 3vw, 2.5rem);--space-xs: clamp(.25rem, .2rem + .2vw, .375rem);--space-sm: clamp(.5rem, .4rem + .4vw, .75rem);--space-md: clamp(1rem, .8rem + .8vw, 1.5rem);--space-lg: clamp(1.5rem, 1rem + 2vw, 2.5rem);--space-section: clamp(2.5rem, 1.5rem + 4vw, 5rem);--duration-fast: .12s;--duration-normal: .24s;--duration-slow: .4s;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--shadow-card: 0 1px 2px oklch(18% .01 250 / .06), 0 4px 12px oklch(18% .01 250 / .08);--shadow-card-hover: 0 2px 4px oklch(18% .01 250 / .08), 0 8px 24px oklch(18% .01 250 / .14);--focus-ring: 0 0 0 3px oklch(56% .18 252 / .35);--color-past-overlay: oklch(94% .004 250);--color-past-text: oklch(60% .008 250);--radius-card: 10px;--radius-badge: 4px;--radius-section-heading: 6px;--color-turf: oklch(55% .15 145);--color-turf-bg: oklch(94% .06 145);--color-dirt: oklch(60% .12 60);--color-dirt-bg: oklch(95% .05 60);--color-obstacle: oklch(55% .12 30);--color-obstacle-bg: oklch(95% .05 30);--color-info-fg: oklch(45% .18 252);--color-info-bg: oklch(95% .04 252);--color-success-bg: oklch(95% .05 145);--color-warning-bg: oklch(96% .06 75);--color-error: oklch(55% .2 25);--color-error-bg: oklch(96% .05 25);--header-height: 64px;--banner-height: auto;--z-header: 10;--z-banner: 9;--z-toast: 100;--max-content-width: 1440px}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sticky{position:sticky}.inline{display:inline}.table{display:table}.grid{display:grid}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}*,*:before,*:after{box-sizing:border-box}body{background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:0;overflow-x:hidden}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.app-shell__main{flex:1;max-width:var(--max-content-width);width:100%;margin-inline:auto;padding-inline:var(--space-md);padding-block:var(--space-md);min-width:0}h1,h2,h3,h4{line-height:1.2;font-weight:700}.race-list-page{padding:var(--space-md) var(--space-lg);max-width:1600px;margin:0 auto}.race-list-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.race-list-page__header-left{display:flex;align-items:baseline;gap:var(--space-sm);flex-wrap:wrap}.race-list-page__header-right{display:flex;align-items:center;gap:var(--space-sm)}.race-list-page__title{font-size:var(--text-hero);font-weight:700;letter-spacing:-.02em;color:var(--color-text);margin:0}.race-list-page__updated{font-size:var(--text-xs);color:var(--color-text-muted)}.race-list-page__refresh{padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:600;color:var(--color-accent);background:transparent;border:1.5px solid var(--color-accent);border-radius:var(--radius-badge);cursor:pointer;transition:background var(--duration-fast) var(--ease-out-expo),color var(--duration-fast) var(--ease-out-expo),opacity var(--duration-fast)}.race-list-page__refresh:hover:not(:disabled){background:var(--color-accent);color:var(--color-surface-raised)}.race-list-page__refresh:focus-visible{outline:none;box-shadow:var(--focus-ring)}.race-list-page__refresh:disabled{opacity:.5;cursor:not-allowed}.race-list-skeleton{display:flex;flex-direction:column;gap:var(--space-section)}.race-list-skeleton__section{display:flex;flex-direction:column;gap:var(--space-sm)}.race-list-skeleton__heading{height:1.5rem;width:8rem;border-radius:var(--radius-badge);background:var(--color-border)}.race-list-skeleton__cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,minmax(0,1fr)));gap:var(--space-sm)}.race-list-skeleton__card{height:120px;border-radius:var(--radius-card);background:var(--color-border)}.race-list-error{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);background:#fff1f0;background:oklch(97% .02 25);border:1px solid oklch(85% .06 25);border-radius:var(--radius-card)}.race-list-error__message{color:var(--color-danger);font-size:var(--text-base);margin:0}.race-list-error__retry{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs);font-weight:600;color:var(--color-surface-raised);background:var(--color-danger);border:none;border-radius:var(--radius-badge);cursor:pointer;transition:opacity var(--duration-fast)}.race-list-error__retry:hover{opacity:.85}.race-list-error__retry:focus-visible{outline:none;box-shadow:var(--focus-ring)}.race-list-empty{padding:var(--space-lg);color:var(--color-text-muted);font-size:var(--text-lg);text-align:center}.race-list-grid{display:flex;flex-direction:column;gap:var(--space-section)}.race-list-grid__empty{padding:var(--space-lg);color:var(--color-text-muted);font-size:var(--text-lg);text-align:center}.place-section{display:flex;flex-direction:column;gap:var(--space-sm)}.place-section__heading{display:inline-block;font-size:var(--text-lg);font-weight:700;letter-spacing:.03em;color:var(--color-text);background:var(--color-surface-raised);border:1px solid var(--color-border);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-section-heading);margin:0}.place-section__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,minmax(0,1fr)));gap:var(--space-sm)}.race-card{position:relative;display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);cursor:pointer;text-align:left;transition:box-shadow var(--duration-normal) var(--ease-out-expo),transform var(--duration-normal) var(--ease-out-expo),border-color var(--duration-fast)}.race-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px);border-color:#92bbea}.race-card:focus-visible{outline:none;box-shadow:var(--focus-ring),var(--shadow-card)}.race-card:active{transform:translateY(0);box-shadow:var(--shadow-card)}.race-card[data-past=true]{background:var(--color-past-overlay);border-color:#cbced2}.race-card[data-past=true] .race-card__time,.race-card[data-past=true] .race-card__number,.race-card[data-past=true] .race-card__name{color:var(--color-past-text)}.race-card[data-past=true]:hover{transform:none;box-shadow:var(--shadow-card)}.race-card__ended-badge{position:absolute;top:var(--space-xs);right:var(--space-xs);font-size:var(--text-xs);font-weight:700;color:var(--color-surface-raised);background:var(--color-past-text);padding:1px var(--space-xs);border-radius:var(--radius-badge);letter-spacing:.04em}.race-card__result-badge{position:absolute;top:var(--space-xs);right:var(--space-xs);font-size:var(--text-xs);font-weight:700;padding:1px var(--space-xs);border-radius:var(--radius-badge);letter-spacing:.04em}.race-card__result-badge--yes{color:var(--color-success);background:var(--color-success-bg)}.race-card__result-badge--no{color:var(--color-text-muted);background:var(--color-border)}.race-card__time{font-size:clamp(1.4rem,1.1rem + 1vw,1.75rem);font-weight:700;letter-spacing:-.01em;color:var(--color-accent);line-height:1}.race-card__date{font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;color:var(--color-text-muted);text-transform:uppercase}.race-card__identity{display:flex;align-items:baseline;gap:var(--space-xs);flex-wrap:wrap}.race-card__number{font-size:var(--text-xs);font-weight:700;color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase}.race-card__name{font-size:var(--text-base);font-weight:600;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.race-card__badges{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-top:auto}.race-card__badge{font-size:var(--text-xs);font-weight:600;padding:1px var(--space-xs);border-radius:var(--radius-badge);letter-spacing:.03em;color:var(--color-text-muted);background:var(--color-border)}.race-card__badge--turf{color:var(--color-turf);background:var(--color-turf-bg)}.race-card__badge--dirt{color:var(--color-dirt);background:var(--color-dirt-bg)}.race-card__badge--obstacle{color:var(--color-obstacle);background:var(--color-obstacle-bg)}.race-card__badge--distance{color:var(--color-text-muted);background:var(--color-border)}.race-card__pnl{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-xs);margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-badge);font-variant-numeric:tabular-nums}.race-card__pnl-label{font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;color:var(--color-text-muted)}.race-card__pnl-value{font-size:var(--text-base);font-weight:700;letter-spacing:-.01em}.race-card__pnl--gain{background:var(--color-success-bg)}.race-card__pnl--gain .race-card__pnl-value{color:var(--color-success)}.race-card__pnl--loss{background:var(--color-error-bg)}.race-card__pnl--loss .race-card__pnl-value{color:var(--color-danger)}.race-card__pnl--zero{background:var(--color-border)}.race-card__pnl--zero .race-card__pnl-value{color:var(--color-text-muted)}.race-card__pnl--pending{background:var(--color-info-bg)}.race-card__pnl-value--pending{color:var(--color-info-fg);font-weight:500;font-size:var(--text-xs);letter-spacing:.04em}.bankroll-input{display:flex;align-items:center;gap:var(--space-xs)}.bankroll-input__label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;white-space:nowrap}.bankroll-input__field{font-size:var(--text-base);font-weight:700;color:var(--color-text);background:var(--color-surface-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-badge);padding:var(--space-xs) var(--space-sm);width:7rem;cursor:default}.bankroll-input__field:focus{outline:none;box-shadow:var(--focus-ring)}
