*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0}ul[role=list],ol[role=list]{list-style:none}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5}a:not([class]){text-decoration-skip-ink:auto}img,picture{max-width:100%;display:block}input,button,textarea,select{font:inherit}@media (prefers-reduced-motion: reduce){html:focus-within{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--primary-color: #e63946;--primary-color-hover: #d62839;--secondary-color: #2b2d42;--secondary-color-hover: #1f2233;--accent: #ffffff;--accent-hover: #ced4da;--success: #4caf50;--error: #e63946;--background: #919294;--text-color: #212529;--text-color-hover: #000000;--font-heading: "Orbitron", sans-serif;--font-body: "Inter", sans-serif}body{font-family:var(--font-body);background-color:var(--background)}h1,h2,h3{font-family:var(--font-heading)}.homepage{padding:1rem}.homepage__body{display:grid;grid-template-columns:2fr 3fr 2fr;gap:1rem}.header{background:linear-gradient(90deg,var(--secondary-color) 0%,var(--primary-color) 100%);padding:.625rem 1.25rem}.header__nav{display:flex;align-items:center;justify-content:space-between}.header__nav-list{display:flex}.header__nav-item{list-style:none;margin-left:20px}.header__nav-link{color:var(--accent);text-decoration:none}.header__nav-link:hover{color:var(--accen-hover);text-decoration:underline}.horse-list__wrapper{border:1px solid var(--secondary-color);border-radius:8px;overflow-y:auto;max-height:70vh}.horse-list h2{margin-bottom:1rem;background-color:var(--secondary-color);padding:.5rem;border-radius:8px;color:var(--accent)}.horse-list table{width:100%;border-collapse:collapse}.horse-list table th,.horse-list table td{padding:.5rem;border:1px solid var(--secondary-color);text-align:center;font-size:12px}.horse-list table th{background-color:var(--secondary-color);color:var(--accent)}.ui-table{width:100%;border-collapse:collapse}.ui-table th,.ui-table td{padding:.5rem;border:1px solid var(--secondary-color);text-align:center;font-size:12px}.ui-table td:nth-child(odd){background-color:var(--accent)}.ui-table td:nth-child(2n){background-color:var(--accent-hover)}.ui-table th{background-color:var(--secondary-color);color:var(--accent)}.race-track{display:block}.race-track__finish-line{position:absolute;right:0;top:50%;transform:translateY(-50%);width:10px;height:50px;background:repeating-linear-gradient(45deg,var(--secondary-color) 0,var(--secondary-color) 6px,var(--accent) 6px,var(--accent) 12px);border-radius:2px;box-shadow:0 0 4px #0000004d;z-index:2}.race-track__line{height:65px;display:flex;align-items:center}.race-track__line-number{width:50px;padding:5px 0;background:var(--success);color:var(--accent);border-radius:.25rem;rotate:-90deg;display:flex;align-items:center;justify-content:center}.race-track__line-horse{flex:1;height:100%;display:flex;align-items:center;border-top:2px dashed var(--secondary-color);position:relative}.race-track__line:last-child .race-track__line-horse{border-bottom:2px dashed var(--secondary-color)}.race-track__horse-anim{position:absolute;left:0;will-change:transform;transition:transform .03s linear;animation:horse-bounce-move .6s infinite ease-in-out;transform:translate(var(--horse-x, 0)) scaleY(1)}.race-track__status{margin-bottom:.625rem;display:flex;justify-content:center}.race-track__status-text{background:var(--primary-color);width:50%;text-align:center;color:var(--accent);padding:5px 1rem;border-radius:.25rem;font-weight:600}@keyframes horse-bounce-move{0%{transform:translate(var(--horse-x, 0)) scaleY(1)}20%{transform:translate(var(--horse-x, 0)) scaleY(1.05)}50%{transform:translate(var(--horse-x, 0)) scaleY(1)}70%{transform:translate(var(--horse-x, 0)) scaleY(.95)}to{transform:translate(var(--horse-x, 0)) scaleY(1)}}.action-area{display:flex;justify-content:center;padding:1rem;gap:1.25rem}.ui-button{font-size:.875rem;width:9.375rem;height:3.125rem;border:none;background-color:var(--secondary-color);color:var(--accent);border-radius:8px;box-shadow:0 2px 8px #0000001a,0 4px 16px #0000001a;transition:box-shadow .2s,transform .2s;cursor:pointer}.ui-button:hover{box-shadow:0 4px 16px #0000002e,0 8px 32px #0000002e;transform:translateY(-2px) scale(1.03)}.ui-button:hover:disabled{box-shadow:none;transform:none}.ui-button:disabled{background-color:#ccc;cursor:not-allowed;box-shadow:none;transform:none}.race-schedule{display:flex;gap:1.25rem}.race-schedule__text{margin-top:.625rem;background-color:var(--success);color:var(--accent);text-align:center;padding:.25rem 0;border-top-left-radius:8px;border-top-right-radius:8px}.race-schedule__text.--error{background-color:var(--error);color:var(--accent)}.race-schedule__program-title{background-color:var(--primary-color);color:var(--accent)}.race-schedule__results-title{background-color:var(--secondary-color);color:var(--accent)}.race-schedule__program,.race-schedule__results{flex:1}.race-schedule__program-title,.race-schedule__results-title{padding:.5rem 0;text-align:center;border-radius:8px}.race-schedule__program-item,.race-schedule__results-item{overflow-y:auto;max-height:70vh}
