:root{color:#f5f7fa;background:#0b0f14;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.4}*{box-sizing:border-box}body{color:#f5f7fa;background:#0b0f14;margin:0}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}.app-shell{background:#0b0f14;min-height:100vh}.app-main{max-width:520px;margin:0 auto;padding:1rem .85rem 8.2rem}.page{flex-direction:column;gap:.85rem;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:.85rem;display:flex}.page-header h1{letter-spacing:-.01em;margin-bottom:.2rem;font-size:1.6rem}.page-header__meta{text-transform:uppercase;letter-spacing:.06em;color:#7c5cff;margin-bottom:.3rem;font-size:.75rem}.page-header p{color:#9aa4b2;font-size:.95rem}.updated-time{color:#9aa4b2;margin-top:-.35rem;font-size:.82rem}.data-source-indicator{color:#9aa4b2;margin-top:-.4rem;font-size:.8rem}.subtle-warning{color:#f5c542;margin-top:-.2rem;font-size:.8rem}.card{background:#141a22;border:1px solid #232c37;border-radius:16px;padding:.9rem .85rem}.stack{flex-direction:column;gap:.65rem;display:flex}.dashboard-section{flex-direction:column;gap:.55rem;display:flex}.section-header{justify-content:space-between;align-items:center;display:flex}.section-header h2{color:#9aa4b2;text-transform:uppercase;letter-spacing:.06em;font-size:.83rem}.section-header span{text-align:center;color:#9aa4b2;border:1px solid #2a3442;border-radius:999px;min-width:1.4rem;padding:.12rem .45rem;font-size:.75rem}.section-header--high h2{color:#f5f7fa}.section-header--high span{color:#c6b8ff;background:#7c5cff26;border-color:#7c5cff61}.dashboard-filters{background:#18212b}.filter-chips{flex-wrap:wrap;gap:.45rem;margin-top:.65rem;display:flex}.filter-chip{color:#9aa4b2;background:#121924;border:1px solid #2a3442;border-radius:999px;padding:.4rem .72rem;font-size:.8rem}.filter-chip.is-active{color:#f5f7fa;background:#7c5cff3d;border-color:#7c5cff73}.machine-card{background:#18212b;flex-direction:column;gap:.65rem;display:flex}.machine-card__top,.machine-card__timing,.machine-card__actions{justify-content:space-between;gap:.65rem;display:flex}.machine-card__top h3{margin-bottom:.15rem;font-size:1.12rem}.machine-card__timing{align-items:center}.machine-card__next-tap{font-size:1.5rem;font-weight:700;line-height:1.05}.machine-card__meta{gap:.45rem;display:grid}.machine-card__actions{margin-top:.1rem}.countdown-wrap{text-align:right}.countdown{letter-spacing:.01em;font-size:1.36rem;font-weight:700}.label{color:#9aa4b2;text-transform:uppercase;letter-spacing:.04em;margin-right:.25rem;font-size:.75rem}.value{margin-top:.2rem;font-size:1.05rem}.muted{color:#9aa4b2}.small{font-size:.82rem}.status-pill{white-space:nowrap;letter-spacing:.02em;border:1px solid #0000;border-radius:999px;align-items:center;padding:.24rem .56rem;font-size:.72rem;font-weight:700;display:inline-flex}.status-pill--tap_now{color:#35d07f;background:#35d07f26;border-color:#35d07f6b}.status-pill--up_next{color:#f5c542;background:#f5c54226;border-color:#f5c54266}.status-pill--later{color:#c3b3ff;background:#7c5cff26;border-color:#7c5cff61}.status-pill--waiting{color:#c1c8d3;background:#9aa4b21f;border-color:#9aa4b24d}.status-pill--maintenance{color:#ff8569;background:#ff6b4a1f;border-color:#ff6b4a59}.status-pill--removed{color:#ff8569;background:#ff6b4a2e;border-color:#ff6b4a7a}.status-pill--no_data{color:#c1c8d3;background:#9aa4b21f;border-color:#9aa4b24d}.machine-card--tap_now{border-color:#35d07f6b;box-shadow:inset 3px 0 #35d07f}.machine-card--up_next{border-color:#f5c5426b;box-shadow:inset 3px 0 #f5c542}.machine-card--later{border-color:#7c5cff59;box-shadow:inset 3px 0 #7c5cff}.machine-card--waiting{box-shadow:inset 3px 0 #9aa4b2}.machine-card--maintenance,.machine-card--removed{border-color:#ff6b4a59;box-shadow:inset 3px 0 #ff6b4a}.machine-card--no_data{box-shadow:inset 3px 0 #9aa4b2}.countdown--tap_now{color:#35d07f}.countdown--up_next{color:#f5c542}.countdown--later{color:#c3b3ff}.countdown--waiting{color:#9aa4b2}.countdown--maintenance,.countdown--removed{color:#ff8569}.countdown--no_data{color:#9aa4b2}.info-row{justify-content:space-between;gap:.55rem;font-size:.86rem;display:flex}.info-row span{color:#9aa4b2}.info-row strong{text-align:right;color:#d4dbe4;font-weight:600}.product-chips{flex-wrap:wrap;gap:.45rem;display:flex}.product-chip{color:#c7d0db;background:#111821;border:1px solid #2a3442;border-radius:999px;padding:.33rem .56rem;font-size:.78rem}.btn{cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;min-width:110px;height:44px;padding:0 .85rem;font-size:.9rem;font-weight:600;transition:transform .12s,background-color .12s;display:inline-flex}.btn--primary{color:#f5f7fa;background:#7c5cff}.btn--primary:active{transform:translateY(1px)}.btn--secondary{color:#f5f7fa;background:#121924;border-color:#2a3442}.full-width{width:100%}.bottom-nav{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.5rem .5rem calc(.5rem + env(safe-area-inset-bottom));z-index:20;background:#0b0f14f5;border-top:1px solid #232c37;grid-template-columns:repeat(4,1fr);max-width:520px;margin:0 auto;display:grid;position:fixed;bottom:0;left:0;right:0}.bottom-nav__item{text-align:center;color:#9aa4b2;border:1px solid #0000;border-radius:11px;padding:.62rem .35rem;font-size:.76rem;font-weight:600}.bottom-nav__item.is-active{color:#f5f7fa;background:#7c5cff33;border-color:#7c5cff59}.bottom-nav__item.is-prominent{color:#d4caff}.bottom-nav__item.is-prominent.is-active{background:#7c5cff;border-color:#7c5cff}.floating-add-run{z-index:18;color:#f5f7fa;background:#7c5cff;border:1px solid #9d87ff;border-radius:999px;padding:.55rem .9rem;font-size:.85rem;font-weight:700;position:fixed;bottom:4.9rem;right:max(1rem,50vw - 260px + 1rem);box-shadow:0 10px 20px #0000004d}.form-card,.search-card,.run-info-card{gap:.75rem;display:grid}.form-card h2{font-size:1.06rem}.check-card__header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.run-info-card h2{font-size:1rem}.run-info-grid,.two-col{grid-template-columns:1fr 1fr;gap:.65rem;display:grid}.outcome-buttons{grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.45rem;display:grid}.outcome-button{color:#d4dbe4;font:inherit;background:#111821;border:1px solid #2a3442;border-radius:10px;padding:.58rem .5rem;font-size:.87rem}.outcome-button.is-active{color:#f5f7fa;background:#7c5cff38;border-color:#7c5cff73}.hit-product-area{background:#121924;border:1px solid #2a3442;border-radius:12px;gap:.65rem;padding:.65rem;display:grid}.submit-run-sticky{z-index:12;background:linear-gradient(#0b0f1459,#0b0f14f2);padding-top:.6rem;position:sticky;bottom:5.1rem}input,select,textarea{color:#f5f7fa;width:100%;font:inherit;background:#0f141c;border:1px solid #2a3442;border-radius:10px;margin-top:.35rem;padding:.7rem}textarea{resize:vertical}.form-field label{display:block}.text-action{color:#c7d0db;font:inherit;background:#121924;border:1px solid #2a3442;border-radius:10px;padding:.32rem .58rem;font-size:.8rem}.text-action.danger{color:#ff8569;border-color:#ff6b4a73}.validation-message{color:#ff8569;margin-top:.35rem;font-size:.8rem}.submit-success{color:#35d07f;font-size:.92rem;font-weight:700}.submit-error-card{background:#1a2029;border-color:#ff6b4a73}.submit-error-card h2{color:#ff8569;margin-bottom:.45rem;font-size:1rem}.submit-error-card p{color:#d4dbe4;font-size:.88rem}.save-summary{background:#18212b;gap:.6rem;display:grid}.save-summary h2{font-size:1rem}.payload-preview{background:#18212b;gap:.6rem;display:grid}.payload-preview h2{font-size:1rem}.payload-preview pre{white-space:pre-wrap;word-break:break-word;background:#0f141c;border:1px solid #2a3442;border-radius:10px;margin:0;padding:.7rem;font-size:.76rem;line-height:1.45}.btn:disabled{cursor:not-allowed;opacity:.7}label{color:#c7d0db;font-size:.87rem}.machine-list-item{justify-content:space-between;align-items:flex-start;gap:.8rem;display:flex}.machine-list-item h3{margin-bottom:.2rem}.machine-list-item .info-row{margin-top:.5rem}.machine-list-item__right{flex-direction:column;align-items:flex-end;gap:.35rem;display:flex}.machine-list-next{color:#f5f7fa;font-size:.84rem;font-weight:600}.detail-grid{grid-template-columns:1fr 1fr;gap:.65rem;margin-top:.6rem;display:grid}.detail-hero{background:#18212b}.detail-hero__headline{justify-content:space-between;gap:.7rem;margin-top:.65rem;display:flex}.detail-next-tap{margin-top:.1rem;font-size:1.45rem;font-weight:700}.simple-list,.reports-list{gap:.65rem;margin:0;padding:0;list-style:none;display:grid}.simple-list li{border-bottom:1px solid #232c37;justify-content:space-between;gap:.6rem;padding-bottom:.55rem;display:flex}.reports-list li{border-left:2px solid #2a3442;padding-left:.65rem}.stats-grid{grid-template-columns:1fr 1fr;gap:.6rem;display:grid}.stat-card{background:#18212b}.stat-value{margin-top:.25rem;font-size:1.2rem;font-weight:700}.empty-state{text-align:center;padding:1.4rem}.empty-state h3{margin-bottom:.45rem}.auth-page{justify-content:center;min-height:100vh}.auth-card{text-align:center;gap:.9rem;display:grid}.auth-card--elevated{background:#18212b;border-color:#2c3342;box-shadow:0 10px 30px #00000059}.badge{color:#c3b3ff;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.auth-copy{color:#d6dde6}.auth-note{color:#9aa4b2;font-size:.82rem}.status-text{margin-top:.55rem;margin-bottom:.4rem;font-weight:700}.status-text.success{color:#35d07f}.status-text.warning{color:#f5c542}@media (width>=640px){.app-main{padding:1.25rem 1.25rem 8.6rem}.machine-card__actions{justify-content:flex-start}.card{padding:1rem}.floating-add-run{bottom:5.35rem}}@media (width<=420px){.machine-card__timing{flex-direction:column;align-items:flex-start}.countdown-wrap{text-align:left}.machine-card__actions{flex-direction:column}.machine-card__actions .btn{width:100%}.detail-hero__headline{flex-direction:column}.run-info-grid,.two-col{grid-template-columns:1fr}}
