:root{--parkrun-aubergine:#4c1a57;--parkrun-apricot:#f7a541;--parkrun-white:#fff;--parkrun-black:#000;--parkrun-grey:#666;--parkrun-light-grey:#f5f5f5}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--parkrun-light-grey);color:var(--parkrun-black);font-family:Atkinson Hyperlegible,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{flex-direction:column;max-width:100%;min-height:100vh;margin:0 auto;display:flex}.app-header{background-color:var(--parkrun-aubergine);color:var(--parkrun-white);padding:1rem}.breadcrumbs{color:#fffc;background:#ffffff1f;border-radius:999px;flex-wrap:wrap;align-items:center;gap:.5rem;width:fit-content;margin-bottom:.75rem;padding:.35rem .6rem;font-size:.85rem;display:flex}.breadcrumbs a{color:var(--parkrun-apricot);font-weight:600;text-decoration:none}.breadcrumbs a:hover,.breadcrumbs a:focus-visible{text-decoration:underline}.breadcrumbs span[aria-current=page]{color:var(--parkrun-white);font-weight:600}.header-content{text-align:center;flex:1;justify-content:space-between;align-items:center;display:flex}.app-header h1{margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.app-header p{opacity:.95;font-size:.9rem}.personal-barcode-toggle{color:var(--parkrun-white);cursor:pointer;background-color:#fff3;border:1px solid #ffffff4d;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;transition:background-color .2s}.personal-barcode-toggle:hover{background-color:#ffffff4d}.personal-barcode-toggle:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--parkrun-apricot);outline-offset:2px}.personal-barcode-modal{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.personal-barcode-content{background-color:var(--parkrun-white);border-radius:12px;width:100%;max-width:500px;max-height:90vh;padding:2rem;overflow-y:auto}.personal-barcode-content h2{color:var(--parkrun-aubergine);margin-bottom:.5rem}.personal-barcode-content>p{color:var(--parkrun-grey);margin-bottom:1.5rem;font-size:.9rem}.personal-barcode-form{flex-direction:column;gap:1rem;display:flex}.personal-barcode-form label{flex-direction:column;gap:.5rem;font-weight:500;display:flex}.personal-barcode-form input{border:2px solid var(--parkrun-grey);border-radius:6px;padding:.75rem;font-size:1rem}.personal-barcode-form input:focus{border-color:var(--parkrun-aubergine);outline:none}.personal-barcode-actions{gap:.75rem;margin-top:1rem;display:flex}.personal-barcode-button{cursor:pointer;border:none;border-radius:6px;flex:1;padding:.75rem;font-size:1rem;font-weight:500;transition:all .2s}.personal-barcode-button-primary{background-color:var(--parkrun-apricot);color:var(--parkrun-white)}.personal-barcode-button-primary:hover{background-color:#e6942d}.personal-barcode-button-secondary{background-color:var(--parkrun-grey);color:var(--parkrun-white)}.personal-barcode-button-secondary:hover{background-color:#555}.personal-barcode-card{background-color:var(--parkrun-white);border-radius:12px;flex-direction:column;align-items:center;width:100%;max-width:500px;max-height:90vh;padding:1.5rem;display:flex;overflow-y:auto;box-shadow:0 4px 12px #00000026}.personal-barcode-card-canvas{background-color:var(--parkrun-white);border:2px solid var(--parkrun-grey);aspect-ratio:85.6/53.98;box-sizing:border-box;border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:.5rem;width:100%;max-width:85.6mm;margin-bottom:1rem;padding:.75rem;display:flex}.personal-barcode-canvas-title{color:var(--parkrun-aubergine);text-align:center;margin:0;font-size:1rem;font-weight:700;line-height:1.2}.personal-barcode-canvas-barcode{flex-shrink:0;justify-content:center;align-items:center;width:100%;padding:.25rem 0;display:flex}.personal-barcode-canvas-content{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;width:100%;display:flex}.personal-barcode-canvas-line{text-align:center;width:100%;line-height:1.2}.personal-barcode-canvas-value{color:var(--parkrun-black);word-break:break-word;font-size:.7rem;display:block}.personal-barcode-canvas-barcode-id{font-weight:700}.personal-barcode-card-actions{flex-flow:wrap;flex-shrink:0;justify-content:center;gap:.5rem;margin-top:0;display:flex}.personal-barcode-card-actions .personal-barcode-button{flex:1;min-width:80px;max-width:150px}.app-main{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2rem;width:100%;max-width:600px;margin:0 auto;padding:1rem;display:flex}footer{background-color:var(--parkrun-aubergine);color:var(--parkrun-white);text-align:center;flex-shrink:0;margin-top:auto;padding:1rem 2rem;font-size:.875rem;line-height:1.4}footer p{margin:.25rem 0}footer a{color:var(--parkrun-white);text-decoration:underline;-webkit-text-decoration-color:var(--parkrun-apricot);text-decoration-color:var(--parkrun-apricot);text-underline-offset:2px;text-decoration-thickness:2px;transition:color .2s,text-decoration-color .2s}footer a:hover{color:var(--parkrun-apricot);-webkit-text-decoration-color:var(--parkrun-white);text-decoration-color:var(--parkrun-white)}footer a:focus-visible{outline:3px solid var(--parkrun-apricot);outline-offset:2px}footer strong{font-weight:600}.about-box{width:100%;max-width:500px}.about-toggle{background-color:var(--parkrun-white);border:2px solid var(--parkrun-aubergine);cursor:pointer;width:100%;color:var(--parkrun-aubergine);border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:1rem;font-weight:500;transition:all .2s;display:flex}.about-toggle:hover{background-color:var(--parkrun-light-grey);border-color:var(--parkrun-apricot)}.about-toggle:focus{outline:none;box-shadow:0 0 0 3px #4c1a571a}.about-toggle-text{text-align:left;flex:1}.about-toggle-icon{text-align:center;width:1.5rem;font-size:1.5rem;font-weight:700;line-height:1}.about-content{background-color:var(--parkrun-white);border:2px solid var(--parkrun-aubergine);text-align:left;border-radius:8px;margin-top:1rem;padding:1.5rem}.about-content h2{color:var(--parkrun-aubergine);margin-top:0;margin-bottom:1rem;font-size:1.5rem}.about-content h3{color:var(--parkrun-aubergine);margin-top:1.5rem;margin-bottom:.75rem;font-size:1.25rem}.about-content p{color:var(--parkrun-black);margin-bottom:1rem;line-height:1.6}.about-content ul{margin-bottom:1rem;padding-left:1.5rem}.about-content li{color:var(--parkrun-black);margin-bottom:.5rem;line-height:1.6}.about-content code{background-color:var(--parkrun-light-grey);color:var(--parkrun-aubergine);border-radius:4px;padding:.2rem .4rem;font-family:Atkinson Hyperlegible Mono,Courier New,Courier,monospace;font-size:.9em}.about-content .nav-indicator{color:var(--parkrun-aubergine);font-size:1.2em;font-weight:700}.about-note{border-top:1px solid var(--parkrun-light-grey);color:var(--parkrun-grey);margin-top:1.5rem;padding-top:1rem;font-size:.9rem}.token-display{background-color:var(--parkrun-white);border-radius:12px;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:500px;padding:2rem;display:flex;box-shadow:0 2px 8px #0000001a}.barcode-section{flex-direction:column;align-items:center;gap:1rem;width:100%;display:flex}.barcode-toggle-container{gap:.5rem;display:flex}.barcode-toggle{border:2px solid var(--parkrun-aubergine);background-color:var(--parkrun-white);color:var(--parkrun-aubergine);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.barcode-toggle:hover{background-color:var(--parkrun-light-grey)}.barcode-toggle.active{background-color:var(--parkrun-aubergine);color:var(--parkrun-white)}.barcode-container-wrapper{box-sizing:border-box;justify-content:center;align-items:center;gap:1rem;width:100%;max-width:100%;display:flex}.barcode-container{background-color:var(--parkrun-white);box-sizing:border-box;border-radius:8px;flex:1;justify-content:center;align-items:center;max-width:100%;min-height:150px;padding:1.5rem;display:flex;overflow:hidden}.barcode-container svg{max-width:100%;height:auto}.barcode-nav-button{color:var(--parkrun-aubergine);cursor:pointer;-webkit-user-select:none;user-select:none;background-color:#0000;border:none;justify-content:center;align-items:center;min-width:3rem;min-height:3rem;padding:.5rem 1rem;font-size:3rem;font-weight:700;line-height:1;transition:all .2s;display:flex}.barcode-nav-button:hover:not(:disabled){color:var(--parkrun-apricot);transform:scale(1.2)}.barcode-nav-button:active:not(:disabled){transform:scale(1.1)}.barcode-nav-button:disabled{color:var(--parkrun-grey);opacity:.3;cursor:not-allowed}.token-label{background-color:var(--parkrun-aubergine);border-radius:8px;justify-content:center;align-items:center;gap:0;width:100%;padding:1rem;display:flex}.token-label .token-prefix{margin-right:0}.token-label .token-input{margin-left:-.3rem}.token-prefix{color:var(--parkrun-apricot);-webkit-user-select:none;user-select:none;margin:0;padding:0;font-family:Atkinson Hyperlegible Mono,Courier New,Courier,monospace;font-size:2.5rem;font-weight:700;line-height:1}.token-input{letter-spacing:.3rem;color:var(--parkrun-apricot);text-align:center;width:auto;min-width:9rem;caret-color:var(--parkrun-apricot);box-sizing:content-box;background-color:#0000;border:2px solid #0000;outline:none;margin:0;padding:0 .5rem 0 0;font-family:Atkinson Hyperlegible Mono,Courier New,Courier,monospace;font-size:2.5rem;font-weight:700;line-height:1}.token-input:focus{border-color:var(--parkrun-apricot);background-color:#f7a5411a;border-radius:4px}.token-input::selection{background-color:var(--parkrun-apricot);color:var(--parkrun-aubergine)}.swipe-hint{color:var(--parkrun-grey);text-align:center;font-size:.875rem}@media (width<=480px){.token-prefix,.token-input{font-size:2rem}.token-input{letter-spacing:.2rem;min-width:7.5rem;margin-left:-.2rem;padding:0 .4rem}.barcode-container{padding:1rem}.barcode-container svg{width:min(100vw - 7rem,250px);max-width:min(100vw - 7rem,250px);height:auto}.barcode-nav-button{min-width:2.5rem;min-height:2.5rem;padding:.5rem;font-size:2.5rem}.barcode-container-wrapper{gap:.5rem}.about-content{padding:1rem}.about-content h2{font-size:1.25rem}.about-content h3{font-size:1.1rem}.personal-barcode-card{padding:1.5rem}.personal-barcode-card-barcode{padding:1rem}.personal-barcode-toggle{white-space:nowrap;padding:.4rem .75rem;font-size:.8rem}.app-footer{padding:1rem;font-size:.8rem}.app-footer p{margin:.4rem 0}}@media (width<=640px){footer{padding:.75rem 1rem;font-size:.8rem;line-height:1.3}footer p{margin:.25rem 0}}.header-actions{align-items:center;gap:.75rem;display:flex}.print-button{color:var(--parkrun-white);cursor:pointer;background-color:#fff3;border:1px solid #ffffff4d;border-radius:6px;padding:.5rem 1rem;font-size:1.2rem;line-height:1;transition:background-color .2s}.print-button:hover{background-color:#ffffff4d}.print-button:focus{outline:none;box-shadow:0 0 0 3px #ffffff4d}.print-sheet-modal{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.print-sheet-modal-content{background-color:var(--parkrun-white);border-radius:12px;width:100%;max-width:800px;max-height:90vh;padding:2rem;overflow-y:auto;box-shadow:0 4px 12px #00000026}.print-sheet-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.print-sheet-header h2{color:var(--parkrun-aubergine);margin:0}.print-sheet-close{color:var(--parkrun-grey);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:2rem;line-height:1;transition:color .2s;display:flex}.print-sheet-close:hover{color:var(--parkrun-aubergine)}.print-sheet-info{color:var(--parkrun-grey);margin-bottom:1.5rem}.print-sheet-info p{margin:0}.print-sheet-preview{background-color:var(--parkrun-light-grey);border-radius:8px;max-height:400px;margin-bottom:1.5rem;padding:1rem;overflow-y:auto}.print-sheet-grid{grid-template-columns:repeat(4,1fr);gap:.5rem;width:100%;display:grid}.print-token{aspect-ratio:2;border:1px solid var(--parkrun-grey);background-color:var(--parkrun-white);box-sizing:border-box;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:100%;padding:.5rem;display:flex}.print-token-qr{flex-direction:row;gap:.5rem}.print-token-code{justify-content:center;align-items:center;display:flex;overflow:hidden}.print-token:not(.print-token-qr) .print-token-code{flex:1;width:100%}.print-token-qr .print-token-code{flex:none;width:40%;max-width:60px}.print-token-code svg{max-width:100%;height:auto}.print-token-label{text-align:center;color:var(--parkrun-black);font-family:Atkinson Hyperlegible Mono,Courier New,Courier,monospace;font-size:.75rem;font-weight:700}.print-token:not(.print-token-qr) .print-token-label{margin-top:.25rem}.print-token-qr .print-token-label{flex:1;justify-content:center;align-items:center;font-size:.7rem;display:flex}.print-sheet-actions{justify-content:flex-end;gap:.75rem;display:flex}.print-sheet-button{cursor:pointer;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.print-sheet-button-primary{background-color:var(--parkrun-apricot);color:var(--parkrun-white)}.print-sheet-button-primary:hover{background-color:#e6942d}.print-sheet-button-secondary{background-color:var(--parkrun-grey);color:var(--parkrun-white)}.print-sheet-button-secondary:hover{background-color:#555}@media (width<=480px){.header-actions{gap:.5rem}.print-button{padding:.4rem .75rem;font-size:1rem}.print-sheet-modal-content{padding:1.5rem}.print-sheet-grid{grid-template-columns:repeat(2,1fr)}.print-token-label{font-size:.65rem}}@media print{@page{size:A4;margin:4mm 10mm}html,body{height:100%;margin:0;padding:0}body *{visibility:hidden}.print-sheet-modal,.print-sheet-modal *{visibility:visible}.print-sheet-modal{background:#fff;width:100%;height:100%;margin:0;padding:0;position:absolute;top:0;left:0}.print-sheet-modal-content{box-shadow:none;max-width:none;max-height:none;margin:0;padding:0;overflow:visible}.print-sheet-header,.print-sheet-info,.print-sheet-actions{display:none}.print-sheet-preview{background:0 0;max-height:none;margin:0;padding:0;overflow:visible}.print-sheet-grid{page-break-inside:avoid;break-inside:avoid;grid-template-columns:repeat(4,40mm);grid-auto-rows:20mm;gap:0;width:160mm;margin:0 auto;padding:0;display:grid}.print-token{width:40mm;height:20mm;aspect-ratio:none;page-break-inside:avoid;break-inside:avoid;box-sizing:border-box;background:#fff;border:.5pt solid #000;margin:0;padding:1mm}.print-token-qr{flex-direction:row;gap:1mm}.print-token-code{justify-content:center;align-items:center;display:flex}.print-token:not(.print-token-qr) .print-token-code{width:100%;height:12mm}.print-token-qr .print-token-code{flex:none;width:18mm;height:18mm}.print-token-code svg{max-width:100%;max-height:100%}.print-token:not(.print-token-qr) .print-token-code svg{height:12mm}.print-token-label{color:#000;text-align:center;font-size:12pt;font-weight:700}.print-token:not(.print-token-qr) .print-token-label{margin-top:.25mm}.print-token-qr .print-token-label{flex:1;justify-content:center;align-items:center;font-size:11pt;display:flex}}@media (prefers-color-scheme:dark){body{color:var(--parkrun-white);background-color:#1a1a1a}.token-display{background-color:#2a2a2a}}#root{width:100%;min-height:100vh}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
