:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}:is(#root:has(.app-shell),#root:has(.auth-shell)){width:100%;max-width:none;text-align:initial;background:#f1f5f9;border:none}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.auth-shell{color:#334155;background:linear-gradient(165deg,#e8f0fb 0%,#f0f4fa 45%,#f8fafc 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:#fff;border:1px solid #d8e3f0;border-radius:16px;width:100%;max-width:400px;padding:32px 28px;box-shadow:0 12px 40px #0f172a14}.auth-title{color:#0f172a;letter-spacing:.02em;margin:0 0 8px;font-size:1.75rem;font-weight:800}.auth-lead{color:#64748b;margin:0 0 24px;font-size:.95rem;line-height:1.45}.auth-muted{color:#64748b;font-size:.9rem}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-label{color:#64748b;text-transform:uppercase;letter-spacing:.06em;flex-direction:column;gap:6px;font-size:.8rem;font-weight:600;display:flex}.auth-input{font:inherit;color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:10px;padding:12px 14px}.auth-input:focus{outline-offset:1px;background:#fff;border-color:#93c5fd;outline:2px solid #3b82f6}.auth-error{color:#f87171;margin:0;font-size:.875rem}.auth-button{color:#334155;cursor:pointer;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:10px;margin-top:8px;padding:12px 16px;font-weight:600}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-button-primary{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#0000}.auth-button-secondary{color:#1e293b;background:#e2e8f0;border:1px solid #cbd5e1}.auth-button-secondary:hover:not(:disabled){background:#cbd5e1}.auth-button-primary:hover:not(:disabled){filter:brightness(1.06)}.auth-hint{color:#64748b;margin:20px 0 0;font-size:.75rem;line-height:1.5}.auth-hint code{color:#1d4ed8;background:#eff6ff;border-radius:4px;padding:2px 6px;font-size:.72rem}.auth-logo{width:100%;max-width:280px;height:auto;margin:0 auto 12px;display:block}.app-shell{color:#334155;background:#f1f5f9;min-height:100vh}.impersonation-banner{color:#fecaca;background:linear-gradient(90deg,#7f1d1d 0%,#991b1b 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px 16px;padding:10px 20px;font-size:.875rem;line-height:1.4;display:flex}.impersonation-banner strong{color:#fff}.impersonation-banner button{color:#7f1d1d;cursor:pointer;background:#fff;border:none;border-radius:8px;flex-shrink:0;padding:8px 14px;font-weight:700}.impersonation-banner button:hover{background:#fee2e2}.impersonate-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:16px}.enter-class-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-top:12px;margin-bottom:16px;padding:12px 14px}.enter-class-panel .section-label{margin:0 0 4px;font-size:.75rem}.enter-class-panel .page-lead{margin:0 0 12px;font-size:.9rem;line-height:1.35}.enter-class-panel .auth-label{margin-bottom:8px}.enter-class-panel .auth-input{margin-top:4px;padding:8px 10px}.enter-class-panel .dog-page-actions{gap:8px;margin-top:12px}.impersonate-panel .impersonate-actions{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.impersonate-panel .impersonate-actions input{flex:200px;min-width:0}.impersonate-dropdown-block{flex-direction:column;gap:14px;margin-top:14px;display:flex}.impersonate-select-label{margin-top:0;display:block}.impersonate-select{width:100%;font:inherit;color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:8px;margin-top:6px;padding:10px 12px}.impersonate-go-btn{align-self:flex-start;min-height:48px;margin-top:4px;padding:14px 24px;font-size:1.05rem}.app-top{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.app-brand{color:#0f172a;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.15rem;font-weight:800}.app-logout{color:#475569;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;padding:8px 14px;font-weight:600}.app-nav{background:#fff;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;gap:8px;padding:12px 16px;display:flex}.app-nav-pill{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:999px;padding:8px 14px;font-size:.8rem;font-weight:600}.app-nav-pill:hover{color:#0f172a;background:#fff;border-color:#94a3b8}.app-nav-pill.active{color:#1e40af;background:#dbeafe;border-color:#3b82f6}.app-nav-pill--badge-slot .app-nav-pill-inner{align-items:center;gap:8px;display:inline-flex}.app-nav-pill-badge{color:#fff;text-align:center;font-variant-numeric:tabular-nums;background:#2563eb;border-radius:999px;min-width:1.15rem;height:1.15rem;padding:0 5px;font-size:.65rem;font-weight:800;line-height:1.15rem}.app-nav-pill.active .app-nav-pill-badge{background:#1d4ed8}.events-list-title-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.events-list-reg-pill{color:#1e40af;font-variant-numeric:tabular-nums;background:#dbeafe;border:1px solid #93c5fd;border-radius:999px;min-width:1.35rem;padding:2px 8px;font-size:.72rem;font-weight:800;line-height:1.25;display:inline-block}.app-nav-pill.admin.active{color:#5b21b6;background:#ede9fe;border-color:#7c3aed}.app-main{max-width:720px;margin:0 auto;padding:20px}.page-h1{color:#0f172a;margin:0 0 8px;font-size:1.5rem;font-weight:800}.page-lead{color:#64748b;margin:0 0 20px;line-height:1.45}.app-muted{color:#94a3b8;font-size:.9rem}.section-label{letter-spacing:.06em;text-transform:uppercase;color:#64748b;margin:0 0 10px;font-size:.7rem;font-weight:700}.link-grid{flex-direction:column;gap:10px;display:flex}.link-tile{text-align:left;cursor:pointer;color:inherit;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:4px;padding:16px;display:flex;box-shadow:0 1px 2px #0f172a0a}.link-tile.admin{background:#f5f3ff;border-color:#c4b5fd}.link-tile-title{color:#0f172a;font-size:1.05rem;font-weight:700}.link-tile-hint{color:#64748b;font-size:.85rem}.auth-button.refresh{margin-bottom:16px}.data-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.data-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:4px;padding:14px;display:flex;box-shadow:0 1px 2px #0f172a0a}.data-card strong{color:#0f172a}.events-class-row{flex-direction:row;align-items:flex-start;gap:12px;padding:10px 12px;display:flex}.events-class-row:not(.events-class-row--entered){align-items:center}.events-class-row-main{flex:auto;min-width:0}.events-class-row-title{color:#0f172a;flex-wrap:wrap;align-items:center;gap:8px;min-width:0;margin:0;font-size:1rem;font-weight:700;display:flex}.events-class-row-marker{border-radius:999px;flex:none;justify-content:center;align-items:center;width:1.35rem;height:1.35rem;font-size:.8rem;font-weight:800;line-height:1;display:inline-flex}.events-class-row-marker--entered{color:#fff;background:#16a34a;border:1px solid #15803d}.events-class-row-marker--ineligible{color:#fff;background:#d97706;border:1px solid #b45309}.events-class-row--entered{background:#f0fdf4;border-color:#86efac!important}.events-class-row--ineligible{background:#fffbeb;border-color:#fcd34d!important}.events-class-row-status{margin-top:6px;font-size:.8rem;line-height:1.35;display:block}.events-class-row-status--entered{color:#166534;font-weight:600}.events-class-row-status--ineligible{color:#92400e}.events-class-row-btn--manage{cursor:pointer;align-self:center;color:#fff!important;background:#16a34a!important;border:1px solid #15803d!important}.events-class-row-btn--manage:hover{background:#15803d!important}.events-entered-block{background:#fff;border:1px solid #bbf7d0;border-radius:8px;margin-top:10px;padding:10px 12px;box-shadow:0 1px 2px #0f172a0a}.events-entered-heading{letter-spacing:.07em;text-transform:uppercase;color:#166534;margin:0 0 8px;font-size:.65rem;font-weight:800}.events-entered-lines{margin:0;padding:0;list-style:none}.events-entered-line{color:#052e16;border-top:1px solid #ecfdf5;margin:0;padding:8px 0;font-size:.95rem;font-weight:600;line-height:1.4}.events-entered-lines .events-entered-line:first-child{border-top:none;padding-top:0}.events-entered-hint{color:#15803d;margin:10px 0 0;font-size:.78rem;line-height:1.35}.events-class-row-btn--ineligible{cursor:default;color:#92400e!important;background:#fef3c7!important;border:1px solid #f59e0b!important}.events-class-row-meta{color:#64748b;margin:2px 0 0;font-size:.85rem;display:block}.events-class-row-criteria{color:#475569;white-space:normal;margin:2px 0 0;font-size:.85rem;line-height:1.3;display:block}.events-class-row-btn{white-space:nowrap;flex:none;padding:8px 16px;margin-top:0!important}ul.data-list.events-class-list{gap:6px}.data-meta{color:#64748b;font-size:.85rem}.score-total{text-align:center;color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe;border-radius:10px;margin-bottom:16px;padding:12px;font-weight:700}.dog-progress-summary{background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;margin-bottom:16px;padding:14px 16px}.dog-progress-summary .dog-progress-name{color:#0f172a;margin:0 0 8px;font-size:1.15rem;font-weight:800}.dog-progress-stats{color:#4338ca;flex-wrap:wrap;gap:12px 20px;font-size:.95rem;font-weight:600;display:flex}.dog-card-footer-actions{border-top:1px solid #f1f5f9;margin-top:10px;padding-top:12px}.dog-progress-nav-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:1px solid #0000;border-radius:10px;min-height:40px;padding:10px 14px;font-size:.95rem;font-weight:700;box-shadow:0 2px 8px #2563eb38}.dog-progress-nav-btn:hover{filter:brightness(1.07)}.dog-card-main-hit{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;background:0 0;border:none;border-radius:6px;padding:0}.dog-card-main-hit:hover{opacity:.92}.admin-dog-points-table{border-collapse:collapse;width:100%;font-size:.88rem}.admin-dog-points-table th,.admin-dog-points-table td{text-align:left;vertical-align:top;border:1px solid #e2e8f0;padding:8px 10px}.admin-dog-points-table th{color:#475569;background:#f8fafc;font-weight:700}.admin-dog-points-table-row{cursor:pointer}.admin-dog-points-table-row:hover{background:#f1f5f9}.admin-dog-points-tabs{flex-wrap:wrap;gap:8px;margin:12px 0;display:flex}.admin-dog-points-tabs .auth-button{box-sizing:border-box;min-height:44px;margin-top:0}.admin-dog-points-points-row{flex-direction:row;align-items:stretch;gap:10px;margin-bottom:4px;display:flex}.admin-dog-points-sign-group{flex-direction:row;flex-shrink:0;gap:6px;display:flex}.admin-dog-points-sign-group .auth-button{box-sizing:border-box;min-width:48px;min-height:44px;margin-top:0;padding:8px 12px;font-size:1.25rem;font-weight:800}.admin-dog-points-points-input{flex:1;min-width:0}.admin-dog-points-inline-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;margin-bottom:12px;display:flex}.admin-dog-points-inline-actions .auth-button{margin-top:0}.admin-dog-points-panel .impersonate-panel .auth-button.auth-button-primary{box-sizing:border-box;width:100%;min-height:48px;margin-top:12px}.admin-pts-pos{color:#15803d;font-weight:700}.admin-pts-neg{color:#b91c1c;font-weight:700}.admin-stats{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:24px;display:grid}.admin-stat{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px;box-shadow:0 1px 2px #0f172a0a}.admin-stat-val{color:#0f172a;font-size:1.35rem;font-weight:800;display:block}.admin-stat-label{text-transform:uppercase;color:#64748b;margin-top:4px;font-size:.65rem;display:block}.dog-page-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.dog-page-actions .auth-button.refresh{margin-bottom:0}.data-card-clickable{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;transition:border-color .15s,box-shadow .15s}.data-card-clickable:hover{border-color:#93c5fd;box-shadow:0 2px 8px #2563eb14}.dog-card-hint{margin-top:4px;font-style:italic}.dog-back-link{color:#1d4ed8;cursor:pointer;box-sizing:border-box;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;justify-content:center;align-items:center;gap:6px;min-height:42px;margin:0 0 12px;padding:10px 14px;font-size:.9rem;font-weight:700;text-decoration:none;transition:background .15s,border-color .15s,transform 80ms;display:inline-flex}.dog-back-link:hover{background:#dbeafe;border-color:#93c5fd;text-decoration:none}.dog-back-link:active{transform:translateY(1px)}.dog-lock-notice{color:#b45309;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:12px 14px}.dog-form.dog-form{margin-top:8px}.dog-stepper-row{align-items:center;gap:10px;margin-top:6px;display:flex}.dog-height-input{text-align:center;max-width:88px}.dog-step-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:999px;width:40px;height:40px;font-size:1.25rem;font-weight:700;line-height:1}.dog-step-btn:hover:not(:disabled){filter:brightness(1.06)}.dog-step-btn:disabled{opacity:.45;cursor:not-allowed}.dog-textarea{resize:vertical;min-height:88px}.dog-checkbox-row{color:#334155;cursor:pointer;align-items:flex-start;gap:10px;font-size:.95rem;display:flex}.dog-checkbox-row input{margin-top:3px}.dog-handlers-block{margin-top:4px}.dog-handler-checklist{flex-direction:column;gap:8px;margin:8px 0 0;padding:0;list-style:none;display:flex}.dog-handler-account{color:#64748b;font-size:.95em;font-weight:400}.dog-card-edit-hit{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;background:0 0;border:none;padding:0;display:block}.handler-basket-row{border-top:1px solid #e2e8f0;margin-top:10px;padding-top:10px}.in-basket-pill{color:#15803d;margin-top:8px;font-size:.875rem;font-weight:600;display:inline-block}.small-hint{margin:6px 0 0;font-size:.9rem}.dog-form-actions{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}.dog-form-actions .auth-button{margin-top:0}.dog-card-row{flex-direction:row;align-items:flex-start;gap:14px}.dog-card-text{text-align:left;flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.dog-mug-thumb{object-fit:cover;border:1px solid #e2e8f0;border-radius:10px;flex-shrink:0;width:56px;height:56px}.dog-mug-placeholder{color:#94a3b8;background:#e2e8f0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.1rem;font-weight:800;display:flex}.dog-mugshot-row{flex-wrap:wrap;align-items:flex-start;gap:14px;margin-top:6px;display:flex}.dog-mug-preview{object-fit:cover;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;width:120px;height:120px}.dog-mug-preview-empty{color:#94a3b8;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.dog-mugshot-actions{flex-direction:column;flex:1;align-items:flex-start;gap:8px;min-width:160px;display:flex}.dog-mugshot-actions input[type=file]{max-width:100%;font-size:.8rem}.dog-mug-remove{margin-top:4px}
