*,*:before,*:after{box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-600: #4b5563;--gray-800: #1f2937}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0;background:var(--gray-100);color:var(--gray-800);line-height:1.5}.app{min-height:100vh;padding:1rem;max-width:800px;margin:0 auto}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.search-box[data-v-3cae7493]{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.search-icon[data-v-3cae7493]{width:2rem;height:2rem;color:var(--primary);flex-shrink:0}.search-box input[data-v-3cae7493]{flex:1;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--gray-300);border-radius:8px;outline:none;transition:border-color .2s}.search-box input[data-v-3cae7493]:focus{border-color:var(--primary)}.tag-filter[data-v-3cae7493]{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tag-chip[data-v-3cae7493]{--tag-color: var(--primary);padding:.25rem .75rem;border-radius:16px;border:2px solid var(--tag-color);background:#fff;color:var(--tag-color);cursor:pointer;font-size:.875rem;transition:all .2s}.tag-chip[data-v-3cae7493]:hover{background:color-mix(in srgb,var(--tag-color) 10%,white)}.tag-chip.selected[data-v-3cae7493]{background:var(--tag-color);color:#fff}.machine-list[data-v-3cae7493]{list-style:none;padding:0;margin:0}.machine-list li[data-v-3cae7493]{background:#fff;border-radius:8px;margin-bottom:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:stretch}.machine-list .machine-link[data-v-3cae7493]{flex:1;display:flex;justify-content:space-between;align-items:center;padding:1rem 1rem 1rem .25rem;color:inherit;text-decoration:none;gap:.5rem;min-width:0}.machine-list li[data-v-3cae7493]:hover{background:var(--gray-100)}.fav-toggle[data-v-3cae7493]{background:none;border:none;cursor:pointer;line-height:0;padding:1rem .5rem 1rem 1rem;color:var(--gray-300);transition:color .15s,transform .1s;display:inline-flex;align-items:center}.fav-toggle svg[data-v-3cae7493]{width:22px;height:22px}.fav-toggle[data-v-3cae7493]:hover{transform:scale(1.15)}.fav-toggle.active[data-v-3cae7493]{color:#f59e0b}.machine-info[data-v-3cae7493]{display:flex;flex-direction:column;gap:.25rem;min-width:0}.name[data-v-3cae7493]{font-weight:500}.meta[data-v-3cae7493]{color:var(--gray-600);font-size:.875rem}.completeness-battery[data-v-3cae7493]{display:flex;gap:2px;flex-shrink:0}.completeness-battery .bar[data-v-3cae7493]{width:4px;height:12px;background-color:var(--gray-300);border-radius:1px}.completeness-battery .bar.filled[data-v-3cae7493]{background-color:var(--gray-600)}.completeness-battery .completeness-award[data-v-3cae7493]{width:22px;height:22px;color:#f59e0b}.loading[data-v-3cae7493],.no-results[data-v-3cae7493],.hint[data-v-3cae7493]{text-align:center;color:var(--gray-600);padding:2rem}.back-link[data-v-cbf3cff4]{display:inline-block;margin-bottom:1rem;color:var(--primary)}.machine-header[data-v-cbf3cff4]{margin-bottom:1rem}.header-row[data-v-cbf3cff4]{display:flex;align-items:center;gap:.75rem}.machine-header h1[data-v-cbf3cff4]{margin:0;font-size:1.75rem}.admin-link[data-v-cbf3cff4]{color:var(--gray-400);text-decoration:none;line-height:0;display:inline-flex;align-items:center}.admin-link svg[data-v-cbf3cff4]{width:20px;height:20px}.admin-link[data-v-cbf3cff4]:hover{color:var(--primary)}.fav-toggle[data-v-cbf3cff4]{background:none;border:none;cursor:pointer;line-height:0;padding:0;color:var(--gray-300);transition:color .15s,transform .1s;display:inline-flex;align-items:center}.fav-toggle svg[data-v-cbf3cff4]{width:24px;height:24px}.fav-toggle[data-v-cbf3cff4]:hover{transform:scale(1.15)}.fav-toggle.active[data-v-cbf3cff4]{color:#f59e0b}.machine-header .shortname[data-v-cbf3cff4]{color:var(--gray-500);font-size:.875rem;margin:0 0 .25rem}.machine-header .meta[data-v-cbf3cff4]{color:var(--gray-600);margin:0}.tech-info[data-v-cbf3cff4]{margin:.5rem 0 0}.badge[data-v-cbf3cff4]{display:inline-block;background:var(--primary);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;margin-right:.5rem}.card[data-v-cbf3cff4]{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.body[data-v-cbf3cff4]{display:flex;flex-direction:column;gap:1.5rem}.info[data-v-cbf3cff4]{display:flex;flex-direction:column;gap:1rem}.playfield[data-v-cbf3cff4]{margin:0}.playfield-wrapper[data-v-cbf3cff4]{position:relative;display:block;max-width:600px;margin:0 auto;line-height:0}.playfield-wrapper img[data-v-cbf3cff4]{display:block;max-width:100%;max-height:100%;width:auto;height:auto;border-radius:8px;box-shadow:0 2px 8px #00000026}.playfield-marker[data-v-cbf3cff4]{position:absolute;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;border:1.5px solid white;color:#fff;font-weight:700;font-size:.55rem;cursor:pointer;box-shadow:0 1px 3px #0006;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:transform .15s}.playfield-marker[data-v-cbf3cff4]:hover{transform:translate(-50%,-50%) scale(1.4)}.markers-toggle[data-v-cbf3cff4]{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:50%;border:none;background:#0000008c;color:#fff;line-height:0;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 2px 6px #0000004d;transition:background-color .15s,transform .1s}.markers-toggle svg[data-v-cbf3cff4]{width:18px;height:18px}.markers-toggle[data-v-cbf3cff4]:hover{background:#000000bf}.markers-toggle.off[data-v-cbf3cff4]{background:#00000059}.tips h2[data-v-cbf3cff4],.links h2[data-v-cbf3cff4],.notes h2[data-v-cbf3cff4]{margin-top:0;margin-bottom:1rem;font-size:1.25rem}.tip-category h3[data-v-cbf3cff4]{font-size:1rem;color:var(--primary);margin:1rem 0 .5rem;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.tip[data-v-cbf3cff4]{border-left:4px solid var(--tip-color, transparent);transition:box-shadow .4s}.tip.highlighted[data-v-cbf3cff4]{box-shadow:0 0 0 3px var(--tip-color),0 4px 12px #00000026}.tip-header[data-v-cbf3cff4]{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.tip-number[data-v-cbf3cff4]{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;color:#fff;font-weight:700;font-size:.875rem;flex-shrink:0}.tip h4[data-v-cbf3cff4]{margin:0;font-size:1rem}.tip p[data-v-cbf3cff4]{margin:0;color:var(--gray-600)}.preserve-lines[data-v-cbf3cff4]{white-space:pre-line}.links ul[data-v-cbf3cff4]{list-style:none;padding:0;margin:0}.links li[data-v-cbf3cff4]{padding:.5rem 0;border-bottom:1px solid var(--gray-200)}.links li[data-v-cbf3cff4]:last-child{border-bottom:none}.link-type[data-v-cbf3cff4]{display:inline-block;background:var(--gray-200);color:var(--gray-700);font-size:.7rem;padding:.125rem .375rem;border-radius:3px;margin-right:.5rem;text-transform:uppercase}.loading[data-v-cbf3cff4],.error[data-v-cbf3cff4]{text-align:center;color:var(--gray-600);padding:2rem}@media (min-width: 900px){.body[data-v-cbf3cff4]{flex-direction:row-reverse;align-items:flex-start}.info[data-v-cbf3cff4],.playfield[data-v-cbf3cff4]{flex:1 1 0;min-width:0}.playfield-wrapper[data-v-cbf3cff4]{margin:0}}
