@charset "UTF-8";@import url(https://fonts.googleapis.com/css2?family=Archivo+Black&family=DM+Sans:wght@400;500;700&display=swap);:root{--primary:gold;--secondary:#fafafa;--accent:#fdb813;--text:#e5e7eb;--text-light:#9ca3af;--bg:#0d0d0d;--bg-card:#1a1a2e;--bg-card-hover:#252540;--bg-surface:#16162a;--border:#ffffff1a;--white:#fff;--success:#10b981;--error:#ef4444;--warning:#f59e0b}*{box-sizing:border-box}body,html{overflow-x:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0d0d0d;background:var(--bg);color:#e5e7eb;color:var(--text);font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{left:0;position:absolute;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.leaflet-tile::selection{background:#0000}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{height:1600px;-webkit-transform-origin:0 0;width:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-height:none!important;max-width:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-height:none!important;max-width:none!important;padding:0;width:auto}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;height:0;width:0;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{height:1px;width:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{pointer-events:visiblePainted;pointer-events:auto;position:relative;z-index:800}.leaflet-bottom,.leaflet-top{pointer-events:none;position:absolute;z-index:1000}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{clear:both;float:left}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;color:#000;display:block;height:26px;line-height:26px;text-align:center;text-decoration:none;width:26px}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.leaflet-bar a.leaflet-disabled{background-color:#f4f4f4;color:#bbb;cursor:default}.leaflet-touch .leaflet-bar a{height:30px;line-height:30px;width:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);height:36px;width:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{height:44px;width:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{background:#fff;color:#333;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{overflow-x:hidden;overflow-y:scroll;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;line-height:1.4;padding:0 5px}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;height:.6669em;vertical-align:initial!important;width:1em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{background:#fffc;border:2px solid #777;border-top:none;box-sizing:border-box;line-height:1.1;padding:2px 5px 1px;text-shadow:1px 1px #fff;white-space:nowrap}.leaflet-control-scale-line:not(:first-child){border-bottom:none;border-top:2px solid #777;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{margin-bottom:20px;position:absolute;text-align:center}.leaflet-popup-content-wrapper{border-radius:12px;padding:1px;text-align:left}.leaflet-popup-content{font-size:13px;font-size:1.08333em;line-height:1.3;margin:13px 24px 13px 20px;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{height:20px;left:50%;margin-left:-20px;margin-top:-1px;overflow:hidden;pointer-events:none;position:absolute;width:40px}.leaflet-popup-tip{height:17px;margin:-10px auto 0;padding:1px;pointer-events:auto;transform:rotate(45deg);width:17px}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;box-shadow:0 3px 14px #0006;color:#333}.leaflet-container a.leaflet-popup-close-button{background:#0000;border:none;color:#757575;font:16px/24px Tahoma,Verdana,sans-serif;height:24px;position:absolute;right:0;text-align:center;text-decoration:none;top:0;width:24px}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678);margin:0 auto;width:24px}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{background-color:#fff;border:1px solid #fff;border-radius:3px;box-shadow:0 1px 3px #0006;color:#222;padding:6px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;white-space:nowrap}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{background:#0000;border:6px solid #0000;content:"";pointer-events:none;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{border-top-color:#fff;bottom:0;margin-bottom:-12px}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-left:-6px;margin-top:-12px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;left:0;margin-left:-12px}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.landing-page{background:var(--bg);color:var(--text);font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;overflow-x:hidden}.landing-page .container{margin:0 auto;max-width:1400px;padding:0 2rem;position:relative;z-index:1}.landing-nav{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#0d0d0df2;border-bottom:1px solid #ffffff0d;left:0;padding:1rem 0;position:fixed;right:0;top:0;z-index:1000}.landing-nav .nav-content{align-items:center;display:flex;gap:3rem}.landing-nav .nav-logo-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;padding:0}.landing-nav .nav-logo-img{height:40px;width:auto}.landing-nav .nav-links{display:flex;gap:2rem;margin-right:auto}.landing-nav .nav-link{background:none;border:none;color:#fffc;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;transition:color .3s ease}.landing-nav .nav-link:hover{color:var(--primary)}.landing-nav .nav-link:focus,.landing-nav .nav-link:hover{background:none!important;background-color:initial!important;border:none!important;box-shadow:none!important}.landing-nav .nav-link:focus{outline:none}.landing-nav .nav-auth{display:flex;gap:3rem}.landing-page .landing-nav .btn-login{background:#0000;border:none;color:#fffc;cursor:pointer;font-family:inherit;font-size:1.1rem;font-weight:500;padding:0;transition:color .3s ease}.landing-page .landing-nav .btn-login:focus,.landing-page .landing-nav .btn-login:hover{background:none!important;background-color:initial!important;border:none!important;box-shadow:none!important;color:var(--primary);outline:none}.landing-page .landing-nav .btn-signup{background:#0000;border:none;color:#fffc;cursor:pointer;font-family:inherit;font-size:1.1rem;font-weight:500;padding:0;transition:color .3s ease}.landing-page .landing-nav .btn-signup:focus,.landing-page .landing-nav .btn-signup:hover{background:none!important;background-color:initial!important;border:none!important;box-shadow:none!important;color:var(--primary);outline:none}.landing-nav .nav-hamburger{background:none;border:none;border-radius:8px;cursor:pointer;display:none;flex-direction:column;gap:5px;height:40px;justify-content:center;outline:none;padding:4px;transition:background .2s;width:40px;z-index:1001}.landing-nav .nav-hamburger:focus{outline:none}.landing-nav .nav-hamburger:hover{background:#ffffff14}.landing-nav .nav-hamburger span{background:var(--primary);border-radius:2px;display:block;height:2.5px;transform-origin:center;transition:all .3s ease;width:22px}.landing-nav .nav-hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.landing-nav .nav-hamburger.open span:nth-child(2){opacity:0}.landing-nav .nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.landing-nav .nav-auth-mobile{display:none}.nav-mobile-links{display:contents}.nav-dropdown-backdrop,.nav-mobile-links .nav-link svg{display:none}.landing-page .hero{align-items:center;background:#0d0d0d;display:flex;min-height:100vh;overflow:hidden;padding-top:80px;position:relative}.landing-page .hero:before{animation:pulse 8s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#ffd70026 0,#0000 50%),radial-gradient(circle at 80% 50%,#fdb8131a 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.6}}.landing-page .hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr}.landing-page .hero-text h1{animation:slideInLeft .8s ease-out;color:#fff;font-family:Archivo Black,-apple-system,BlinkMacSystemFont,sans-serif;font-size:clamp(3rem,6vw,5rem);letter-spacing:-.03em;line-height:1.1;margin-bottom:1.5rem}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.landing-page .hero-text h1 .highlight{color:var(--primary)}.landing-page .hero-logo{animation:slideInLeft .8s ease-out;height:auto;margin-bottom:1.5rem;max-width:500px;width:100%}.landing-page .hero-text p{animation:slideInLeft .8s ease-out .2s backwards;color:#fffc;font-size:1.35rem;margin-bottom:2.5rem;max-width:550px}.landing-page .cta-group{animation:slideInLeft .8s ease-out .4s backwards;display:flex;flex-wrap:wrap;gap:1.5rem}.landing-page .btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-family:inherit;font-size:1.125rem;font-weight:700;padding:1.25rem 2.5rem;text-decoration:none;transition:all .3s ease}.landing-page .btn-primary{background:var(--primary);color:#0d0d0d}.landing-page .btn-primary:hover{transform:translateY(-2px)}.landing-page .btn-secondary{background:#1a1a2e;border:none;color:#fff}.landing-page .btn-secondary:hover{background:#12121f;color:var(--primary)}.landing-page .btn-white{background:#fff;color:#0d0d0d;font-size:1.25rem;padding:1.5rem 4rem}.landing-page .btn-white:hover{box-shadow:0 20px 60px #0003;transform:translateY(-5px)}.landing-page .hero-visual{animation:slideInRight .8s ease-out .3s backwards;position:relative}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.landing-page .hero-screenshot-container{position:relative;transform:perspective(1000px) rotateY(-5deg);transition:transform .5s ease}.landing-page .hero-screenshot-container:hover{transform:perspective(1000px) rotateY(0deg)}.landing-page .hero-screenshot{height:auto;max-width:700px;width:100%}.landing-page .hero-carousel,.landing-page .hero-screenshot{border-radius:16px;box-shadow:0 30px 80px #00000080,0 0 0 1px #ffffff1a}.landing-page .hero-carousel{overflow:hidden;position:relative;transform:perspective(1000px) rotateY(-5deg);transition:transform .5s ease}.landing-page .hero-carousel:hover{transform:perspective(1000px) rotateY(0deg)}.landing-page .hero-carousel-track{display:flex;transition:transform .5s ease-in-out}.landing-page .hero-carousel-slide{flex-shrink:0;min-width:100%}.landing-page .hero-carousel-slide img{display:block;height:auto;width:100%}.landing-page .hero-carousel-dots{bottom:1rem;display:flex;gap:.5rem;left:50%;position:absolute;transform:translateX(-50%);z-index:10}.landing-page .hero-carousel-dot{background:#fff6;border:none;border-radius:50%;cursor:pointer;height:10px;padding:0;transition:all .3s ease;width:10px}.landing-page .hero-carousel-dot:hover{background:#ffffffb3}.landing-page .hero-carousel-dot.active{background:var(--primary);transform:scale(1.2)}.landing-page .hero-carousel-label{background:#0d0d0dcc;border-radius:20px;bottom:2.5rem;color:var(--primary);font-size:.875rem;font-weight:600;left:50%;padding:.5rem 1rem;position:absolute;transform:translateX(-50%);z-index:10}.landing-page .benefits-strip{background:var(--secondary);border-bottom:1px solid #ffffff1a;border-top:1px solid #ffffff1a;padding:2rem 0}.landing-page .benefits-grid{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}.landing-page .benefit-item{align-items:center;display:flex;gap:.75rem}.landing-page .benefit-icon{color:var(--primary);height:32px;width:32px}.landing-page .benefit-icon svg{height:100%;width:100%}.landing-page .benefit-text{color:#ffffffe6;font-size:1rem;font-weight:600}.landing-page .section-header{margin-bottom:4rem;text-align:center}.landing-page .section-label{color:var(--primary);font-size:.875rem;font-weight:700;letter-spacing:.15em;margin-bottom:1rem;text-transform:uppercase}.landing-page .section-label.light{color:var(--primary)}.landing-page .section-title{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:clamp(2.5rem,5vw,4rem);letter-spacing:-.02em;line-height:1.1}.landing-page .section-title.light{color:#fff}.landing-page .app-preview{align-items:center;background:var(--primary);display:flex;min-height:100vh;padding:6rem 0}.landing-page .app-preview .section-label,.landing-page .app-preview .section-title{color:#0d0d0d}.landing-page .preview-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:3rem}.landing-page .preview-tab{background:#0d0d0d1a;border:2px solid #0000;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.landing-page .preview-tab:hover{background:#0d0d0d26}.landing-page .preview-tab.active{background:#0d0d0d;border-color:#0d0d0d;color:var(--primary)}.landing-page .preview-content{position:relative}.landing-page .preview-panel{animation:fadeIn .5s ease;display:none}.landing-page .preview-panel.active{display:block}.landing-page .preview-layout{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1.2fr 1fr}.landing-page .preview-screenshot-container{border-radius:16px;box-shadow:0 30px 80px #00000040;overflow:hidden;transition:transform .4s ease,box-shadow .4s ease}.landing-page .preview-screenshot-container:hover{box-shadow:0 40px 100px #0000004d;transform:translateY(-5px)}.landing-page .preview-screenshot{display:block;height:auto;width:100%}.landing-page .preview-info{text-align:left}.landing-page .preview-info h3{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:2rem;margin-bottom:1.5rem}.landing-page .preview-info p{color:#0d0d0d;font-size:1.125rem;line-height:1.7;margin-bottom:2rem}.landing-page .preview-features{display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:0;padding:0}.landing-page .preview-features li{align-items:center;color:#0d0d0d;display:flex;font-size:1.1rem;gap:.75rem}.landing-page .preview-features li:before{align-items:center;background:#0d0d0d;border-radius:50%;color:var(--primary);content:"\2713";display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.landing-page .features-detailed{background:var(--bg);padding:6rem 0}.landing-page .feature-row{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin-bottom:6rem}.landing-page .feature-row:last-child{margin-bottom:0}.landing-page .feature-row.reverse .feature-image{order:2}.landing-page .feature-row.reverse .feature-content{order:1}.landing-page .feature-image{border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.landing-page .feature-image img{display:block;height:auto;width:100%}.landing-page .feature-content h3{color:#fff;font-family:Archivo Black,sans-serif;font-size:2rem;margin-bottom:1rem}.landing-page .feature-content p{color:#fffc;font-size:1.125rem;line-height:1.7;margin-bottom:1.5rem}.landing-page .feature-list{list-style:none;margin:0;padding:0}.landing-page .feature-list li{align-items:flex-start;color:#fffc;display:flex;font-size:1rem;gap:.75rem;margin-bottom:1rem}.landing-page .feature-list li:before{align-items:center;background:var(--primary);border-radius:50%;color:var(--secondary);content:"\2713";display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.landing-page .integration{align-items:center;background:#0d0d0d;display:flex;min-height:100vh;padding:6rem 0}.landing-page .integration .section-label,.landing-page .integration .section-title{color:var(--primary)}.landing-page .integration-content{grid-gap:5rem;align-items:center;display:grid;gap:5rem;grid-template-columns:1fr 1fr}.landing-page .integration-description{color:#fffc;font-size:1.25rem;margin:2rem 0}.landing-page .benefits-list{display:flex;flex-direction:column;gap:.625rem;list-style:none;margin:1.25rem 0;padding:0}.landing-page .benefits-list li{align-items:flex-start;color:#ffffffe6;display:flex;font-size:1rem;gap:.75rem;line-height:1.4}.landing-page .benefits-list li:before{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;content:"\2713";display:flex;flex-shrink:0;font-size:.6875rem;font-weight:700;height:20px;justify-content:center;margin-top:2px;width:20px}.landing-page .integration-visual{align-items:center;background:#0d0d0d;display:flex;justify-content:center;position:relative}.landing-page .device-badge{align-items:center;background:#ffffff1a;border-radius:12px;display:flex;gap:.75rem;margin-bottom:2rem;padding:1rem 1.5rem;width:-webkit-fit-content;width:fit-content}.landing-page .device-icon{font-size:1.5rem}.landing-page .device-badge span{color:#ffffffe6;font-weight:600}.landing-page .watch-mockup{border-radius:16px;box-shadow:0 24px 64px #00000080;max-width:340px;overflow:hidden;transition:transform .4s ease}.landing-page .watch-mockup:hover{transform:translateY(-6px)}.landing-page .wm-header{background:var(--primary);padding:1rem 1.25rem}.landing-page .wm-workout-title{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:1.5rem;line-height:1.1;margin-bottom:.25rem}.landing-page .wm-workout-date{color:#0d0d0da6;font-size:.8125rem;font-weight:500}.landing-page .wm-body{background:#16163a;padding:1rem 1.25rem}.landing-page .wm-section-label{color:#ffffff59;font-size:.6875rem;font-weight:600;letter-spacing:.1em;margin-bottom:.75rem;text-transform:uppercase}.landing-page .wm-step-row{align-items:center;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.5rem}.landing-page .wm-dist{color:#ffffffd9;font-size:.9375rem;font-weight:600;min-width:36px}.landing-page .wm-badge{border-radius:8px;font-size:.75rem;font-weight:600;line-height:1.3;padding:.3rem .625rem;text-align:right}.landing-page .wm-badge small{display:block;font-size:.625rem;font-weight:400;opacity:.8}.landing-page .wm-easy{background:#10b9812e;color:#34d399}.landing-page .wm-tempo{background:#8b5cf633;color:#a78bfa}.landing-page .wm-repeat{border-left:3px solid #6366f18c;margin:.25rem 0 .625rem;padding-left:.875rem}.landing-page .wm-repeat-count{color:#818cf8;font-size:.75rem;font-weight:700;margin-bottom:.375rem}.landing-page .wm-sync-status{align-items:center;border-top:1px solid #ffffff14;color:#10b981;display:flex;font-size:.75rem;font-weight:600;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.landing-page .wm-sync-status:before{background:#10b981;border-radius:50%;content:"";flex-shrink:0;height:7px;width:7px}.landing-page .watches-photo{border-radius:16px;display:block;height:auto;max-width:100%;width:100%}@media (max-width:768px){.landing-page .watches-photo{border-radius:0;height:auto;margin-left:-1.5rem;max-width:none;object-fit:contain;width:calc(100% + 3rem)}}.landing-page .community-section{background:#fff;padding:6rem 0}.landing-page .community-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.landing-page .community-card{background:var(--bg);border-radius:20px;padding:2.5rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.landing-page .community-card:hover{box-shadow:0 20px 60px #00000026;transform:translateY(-10px)}.landing-page .community-icon{background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:16px;color:var(--secondary);height:64px;margin:0 auto 1.5rem;padding:1rem;width:64px}.landing-page .community-icon svg{height:100%;width:100%}.landing-page .community-card h3{color:#fff;font-family:Archivo Black,sans-serif;font-size:1.5rem;margin-bottom:1rem}.landing-page .community-card p{color:#ffffffb3;font-size:1rem;line-height:1.6}.landing-page .how-it-works{align-items:center;background:var(--primary);display:flex;min-height:100vh;overflow:hidden;padding:6rem 0;position:relative}.landing-page .how-it-works .section-title{color:#0d0d0d}.landing-page .steps-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(4,1fr);margin-top:4rem}.landing-page .step{background:#0d0d0d0d;border:1px solid #0d0d0d1a;border-radius:20px;padding:2.5rem 2rem;position:relative;transition:all .3s ease}.landing-page .step:hover{background:#0d0d0d1a;border-color:#0d0d0d;transform:translateY(-5px)}.landing-page .step-number{align-items:center;background:#0d0d0d;border-radius:50%;box-shadow:0 10px 30px #0003;color:var(--primary);display:flex;font-family:Archivo Black,sans-serif;font-size:1.5rem;height:50px;justify-content:center;left:2rem;position:absolute;top:-20px;width:50px}.landing-page .step h3{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:1.25rem;margin-bottom:1rem;margin-top:1rem}.landing-page .step p{color:#0d0d0dcc;font-size:.95rem;line-height:1.6}.landing-page .cta-section{background:linear-gradient(135deg,var(--primary) 0,var(--accent) 100%);overflow:hidden;padding:8rem 0;position:relative;text-align:center}.landing-page .cta-section:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:150%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:150%}@keyframes rotate{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.landing-page .cta-content{position:relative;z-index:1}.landing-page .cta-content h2{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:clamp(2.5rem,5vw,4.5rem);line-height:1.1;margin-bottom:1.5rem}.landing-page .cta-content p{color:#000000b3;font-size:1.5rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:700px}.landing-page .landing-footer{background:#0d0d0d;color:#fff9;padding:4rem 0 2rem}.landing-page .footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr;margin-bottom:3rem}.landing-page .footer-section h4{color:#fff;font-family:Archivo Black,sans-serif;font-size:1.25rem;margin-bottom:1.5rem}.landing-page .footer-brand .footer-logo{height:50px;margin-bottom:1rem;width:auto}.landing-page .footer-section a,.landing-page .footer-section button,.landing-page .footer-section p{background:none;border:none;color:#fff9;cursor:pointer;display:block;font-family:inherit;font-size:1rem;margin-bottom:.75rem;padding:0;text-align:left;text-decoration:none;transition:color .3s ease}.landing-page .footer-section a:hover,.landing-page .footer-section button:hover{color:var(--primary)}.landing-page .copyright{border-top:1px solid #ffffff1a;font-size:.875rem;padding-top:2rem;text-align:center}@media (max-width:1024px){.landing-page .container{padding:0 1.5rem}.landing-page .hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.landing-page .hero-text h1{font-size:3rem}.landing-page .hero-logo,.landing-page .hero-text p{margin-left:auto;margin-right:auto}.landing-page .hero-logo{max-width:400px}.landing-page .cta-group{justify-content:center}.landing-page .hero-visual{margin:0 auto;max-width:600px;order:2}.landing-page .hero-carousel,.landing-page .hero-carousel:hover,.landing-page .hero-screenshot-container{transform:none}.landing-page .feature-row,.landing-page .integration-content,.landing-page .preview-layout{gap:3rem;grid-template-columns:1fr}.landing-page .preview-info{order:2;text-align:center}.landing-page .preview-screenshot-container{margin:0 auto;max-width:600px}.landing-page .preview-features{align-items:center}.landing-page .feature-row.reverse .feature-content,.landing-page .feature-row.reverse .feature-image{order:0}.landing-page .integration-text,.landing-page .integration-text .section-label,.landing-page .integration-text .section-title{text-align:center}.landing-page .integration-text .btn{display:inline-block}.landing-page .benefits-list{margin-left:auto;margin-right:auto;max-width:400px;text-align:left}.landing-page .benefits-list li{text-align:left}.landing-page .integration-visual{display:block;order:-1;overflow:hidden}.landing-page .steps-container{gap:2.5rem 2rem;grid-template-columns:repeat(2,1fr)}.landing-page .community-grid{grid-template-columns:1fr;margin:0 auto;max-width:500px}.landing-page .footer-content{gap:2rem;grid-template-columns:1fr;text-align:left}.landing-page .footer-section a,.landing-page .footer-section button{text-align:left}.landing-page .footer-brand .footer-logo{margin-left:0;margin-right:0}}@media (max-width:768px){.landing-nav .nav-hamburger{display:flex;margin-left:auto}.landing-nav .nav-links{align-items:stretch;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#0d0d0dfa;border-bottom:1px solid #ffd70026;bottom:auto;box-shadow:0 12px 32px #00000080;flex-direction:column;gap:0;justify-content:flex-start;left:0;opacity:0;position:fixed;right:0;top:72px;transform:translateY(-10px);transition:opacity .22s ease,visibility .22s ease,transform .22s ease;visibility:hidden;z-index:999}.landing-nav .nav-links.open{opacity:1;transform:translateY(0);visibility:visible}.nav-mobile-links{display:flex;flex-direction:column;padding:.375rem 0}.nav-mobile-links .nav-link svg{display:block;flex-shrink:0;opacity:.4}.landing-nav .nav-link{align-items:center;border-bottom:1px solid #ffffff0d;border-radius:0;color:#ffffffd9;display:flex;font-size:1rem;font-weight:500;justify-content:space-between;padding:1rem 1.25rem;text-align:left;transition:color .2s,padding-left .2s;width:100%}.landing-nav .nav-link:hover{background:#ffd7000a;color:var(--primary);padding-left:1.5rem}.landing-nav .nav-auth{display:none}.landing-nav .nav-auth-mobile{border-top:1px solid #ffffff0d;display:flex;flex-direction:column;gap:0;padding:0}.landing-nav .nav-auth-mobile .btn-login,.landing-nav .nav-auth-mobile .btn-signup{background:none!important;border:none!important;border-bottom:1px solid #ffffff0d!important;border-radius:0!important;color:var(--primary)!important;cursor:pointer;display:block;font-family:inherit;font-size:1rem;font-weight:500;padding:1rem 1.25rem;text-align:left;transition:color .2s,padding-left .2s,background .2s;width:100%}.landing-nav .nav-auth-mobile .btn-login:hover,.landing-nav .nav-auth-mobile .btn-signup:hover{background:#ffd7000a!important;color:#fff!important;padding-left:1.5rem}.nav-dropdown-backdrop{animation:fadeIn .22s ease;background:#00000080;bottom:0;display:block;left:0;position:fixed;right:0;top:72px;z-index:998}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.landing-page .hero{min-height:100vh;min-height:100svh;padding:72px 0 2rem}.landing-page .app-preview{min-height:100vh;min-height:100svh;padding:2rem 0 2.5rem}.landing-page .integration{align-items:stretch;display:flex;height:100vh;height:100svh;padding:0}.landing-page .integration .container{align-items:center;display:flex;width:100%}.landing-page .integration .integration-content{gap:1rem;width:100%}.landing-page .how-it-works{min-height:100vh;min-height:100svh;padding:2rem 0}.landing-page .hero-visual{display:none}.landing-page .hero-text h1{font-size:2.25rem}.landing-page .hero-text p{font-size:1.125rem;margin-bottom:2rem}.landing-page .hero-logo{max-width:300px}.landing-page .hero-carousel-label{bottom:2rem;font-size:.75rem;padding:.4rem .8rem}.landing-page .hero-carousel-dots{bottom:.75rem}.landing-page .hero-carousel-dot{height:8px;width:8px}.landing-page .cta-group{flex-direction:column;gap:1rem}.landing-page .btn{padding:1rem 2rem;text-align:center;width:100%}.landing-page .benefits-grid{flex-direction:column;gap:1rem}.landing-page .preview-tabs{flex-wrap:wrap;gap:.25rem;justify-content:center}.landing-page .preview-tab{flex:0 1 auto;font-size:.8rem;padding:.6rem .9rem}.landing-page .preview-info h3{font-size:1.5rem}.landing-page .preview-info p{font-size:1rem}.landing-page .preview-features li{font-size:.9rem}.landing-page .preview-screenshot{display:block;margin:0 auto;max-height:42vh;max-width:100%;width:auto}.landing-page .preview-screenshot-container{display:flex;justify-content:center}.landing-page .preview-info h3,.landing-page .preview-info>p{display:none}.landing-page .preview-info{margin-top:1rem;padding:0 1rem;text-align:left}.landing-page .preview-features{align-items:flex-start;gap:.625rem}.landing-page .section-header{margin-bottom:1.5rem}.landing-page .section-title{font-size:clamp(2rem,8vw,2.5rem)}.landing-page .integration .section-title{font-size:clamp(1.75rem,7vw,2.25rem)}.landing-page .integration-description{font-size:1rem;margin:.75rem 0}.landing-page .benefits-list{margin:.75rem 0}.landing-page .watch-mockup{max-width:300px}.landing-page .wm-workout-title{font-size:1.25rem}.landing-page .steps-container{gap:2.5rem 1rem;grid-template-columns:repeat(2,1fr);margin-top:1.5rem}.landing-page .step{padding:1.75rem 1rem 1.25rem}.landing-page .step h3{font-size:.95rem;margin-bottom:.5rem;margin-top:.75rem}.landing-page .step p{font-size:.8125rem;line-height:1.5}.landing-page .feature-row{margin-bottom:3rem}.landing-page .feature-content h3{font-size:1.5rem}.landing-page .landing-footer{padding:2rem 0 1rem}.landing-page .footer-content{gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem;text-align:left}.landing-page .footer-brand{grid-column:1/-1}.landing-page .footer-brand .footer-logo{height:36px;margin-bottom:.5rem;margin-left:0;margin-right:0}.landing-page .footer-brand p{font-size:.8125rem}.landing-page .footer-section h4{font-size:.875rem;margin-bottom:.5rem}.landing-page .footer-section a,.landing-page .footer-section button{font-size:.875rem;margin-bottom:.375rem;text-align:left}.landing-page .copyright{font-size:.75rem;padding-top:1rem}}@media (max-width:480px){.landing-page .container{padding:0 1rem}.landing-nav .nav-logo-img{height:32px}.landing-page .hero-text h1{font-size:2rem}.landing-page .hero-text p{font-size:1rem}.landing-page .hero-logo{max-width:250px}.landing-page .hero{padding:72px 0 1.5rem}.landing-page .app-preview,.landing-page .how-it-works{padding:1.5rem 0}.landing-page .integration{padding:0}.landing-page .preview-tabs{display:flex;flex-wrap:nowrap;gap:.25rem;width:100%}.landing-page .preview-tab{flex:1 1;font-size:.7rem;min-width:0;padding:.625rem .25rem}.landing-page .preview-info h3{font-size:1.35rem}.landing-page .section-title{font-size:1.75rem}.landing-page .watch-mockup{max-width:270px}.landing-page .wm-workout-title{font-size:1.1rem}.landing-page .wm-body{padding:.875rem 1rem}.landing-page .step{padding:1.5rem .75rem 1rem}.landing-page .step-number{font-size:1.1rem;height:36px;left:.75rem;top:-14px;width:36px}.landing-page .step h3{font-size:.875rem;margin-bottom:.375rem;margin-top:.5rem}.landing-page .step p{font-size:.75rem;line-height:1.4}.landing-page .btn{font-size:1rem;padding:.875rem 1.5rem}.landing-page .preview-features li:before{font-size:.65rem;height:20px;width:20px}.landing-page .preview-features li{font-size:.9rem;gap:.5rem}}.auth-page{align-items:center;background:linear-gradient(135deg,#0d0d0d,#1a1a1a 50%,#0d0d0d);display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.auth-page:before{background:radial-gradient(circle at 20% 50%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 50%,#fdb81314 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.auth-container{max-width:420px;position:relative;width:100%;z-index:1}.auth-close-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-family:inherit;font-size:1.75rem;line-height:1;padding:0;position:absolute;right:16px;top:16px;transition:opacity .2s}.auth-close-btn:hover:not(:disabled){opacity:.7}.auth-close-btn:disabled{cursor:not-allowed;opacity:.5}.auth-header{margin-bottom:30px;text-align:center}.auth-logo{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:3rem;font-weight:700;letter-spacing:-1px;margin:0}.auth-tagline{color:var(--text-light);font-size:1rem;margin:8px 0 0}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 60px #00000080;padding:40px}.auth-title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;font-weight:600;margin:0 0 10px;text-align:center}.auth-subtitle{color:var(--text-light);font-size:.9rem;line-height:1.5;margin:0 0 24px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.form-group input{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:1rem;padding:14px 16px;transition:all .2s}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.auth-error{background:#ef44441a;border-left:4px solid #ef4444;color:#f87171}.auth-error,.auth-success{border-radius:8px;font-size:.875rem;padding:12px 16px;text-align:center}.auth-success{background:#48bb781a;border-left:4px solid #48bb78;color:#68d391}.forgot-password-btn{background:none;border:none;color:var(--text-light);cursor:pointer;display:block;font-family:inherit;font-size:.875rem;margin-top:-12px;padding:0;text-align:left;transition:color .2s;width:-webkit-fit-content;width:fit-content}.forgot-password-btn:hover:not(:disabled){color:var(--primary)}.forgot-password-btn:disabled{cursor:not-allowed;opacity:.6}.auth-submit{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;margin-top:10px;padding:16px;transition:transform .2s,box-shadow .2s}.auth-submit:hover:not(:disabled){box-shadow:0 6px 20px #ffd70066;transform:translateY(-2px)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{cursor:not-allowed;opacity:.6}.auth-switch{border-top:2px solid var(--border);margin-top:24px;padding-top:24px;text-align:center}.auth-switch p{color:var(--text-light);font-size:.875rem;margin:0}.auth-switch-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-left:6px;padding:0}.auth-switch-btn:hover{opacity:.7}.auth-switch-btn:disabled{cursor:not-allowed;opacity:.6}.auth-age-disclaimer{color:var(--text-light);font-size:.75rem;margin:16px 0 0;padding:0;text-align:center}@media (max-width:480px){.auth-card{padding:30px 24px}.auth-logo{font-size:2.5rem}}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{border:0;-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker-wrapper{border:0;display:inline-block;padding:0}.react-datepicker{background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;color:#000;display:inline-block;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;line-height:normal;position:relative}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{line-height:0;z-index:1}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative;text-align:center}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-radius:0;border-top:1px solid #aeaeae;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-radius:0 0 .3rem .3rem;border-top:1px solid #aeaeae}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__year-dropdown-container--select{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__month-year-select,.react-datepicker__year-select{background-color:initial;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__month-year-select:focus-visible,.react-datepicker__year-select:focus-visible{outline:1px auto}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#000;font-size:.944rem;font-weight:700;margin-top:0}h2.react-datepicker__current-month{margin:0;padding:0}.react-datepicker-time__header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__navigation{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;overflow:hidden;padding:0;position:absolute;text-align:center;text-indent:-999em;top:2px;width:32px;z-index:1}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{display:block;margin-left:auto;margin-right:auto;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{font-size:20px;position:relative;top:-1px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;margin:2px;width:5em}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;margin:2px;width:5em}.react-datepicker__input-time-container{clear:both;float:left;margin:5px 0 10px 15px;text-align:left;width:100%}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{display:inline-block;margin-left:5px}.react-datepicker__time-container{border-left:1px solid #aeaeae;float:right;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.375em;display:inline;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.375em;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{border-bottom-right-radius:.375em;margin:0 auto;overflow-x:hidden;text-align:center;width:85px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:initial;height:calc(195px + 1.0625em);list-style:none;margin:0;overflow-y:scroll;padding-left:0;padding-right:0;width:100%}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background-color:#f0f0f0;cursor:pointer}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{background-color:initial;cursor:default}.react-datepicker__week-number{color:#ccc;display:inline-block;line-height:2.125em;margin:.208em;text-align:center;width:2.125em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__week-number--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{margin-bottom:-8px;text-align:center;white-space:nowrap}.react-datepicker__week{white-space:nowrap}.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__time-name{color:#000;display:inline-block;line-height:2.125em;margin:.208em;text-align:center;width:2.125em}.react-datepicker__day--disabled,.react-datepicker__day-name--disabled,.react-datepicker__time-name--disabled{color:#ccc;cursor:default}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{background-color:#3dcc4a;border-radius:.3rem;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{background-color:#ff6803;border-radius:.3rem;color:#fff;position:relative}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{background-color:#333;border-radius:4px;bottom:100%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{opacity:1;visibility:visible}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__month-text--in-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--selected,.react-datepicker__quarter-text--in-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--selected,.react-datepicker__year-text--in-range,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{background-color:#bad9f1;border-radius:.3rem;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{color:#ccc;cursor:default}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{background-color:#333;border-radius:4px;bottom:70%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__input-container{display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{box-sizing:initial;padding:.625em;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__month-read-view,.react-datepicker__month-year-read-view,.react-datepicker__year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover,.react-datepicker__year-read-view:hover{cursor:pointer}.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{right:-16px;top:0;transform:rotate(135deg)}.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown,.react-datepicker__year-dropdown{background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;left:25%;position:absolute;text-align:center;top:30px;width:50%;z-index:1}.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover,.react-datepicker__year-dropdown:hover{cursor:pointer}.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable,.react-datepicker__year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__month-option,.react-datepicker__month-year-option,.react-datepicker__year-option{display:block;line-height:20px;margin-left:auto;margin-right:auto;width:100%}.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type,.react-datepicker__year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type,.react-datepicker__year-option:last-of-type{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem;-webkit-user-select:none;user-select:none}.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover,.react-datepicker__year-option:hover{background-color:#ccc}.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected,.react-datepicker__year-option--selected{left:15px;position:absolute}.react-datepicker__close-icon{background-color:initial;border:0;cursor:pointer;display:table-cell;height:100%;outline:0;padding:0 6px 0 0;position:absolute;right:0;top:0;vertical-align:middle}.react-datepicker__close-icon:after{background-color:#216ba5;border-radius:50%;color:#fff;content:"×";cursor:pointer;display:table-cell;font-size:12px;height:16px;line-height:1;padding:2px;text-align:center;vertical-align:middle;width:16px}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{background-color:#ccc;cursor:default}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;clear:left;cursor:pointer;font-weight:700;padding:5px 0;text-align:center}.react-datepicker__portal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2147483647}.react-datepicker__children-container{height:auto;margin:.5em;padding-left:.25em;padding-right:.25em;width:17.25em}.react-datepicker__aria-live{border:0;-webkit-clip-path:circle(0);clip-path:circle(0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker__calendar-icon{height:1em;vertical-align:-.125em;width:1em}.react-datepicker-popper-offset{margin-top:-.7em}.profile-questionnaire{background:linear-gradient(135deg,#0d0d0d,#1a1a1a 50%,#0d0d0d);min-height:100vh;padding:2rem 1rem;position:relative}.profile-questionnaire:before{background:radial-gradient(circle at 30% 30%,#ffd70014 0,#0000 50%),radial-gradient(circle at 70% 70%,#fdb8130f 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.questionnaire-container{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 60px #0000004d;margin:0 auto;max-width:700px;overflow:visible;padding:2rem;position:relative;z-index:1}.questionnaire-container .progress-bar{background:#0000;height:auto;margin-bottom:2rem;overflow:visible}.questionnaire-container .progress-fill{display:none}.questionnaire-container .progress-steps{display:flex;gap:1rem;justify-content:space-between}.questionnaire-container .progress-step{align-items:center;display:flex;flex:1 1;flex-direction:column}.questionnaire-container .step-number{align-items:center;background:var(--bg-card);border:2px solid var(--border);border-radius:50%;color:var(--text-light);display:flex;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;margin-bottom:.5rem;transition:all .2s;width:40px}.questionnaire-container .progress-step.active .step-number{background:var(--primary);border-color:var(--primary);color:#0d0d0d}.questionnaire-container .progress-step.current .step-number{box-shadow:0 0 0 4px #ffd7004d}.questionnaire-container .step-label{color:var(--text-light);font-size:.75rem;font-weight:600;text-align:center}.questionnaire-container .progress-step.active .step-label{color:var(--text)}.step-container{display:flex;flex-direction:column;min-height:400px}.step-content{flex:1 1}.step-content h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .5rem}.step-description{color:var(--text-light);font-size:1.1rem;margin-bottom:2rem}.form-group,.form-row{margin-bottom:1.5rem}.form-row{grid-gap:1.5rem;gap:1.5rem}.form-group label{color:var(--text-light);font-size:1rem}.form-group input,.form-group select{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;box-sizing:border-box;color:var(--text);font-family:inherit;font-size:1rem;padding:.875rem;transition:all .2s;width:100%}.form-group input::placeholder{color:var(--text-light)}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.form-group select option{background:var(--bg-surface)}.form-group small{color:var(--text-light);display:block;font-size:.875rem;margin-top:.5rem}.checkbox-label{align-items:center;border-radius:8px;cursor:pointer;display:flex;padding:.75rem;transition:background .2s}.checkbox-label:hover{background:var(--bg-surface)}.checkbox-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer;height:20px;margin-right:.75rem;width:20px}.checkbox-label span{color:var(--text);font-weight:500}.radio-group{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.radio-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;padding:1rem;transition:all .2s}.radio-option:hover{background:var(--bg-card-hover);border-color:var(--text-light)}.radio-option input[type=radio]{accent-color:var(--primary);cursor:pointer;height:20px;margin-right:.75rem;width:20px}.radio-option input[type=radio]:checked+span{color:var(--primary);font-weight:600}.radio-option:has(input:checked){background:#ffd7001a;border-color:var(--primary)}.unit-toggle{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;display:flex;margin-top:.5rem;overflow:hidden}.unit-toggle-btn{flex:1 1;font-size:1rem;padding:.75rem 1.5rem}.radio-group-inline{display:flex;gap:1rem;margin-top:.5rem}.radio-option-inline{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;flex:1 1;padding:.75rem 1rem;transition:all .2s}.radio-option-inline:hover{background:var(--bg-card-hover);border-color:var(--text-light)}.radio-option-inline input[type=radio]{accent-color:var(--primary);cursor:pointer;height:18px;margin-right:.5rem;width:18px}.radio-option-inline span{color:var(--text);font-size:.9375rem;font-weight:500}.radio-option-inline.selected{background:#ffd7001a;border-color:var(--primary)}.radio-option-inline.selected span{color:var(--primary);font-weight:600}.form-group input[type=date]{color-scheme:dark}.form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1)}.datepicker-input{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s;width:100%}.datepicker-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.react-datepicker-wrapper{width:100%}.react-datepicker__input-container{align-items:center;display:flex;position:relative}.react-datepicker__calendar-icon{fill:var(--text-light);height:20px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px}.react-datepicker__input-container .datepicker-input{padding-right:40px}.react-datepicker{background:#1a1a2e;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 40px #0006;font-family:inherit}.react-datepicker__header{background:#1a1a2e;border-bottom:1px solid var(--border);border-radius:12px 12px 0 0;padding:1rem}.react-datepicker__current-month{display:none}.react-datepicker-time__header,.react-datepicker__day-name{color:var(--text)}.react-datepicker__month-dropdown-container,.react-datepicker__year-dropdown-container{margin:0 .5rem}.react-datepicker__month-dropdown-container select,.react-datepicker__month-select,.react-datepicker__year-dropdown-container select,.react-datepicker__year-select{-webkit-appearance:auto;appearance:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.875rem;padding:.375rem .75rem}.react-datepicker__month-dropdown-container select:focus,.react-datepicker__month-select:focus,.react-datepicker__year-dropdown-container select:focus,.react-datepicker__year-select:focus{border-color:var(--primary);outline:none}.react-datepicker__month-select option,.react-datepicker__year-select option{background:var(--bg-card);color:var(--text)}.react-datepicker__day-name{color:#a0a0a0;font-weight:600;line-height:2.5rem;width:2.5rem}.react-datepicker__month{background:#1a1a2e;margin:0;padding:.5rem}.react-datepicker__day{border-radius:8px;color:#fff;line-height:2.5rem;transition:all .15s;width:2.5rem}.react-datepicker__day:hover{background:#ffffff1a;border-radius:8px}.react-datepicker__day--keyboard-selected,.react-datepicker__day--selected{background:var(--primary)!important;color:#0d0d0d!important;font-weight:600}.react-datepicker__day--today{color:var(--primary);font-weight:700}.react-datepicker__day--outside-month{color:#666;opacity:1}.react-datepicker__day--disabled{color:var(--text-light);cursor:not-allowed;opacity:.3}.react-datepicker__navigation{top:.75rem}.react-datepicker__navigation-icon:before{border-color:var(--text-light);border-width:2px 2px 0 0}.react-datepicker__navigation:hover :before{border-color:var(--primary)}.react-datepicker__header--has-time-select{padding:.75rem}.react-datepicker__month-dropdown,.react-datepicker__year-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.react-datepicker__month-option,.react-datepicker__year-option{color:var(--text);padding:.5rem}.react-datepicker__month-option:hover,.react-datepicker__year-option:hover{background:var(--bg-card-hover)}.react-datepicker__month-option--selected_month,.react-datepicker__year-option--selected_year{background:var(--primary);color:#0d0d0d}.react-datepicker__month-read-view,.react-datepicker__year-read-view{color:var(--text)}.react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{border-color:var(--text-light)}.react-datepicker__triangle{display:none}.react-datepicker-popper{z-index:100}.react-datepicker-popper[data-placement^=bottom]{padding-top:0}.react-datepicker-popper[data-placement^=top]{padding-bottom:0}.file-input{background:var(--bg-surface);border:2px dashed var(--border);border-radius:10px;color:var(--text);cursor:pointer;padding:.75rem;width:100%}.file-input:hover{background:var(--bg-card-hover);border-color:var(--primary)}.mileage-options{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.mileage-option{align-items:flex-start;background:var(--bg-surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;padding:1.25rem;transition:all .2s}.mileage-option:hover{background:var(--bg-card-hover);border-color:var(--text-light);box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.mileage-option input[type=radio]{accent-color:var(--primary);cursor:pointer;flex-shrink:0;height:20px;margin-right:1rem;margin-top:.25rem;width:20px}.mileage-option.selected{background:#ffd7001a;border-color:var(--primary);box-shadow:0 4px 12px #ffd70033}.mileage-option-content{flex:1 1}.mileage-option-content strong{color:var(--text);display:block;font-size:1.1rem;margin-bottom:.25rem}.mileage-option-content p{color:var(--text-light);font-size:.95rem;margin:0}.mileage-option-content .days-per-week{color:var(--primary);font-weight:600;margin-top:.25rem}.mileage-option.selected .mileage-option-content strong{color:var(--primary)}.info-box{margin-bottom:1.5rem}.info-box strong{color:var(--primary);margin-bottom:.25rem}.info-box p{margin:.5rem 0 0}.success-box{background:#48bb781a;border-left:4px solid #48bb78;border-radius:8px;color:#68d391;font-weight:600;margin-top:1.5rem;padding:1rem 1.25rem}.pb-section{border-top:2px solid var(--border);margin-top:2rem;padding-top:1.5rem}.pb-section h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .5rem}.pb-description{color:var(--text-light);font-size:.9375rem;margin-bottom:1rem}.pb-grid{grid-gap:1rem;gap:1rem}.pb-input-group{gap:.375rem}.pb-input-group label{font-size:.8125rem}.pb-input-group input{background:var(--bg-surface);border:2px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;transition:all .2s}.pb-input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.pb-input-group input::placeholder{color:var(--text-light);opacity:.6}.pb-input-group input.valid{border-color:#48bb78}.pb-input-group input.invalid{border-color:#fc8181}.pb-error{color:#fc8181;font-size:.6875rem;margin-top:.125rem}.pb-hint{color:var(--text-light);display:block;font-size:.8125rem;margin-top:.75rem}.review-pbs{grid-gap:.25rem 1rem;display:grid;gap:.25rem 1rem;grid-template-columns:repeat(2,1fr)}.review-pbs p{font-size:.9375rem;margin:0}.review-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.review-item{background:var(--bg-surface);border-left:4px solid var(--primary);border-radius:10px;padding:1.25rem}.review-item strong{color:var(--text);display:block;font-size:1.1rem;margin-bottom:.5rem}.review-item p{color:var(--text-light);line-height:1.6;margin:.25rem 0}.vdot-display{color:var(--primary)!important;font-weight:600;margin-top:.5rem!important}.error-message{background:#ef44441a;border-left:4px solid #ef4444;color:#f87171;font-size:.95rem}.button-group{border-top:2px solid var(--border);display:flex;gap:1rem;margin-top:2rem;padding-top:2rem}.profile-questionnaire .btn-primary,.profile-questionnaire .btn-secondary{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-family:inherit;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .2s}.profile-questionnaire .btn-primary{background:var(--primary);color:#0d0d0d}.profile-questionnaire .btn-primary:hover:not(:disabled){box-shadow:0 10px 25px #ffd70066;transform:translateY(-2px)}.profile-questionnaire .btn-primary:disabled{cursor:not-allowed;opacity:.6}.profile-questionnaire .btn-secondary{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-light)}.profile-questionnaire .btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text);transform:translateY(-2px)}.profile-questionnaire .btn-submit{font-size:1.2rem;padding:1.25rem 2rem}@media (max-width:768px){.profile-questionnaire{padding:1rem .5rem}.questionnaire-container{border-radius:16px;padding:1.5rem}.questionnaire-container .progress-bar{margin-bottom:1.5rem}.questionnaire-container .progress-steps{gap:.5rem}.questionnaire-container .step-label{font-size:.65rem}.questionnaire-container .step-number{font-size:.9rem;height:32px;width:32px}.step-container{min-height:auto}.step-content h2{font-size:1.5rem}.step-description{font-size:1rem}.form-row{grid-template-columns:1fr}.radio-group-inline{flex-direction:column}.unit-toggle-btn{font-size:.9375rem;padding:.625rem 1rem}.height-imperial{flex-wrap:wrap}.height-imperial input{width:60px}.pb-grid,.review-pbs{grid-template-columns:1fr}.button-group{flex-direction:column-reverse}.profile-questionnaire .btn-primary,.profile-questionnaire .btn-secondary{width:100%}}.step-content{animation:fadeIn .3s ease-out}.form-group input:invalid:not(:placeholder-shown){border-color:#fc8181}.form-group input:valid:not(:placeholder-shown){border-color:#68d391}.profile-questionnaire .btn-primary:disabled:after{animation:ellipsis 1.5s infinite;content:"..."}@keyframes ellipsis{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}.profile-image-section{gap:.75rem;margin-bottom:1.5rem}.profile-image-preview:hover:not(.uploading){border-color:var(--primary);transform:scale(1.02)}.profile-image-placeholder{gap:.25rem;height:100%;width:100%}.change-photo-btn{border:2px solid var(--border);color:var(--text)}.change-photo-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.photo-hint{color:var(--text-light);font-size:.75rem}.home-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.home-container{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:1200px}.race-countdown{align-items:center;background:var(--bg-card);border-radius:16px;box-shadow:0 2px 12px #0003;display:flex;gap:1.25rem;padding:1rem 1.5rem}.countdown-circle{align-items:center;background:#ffd7000d;border:3px solid var(--primary);border-radius:50%;box-shadow:0 0 16px #ffd70026;display:flex;flex-direction:column;flex-shrink:0;height:88px;justify-content:center;width:88px}.countdown-days{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;line-height:1}.countdown-days-label{color:var(--text-light);font-size:.5625rem;letter-spacing:.12em;margin-top:2px;text-transform:uppercase}.countdown-right{display:flex;flex-direction:column;gap:.25rem}.countdown-hms{align-items:flex-start;display:flex;gap:0}.countdown-unit{align-items:center;display:flex;flex-direction:column}.countdown-value{font-size:1.375rem}.countdown-label{font-size:.5rem;letter-spacing:.1em;margin-top:2px}.countdown-colon{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.375rem;line-height:1;margin:0 3px;opacity:.6}.countdown-until{color:var(--text-light);font-size:.6875rem;letter-spacing:.1em;margin-top:4px;text-transform:uppercase}.next-workout-standalone{border-left:4px solid var(--primary)}.next-workout{background:var(--bg-card);border-left:6px solid var(--primary);border-radius:16px;box-shadow:0 4px 20px #0000004d;overflow:hidden;padding:2rem;position:relative}.next-workout--empty{border-left-color:#a0aec0;padding:3rem 2rem;text-align:center}.next-workout--empty h2{color:var(--text-light);margin-bottom:.5rem}.next-workout--empty p{color:var(--text-light)}.next-workout__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.next-workout__date-info{display:flex;flex-direction:column;gap:.25rem}.next-workout__label{color:var(--primary);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.next-workout__date{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.next-workout__header-right{align-items:center;display:flex;gap:.75rem}.unit-toggle-btn{font-size:.875rem;padding:.375rem .75rem}.next-workout__badge{border-radius:20px;color:#fff;font-size:.875rem;font-weight:600;padding:.5rem 1rem}.next-workout__body{display:flex;flex-direction:column;gap:1.25rem}.next-workout__main{align-items:flex-start;display:flex;gap:2rem}.next-workout__distance{align-items:baseline;display:flex;flex-shrink:0;gap:.25rem}.distance-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:3rem;line-height:1}.distance-unit{color:var(--text-light);font-size:1.25rem;font-weight:500}.next-workout__description{flex:1 1}.next-workout__description p{color:var(--text);font-size:1.125rem;line-height:1.6;margin:0}.next-workout__targets{background:var(--bg-surface);border-radius:12px;display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem 1.5rem}.target-item{display:flex;flex-direction:column;gap:.25rem}.target-label{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.target-value{color:var(--primary);font-size:1.125rem;font-weight:600}.target-value--secondary{color:var(--text-light);font-weight:500}.next-workout__notes{background:#ffd7001a;border-left:3px solid var(--primary);border-radius:8px;padding:1rem}.next-workout__notes p{color:var(--text);font-size:.9375rem;font-style:italic;margin:0}.next-workout__actions{border-top:1px solid var(--border);display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.next-workout__actions .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.next-workout__actions .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.next-workout__actions .btn-secondary{background:var(--bg-surface);border:none;border-radius:10px;color:var(--text);cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;padding:.875rem 1.5rem;transition:all .2s}.next-workout__actions .btn-secondary:hover{background:var(--bg-card-hover)}.next-workout__note{background:#ffd70026;border-radius:8px;color:var(--primary);font-size:.875rem;font-weight:500;margin-top:1rem;padding:.75rem 1rem}.home-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.training-summary-card{align-items:stretch;display:flex;gap:0}.summary-section{flex:1 1;padding:0 1.5rem}.summary-section:first-child{padding-left:0}.summary-section:last-child{padding-right:0}.summary-divider{align-self:stretch;background:var(--border);flex-shrink:0;width:1px}@media (max-width:768px){.training-summary-card{flex-direction:column}.summary-divider{height:1px;margin:.75rem 0;width:auto}.summary-section{padding:0}}.home-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem}.card-title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:.875rem;letter-spacing:.05em;margin:0 0 1.25rem;text-transform:uppercase}.card-empty{color:var(--text-light);font-size:.9375rem;margin:0}.race-countdown__race{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.25rem}.race-name{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem}.race-date{color:var(--text-light);font-size:.875rem}.race-countdown__timer{align-items:center;display:flex;gap:.75rem;margin-bottom:1.25rem}.countdown-item{align-items:center;display:flex;flex-direction:column}.countdown-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2.5rem;line-height:1}.countdown-label{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.countdown-divider{color:var(--text-light);font-size:1.5rem;font-weight:300}.race-countdown__phase{margin-bottom:1rem}.phase-badge{background:var(--primary)!important;border-radius:20px;color:#0d0d0d;display:inline-block;font-size:.75rem;font-weight:600;padding:.375rem .75rem}.race-countdown__progress{display:flex;flex-direction:column;gap:.5rem}.progress-bar{background:var(--bg-surface);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:var(--text-light);font-size:.75rem}.recent-sessions__list{display:flex;flex-direction:column;gap:.75rem}.recent-sessions__item{align-items:center;background:var(--bg-surface);border-radius:10px;display:flex;gap:.75rem;padding:.75rem}.session-badge{align-items:center;border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:32px;justify-content:center;width:32px}.session-info{display:flex;flex-direction:column;gap:.125rem}.session-date{color:var(--text);font-size:.875rem;font-weight:500}.session-distance{color:var(--text-light);font-size:.75rem}.training-health__stat{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:.75rem 0}.training-health__stat:last-of-type{border-bottom:none}.training-health__stat .stat-label{color:var(--text-light);font-size:.875rem}.training-health__stat .stat-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem}.training-health__focus{background:var(--bg-surface);border-radius:8px;margin-top:1rem;padding:.75rem}.focus-label{color:var(--text-light);display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.focus-value{color:var(--text);font-size:.9375rem}.feature-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-top:1.5rem}.feature-card{background:var(--bg-card);border-left:6px solid var(--primary);border-radius:16px;box-shadow:0 4px 20px #0000004d;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.feature-card:hover{box-shadow:0 8px 30px #0006;transform:translateY(-4px)}.feature-card__header{align-items:center;display:flex;justify-content:space-between}.feature-card__icon{align-items:center;display:flex;font-size:2rem;line-height:1}.feature-card__title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.feature-card__stat{color:var(--text-light);font-size:.875rem;margin:0}.feature-card__cta{color:var(--primary);font-size:.875rem;font-weight:600;margin-top:auto}.latest-run{background:var(--bg-card);border-left:6px solid #22c55e;border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem 2rem}.latest-run__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.25rem}.latest-run__title-area{display:flex;flex-direction:column;gap:.25rem}.latest-run__label{color:#22c55e;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.latest-run__title{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.latest-run__icon{align-items:center;background:#22c55e26;border-radius:10px;display:flex;height:40px;justify-content:center;width:40px}.latest-run__icon svg{color:#22c55e;height:20px;width:20px}.latest-run__stats{display:flex;flex-wrap:wrap;gap:2rem}.latest-run__stat{align-items:baseline;display:flex;gap:.25rem}.latest-run__stat-value{color:#22c55e;font-family:Archivo Black,sans-serif;font-size:1.75rem;line-height:1}.latest-run__stat-label{color:var(--text-light);font-size:.875rem;font-weight:500}@media (max-width:1024px){.home-grid{grid-template-columns:repeat(2,1fr)}.home-grid .training-health{grid-column:1/-1}.feature-cards-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.home-page{padding:1rem}.home-container{gap:1rem}.next-workout{padding:1.5rem}.next-workout__main{flex-direction:column;gap:1rem}.distance-value{font-size:2.5rem}.feature-cards-grid,.home-grid{grid-template-columns:1fr}.countdown-value{font-size:2rem}.latest-run{padding:1.25rem 1.5rem}.latest-run__stats{gap:1.5rem}.latest-run__stat-value{font-size:1.5rem}}@media (max-width:480px){.next-workout__header{flex-direction:column;gap:1rem}.next-workout__header-right{align-self:flex-start}.next-workout__targets{gap:1rem}.target-item{min-width:calc(50% - .5rem)}.next-workout__actions{flex-direction:column}.next-workout__actions .btn-primary,.next-workout__actions .btn-secondary{text-align:center;width:100%}.race-countdown__timer{justify-content:center}.latest-run__stats{gap:1rem}.latest-run__stat-value{font-size:1.25rem}}.activity-feed-section{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;overflow:hidden}.activity-feed-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem 2rem}.activity-feed-title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.activity-feed-toggle{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;display:flex;overflow:hidden}.activity-feed-toggle .toggle-btn{background:#0000;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.activity-feed-toggle .toggle-btn:first-child{border-right:1px solid var(--border)}.activity-feed-toggle .toggle-btn:hover:not(.active){background:var(--bg-card-hover);color:var(--text)}.activity-feed-toggle .toggle-btn.active{background:var(--primary);color:#0d0d0d}.activity-feed-content{max-height:650px;min-height:550px;overflow-y:auto}.activity-feed-loading{color:var(--text-light);padding:2rem;text-align:center}.activity-feed-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:500px;padding:5rem 2rem;text-align:center}.activity-feed-empty-icon{font-size:5rem;margin-bottom:2rem;opacity:.6}.activity-feed-empty h4{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 1rem}.activity-feed-empty p{color:var(--text-light);font-size:1.125rem;margin:0 0 2rem}.activity-feed-empty .btn-primary{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.activity-feed-empty .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.activity-feed-list{padding:.5rem 0}.activity-item{padding:1rem 2rem;transition:background .2s}.activity-item:hover{background:var(--bg-surface)}.activity-item+.activity-item{border-top:1px solid var(--border)}.activity-item-content{min-width:0}.activity-item-header{margin-bottom:.25rem}.activity-item-title{color:var(--text);font-size:.9375rem;font-weight:600}.activity-item-time{color:var(--text-light);font-size:.75rem}.activity-item-description{color:var(--text-light);font-size:.8125rem;line-height:1.4;margin:.5rem 0 0}.activity-item-map{border-radius:10px;height:200px;margin-top:.75rem;overflow:hidden}.activity-item-map .leaflet-container{background:var(--bg-surface)}.next-workout-card{border-left:4px solid var(--primary)}.next-workout-card__date{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1rem;margin-bottom:.75rem}.next-workout-card__type{margin-bottom:.75rem}.workout-type-badge{background:var(--primary)!important;border-radius:16px;color:#0d0d0d!important;display:inline-block;font-size:.75rem;font-weight:600;padding:.375rem .75rem}.next-workout-card__distance{align-items:baseline;display:flex;gap:.25rem;margin-bottom:.75rem}.next-workout-card__distance .distance-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;line-height:1}.next-workout-card__distance .distance-unit{color:var(--text-light);font-size:1rem}.next-workout-card__description{color:var(--text);font-size:.875rem;line-height:1.5;margin:0}.retest-note{background:#ffd70026;border-radius:6px;color:var(--primary);font-size:.75rem;font-weight:500;margin-top:.75rem;padding:.5rem .75rem}@media (max-width:768px){.activity-feed-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.25rem 1.5rem}.activity-feed-toggle{width:100%}.activity-feed-toggle .toggle-btn{flex:1 1;text-align:center}.activity-item{padding:1rem 1.5rem}.activity-feed-content{max-height:500px;min-height:400px}.activity-feed-empty{min-height:350px;padding:3rem 1.5rem}}@media (max-width:480px){.next-workout-card__distance .distance-value{font-size:1.75rem}}.whoop-recovery-card{border-left:6px solid var(--primary)}.whoop-recovery-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.whoop-recovery-card__header .card-title{margin:0}.whoop-recovery-card__date{color:var(--text-light);font-size:.875rem}.whoop-recovery-card__loading{color:var(--text-light);padding:2rem;text-align:center}.whoop-recovery-card__body{align-items:center;display:flex;gap:2rem}.whoop-recovery-card__score{align-items:center;display:flex;flex-direction:column;flex-shrink:0;min-width:100px}.whoop-recovery-card__score .score-value{font-family:Archivo Black,sans-serif;font-size:2.5rem;line-height:1}.whoop-recovery-card__score .score-label{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}.whoop-recovery-card__metrics{grid-gap:1rem;display:grid;flex:1 1;gap:1rem;grid-template-columns:1fr 1fr}.whoop-metric{background:var(--bg-surface);border-radius:10px;display:flex;flex-direction:column;padding:.75rem}.whoop-metric__value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;line-height:1}.whoop-metric__label{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}.whoop-recovery-card__trend{align-items:center;border-top:1px solid var(--border);display:flex;gap:1rem;margin-top:1.25rem;padding-top:1rem}.whoop-recovery-card__trend .trend-label{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.whoop-sparkline{flex:1 1;height:40px}@media (max-width:768px){.whoop-recovery-card__body{align-items:stretch;flex-direction:column;gap:1rem}.whoop-recovery-card__score{flex-direction:row;gap:.75rem;min-width:0;min-width:auto}.whoop-recovery-card__score .score-value{font-size:2rem}}@media (max-width:480px){.whoop-recovery-card__metrics{gap:.75rem}.whoop-metric{padding:.5rem}.whoop-metric__value{font-size:1rem}}.oura-readiness-card{border-left:6px solid var(--primary)}.oura-readiness-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.oura-readiness-card__header .card-title{margin:0}.oura-readiness-card__date{color:var(--text-light);font-size:.875rem}.oura-readiness-card__loading{color:var(--text-light);padding:2rem;text-align:center}.oura-readiness-card__body{align-items:center;display:flex;gap:2rem}.oura-readiness-card__score{align-items:center;display:flex;flex-direction:column;flex-shrink:0;min-width:100px}.oura-readiness-card__score .score-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2.5rem;line-height:1}.oura-readiness-card__score .score-label{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}.oura-readiness-card__metrics{grid-gap:1rem;display:grid;flex:1 1;gap:1rem;grid-template-columns:1fr 1fr}.oura-metric{background:var(--bg-surface);border-radius:10px;display:flex;flex-direction:column;padding:.75rem}.oura-metric__value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;line-height:1}.oura-metric__label{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}@media (max-width:768px){.oura-readiness-card__body{align-items:stretch;flex-direction:column;gap:1rem}.oura-readiness-card__score{flex-direction:row;gap:.75rem;min-width:0;min-width:auto}.oura-readiness-card__score .score-value{font-size:2rem}}@media (max-width:480px){.oura-readiness-card__metrics{gap:.75rem}.oura-metric{padding:.5rem}.oura-metric__value{font-size:1rem}}.retest-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.retest-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{border-bottom:2px solid #e2e8f0;padding:2rem}.modal-header h2{font-size:1.75rem}.close-btn{align-items:center;background:none;border-radius:50%;color:#a0aec0;display:flex;font-size:2rem;height:40px;justify-content:center;padding:0;transition:all .2s;width:40px}.close-btn:hover{background:#edf2f7;color:var(--secondary)}.modal-body{padding:2rem}.modal-description{color:var(--text-light);font-size:1.1rem;margin-bottom:2rem}.workout-choice{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.choice-btn{align-items:center;background:#f7fafc;border:3px solid #e2e8f0;border-radius:15px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;padding:1.5rem;text-align:center;transition:all .2s}.choice-btn:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.choice-btn.selected{background:#ffd7001a;border-color:var(--primary);box-shadow:0 4px 12px #ffd70033}.choice-icon{font-size:3rem;margin-bottom:.75rem}.choice-content strong{color:var(--secondary);display:block;font-size:1.1rem;margin-bottom:.25rem}.choice-content p{color:var(--text-light);font-size:.9rem;margin:0}.retest-form{animation:slideDown .3s ease-out;background:#f7fafc;border-radius:12px;margin-top:1.5rem;padding:1.5rem}.retest-form h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.2rem;margin:0 0 1.5rem}.retest-form .form-group{margin-bottom:1.25rem}.retest-form label{color:var(--text);display:block;font-weight:600;margin-bottom:.5rem}.retest-form input,.retest-form select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.875rem;transition:all .2s;width:100%}.retest-form input:focus,.retest-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.retest-form small{color:var(--text-light);display:block;font-size:.875rem;margin-top:.5rem}.comparison-section{margin-bottom:2rem}.comparison-section h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.3rem;margin:0 0 1rem}.vdot-comparison{align-items:center;background:#ffd7001a;border-radius:12px;display:flex;gap:1.5rem;justify-content:center;margin-bottom:1rem;padding:1.5rem}.vdot-new,.vdot-old{align-items:center;background:#fff;border-radius:10px;display:flex;flex-direction:column;min-width:100px;padding:1rem}.vdot-new .label,.vdot-old .label{color:var(--text-light);font-size:.875rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.vdot-old .value{color:#a0aec0;font-size:2rem;font-weight:700}.vdot-new .value{color:var(--secondary);font-size:2rem;font-weight:700}.vdot-arrow{color:var(--primary);font-size:2rem}.vdot-improvement{text-align:center}.improvement-value{background:#c6f6d5;border-radius:8px;color:#48bb78;display:block;font-size:1.1rem;font-weight:700;padding:.5rem 1rem}.pace-comparison-table{overflow-x:auto}.pace-comparison-table table{background:#fff;border-collapse:collapse;border-radius:10px;overflow:hidden;width:100%}.pace-comparison-table td,.pace-comparison-table th{border-bottom:1px solid #e2e8f0;padding:1rem;text-align:left}.pace-comparison-table thead{background:#f7fafc}.pace-comparison-table th{color:var(--secondary);font-size:.875rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pace-comparison-table tbody tr:last-child td{border-bottom:none}.pace-comparison-table td{color:var(--text-light)}.new-pace{color:var(--secondary)!important;font-weight:700}.info-box{background:#ffd7001a;border-left:4px solid var(--primary);border-radius:8px;margin-top:1.5rem;padding:1rem 1.25rem}.info-box strong{color:var(--secondary);display:block;margin-bottom:.5rem}.info-box p{color:var(--text);margin:.25rem 0}.error-message{background:#fed7d7;border-left:4px solid #c53030;border-radius:10px;color:#c53030;margin-top:1.5rem;padding:1rem}.modal-footer{border-top:2px solid #e2e8f0;gap:1rem;padding:2rem}.btn-primary,.btn-secondary{border:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .2s}.btn-primary{color:var(--secondary)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #ffd70066}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#e2e8f0;color:var(--text-light)}.btn-secondary:hover:not(:disabled){background:#cbd5e0}.btn-large{font-size:1.1rem;padding:1.25rem 2rem;width:100%}@media (max-width:768px){.retest-modal{max-height:95vh}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.5rem}.modal-body{padding:1.5rem}.workout-choice{grid-template-columns:1fr}.vdot-comparison{flex-direction:column;gap:1rem}.vdot-arrow{transform:rotate(90deg)}.modal-footer{flex-direction:column-reverse;padding:1.5rem}.btn-primary,.btn-secondary{width:100%}}.garmin-connect{margin:1.5rem 0}.garmin-connect-section{text-align:center}.garmin-note{color:var(--text-light);font-size:.875rem;margin-top:.75rem}.garmin-connect-btn{align-items:center;background:linear-gradient(135deg,#007cc3,#005a8f);border:none;border-radius:10px;box-shadow:0 4px 12px #007cc34d;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:1rem;font-weight:600;gap:.75rem;margin:0 auto;padding:.875rem 1.5rem;transition:all .2s}.garmin-connect-btn:hover:not(:disabled){box-shadow:0 6px 16px #007cc366;transform:translateY(-2px)}.garmin-connect-btn:disabled{cursor:not-allowed;opacity:.6}.garmin-icon{height:24px;width:24px}.garmin-connected{background:var(--bg-card);border-radius:12px;box-shadow:0 2px 8px #0000004d;padding:1rem 1.25rem}.garmin-status-row{align-items:center;display:flex;gap:1rem;justify-content:space-between}.garmin-status{align-items:center;display:flex;gap:.625rem}.garmin-icon.connected{color:#10b981;height:28px;width:28px}.connected-text{color:#10b981;font-size:1rem;font-weight:600}.garmin-disconnect-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.garmin-disconnect-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-light);color:var(--text)}.garmin-disconnect-btn:disabled{cursor:not-allowed;opacity:.5}.garmin-sync-message{align-items:center;border-top:1px solid var(--border);display:flex;font-size:.875rem;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.garmin-sync-message svg{flex-shrink:0;height:16px;width:16px}.garmin-sync-message.success{color:#10b981}.garmin-sync-message.success svg{animation:checkPop .3s ease-out}@keyframes checkPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.garmin-sync-message.info{color:var(--text-light)}.garmin-sync-message.info svg{animation:spin 1s linear infinite}.garmin-sync-message.error{color:#f87171}.garmin-sync-note{border-top:1px solid var(--border);color:var(--text-light);font-size:.875rem;margin:.75rem 0 0;padding-top:.75rem}.garmin-error{align-items:center;background:#dc262626;border:1px solid #dc26264d;border-radius:8px;color:#f87171;display:flex;font-size:.875rem;gap:.75rem;margin-top:1rem;padding:.75rem 1rem}.garmin-error svg{flex-shrink:0;height:20px;width:20px}@media (max-width:480px){.garmin-status-row{align-items:flex-start;flex-direction:column;gap:.75rem}.garmin-disconnect-btn{text-align:center;width:100%}}.whoop-connect{margin:1.5rem 0}.whoop-connect-section{text-align:center}.whoop-note{color:var(--text-light);font-size:.875rem;margin-top:.75rem}.whoop-connect-btn{align-items:center;background:linear-gradient(135deg,#f36,#c04);border:none;border-radius:10px;box-shadow:0 4px 12px #ff33664d;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:1rem;font-weight:600;gap:.75rem;margin:0 auto;padding:.875rem 1.5rem;transition:all .2s}.whoop-connect-btn:hover:not(:disabled){box-shadow:0 6px 16px #f366;transform:translateY(-2px)}.whoop-connect-btn:disabled{cursor:not-allowed;opacity:.6}.whoop-icon{height:24px;width:24px}.whoop-connected{background:var(--bg-card);border-radius:12px;box-shadow:0 2px 8px #0000004d;padding:1rem 1.25rem}.whoop-status-row{align-items:center;display:flex;gap:1rem;justify-content:space-between}.whoop-status{align-items:center;display:flex;gap:.625rem}.whoop-icon.connected{color:#10b981;height:28px;width:28px}.whoop-connected-text{color:#10b981;font-size:1rem;font-weight:600}.whoop-disconnect-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.whoop-disconnect-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-light);color:var(--text)}.whoop-disconnect-btn:disabled{cursor:not-allowed;opacity:.5}.whoop-sync-message{align-items:center;border-top:1px solid var(--border);display:flex;font-size:.875rem;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.whoop-sync-message svg{flex-shrink:0;height:16px;width:16px}.whoop-sync-message.success{color:#10b981}.whoop-sync-message.success svg{animation:whoopCheckPop .3s ease-out}@keyframes whoopCheckPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.whoop-sync-message.info{color:var(--text-light)}.whoop-sync-message.info svg{animation:whoopSpin 1s linear infinite}.whoop-sync-message.error{color:#f87171}.whoop-sync-note{border-top:1px solid var(--border);color:var(--text-light);font-size:.875rem;margin:.75rem 0 0;padding-top:.75rem}.whoop-error{align-items:center;background:#dc262626;border:1px solid #dc26264d;border-radius:8px;color:#f87171;display:flex;font-size:.875rem;gap:.75rem;margin-top:1rem;padding:.75rem 1rem}.whoop-error svg{flex-shrink:0;height:20px;width:20px}@keyframes whoopSpin{to{transform:rotate(1turn)}}@media (max-width:480px){.whoop-status-row{align-items:flex-start;flex-direction:column;gap:.75rem}.whoop-disconnect-btn{text-align:center;width:100%}}.oura-connect{margin:1.5rem 0}.oura-connect-section{text-align:center}.oura-note{color:var(--text-light);font-size:.875rem;margin-top:.75rem}.oura-connect-btn{align-items:center;background:linear-gradient(135deg,#6ca,#4da88a);border:none;border-radius:10px;box-shadow:0 4px 12px #66ccaa4d;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:1rem;font-weight:600;gap:.75rem;margin:0 auto;padding:.875rem 1.5rem;transition:all .2s}.oura-connect-btn:hover:not(:disabled){box-shadow:0 6px 16px #6ca6;transform:translateY(-2px)}.oura-connect-btn:disabled{cursor:not-allowed;opacity:.6}.oura-icon{height:24px;width:24px}.oura-connected{background:var(--bg-card);border-radius:12px;box-shadow:0 2px 8px #0000004d;padding:1rem 1.25rem}.oura-status-row{gap:1rem;justify-content:space-between}.oura-status,.oura-status-row{align-items:center;display:flex}.oura-status{gap:.625rem}.oura-icon.connected{color:#10b981;height:28px;width:28px}.oura-connected-text{color:#10b981;font-size:1rem;font-weight:600}.oura-actions{align-items:center;display:flex;gap:.5rem}.oura-sync-btn{background:var(--primary);border:none;border-radius:8px;color:var(--bg-card);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.oura-sync-btn:hover:not(:disabled){opacity:.85}.oura-sync-btn:disabled{cursor:not-allowed;opacity:.5}.oura-disconnect-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.oura-disconnect-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-light);color:var(--text)}.oura-disconnect-btn:disabled{cursor:not-allowed;opacity:.5}.oura-sync-message{align-items:center;border-top:1px solid var(--border);display:flex;font-size:.875rem;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.oura-sync-message svg{flex-shrink:0;height:16px;width:16px}.oura-sync-message.success{color:#10b981}.oura-sync-message.success svg{animation:ouraCheckPop .3s ease-out}@keyframes ouraCheckPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.oura-sync-message.info{color:var(--text-light)}.oura-sync-message.info svg{animation:ouraSpin 1s linear infinite}.oura-sync-message.error{color:#f87171}.oura-sync-note{border-top:1px solid var(--border);color:var(--text-light);font-size:.875rem;margin:.75rem 0 0;padding-top:.75rem}.oura-error{align-items:center;background:#dc262626;border:1px solid #dc26264d;border-radius:8px;color:#f87171;display:flex;font-size:.875rem;gap:.75rem;margin-top:1rem;padding:.75rem 1rem}.oura-error svg{flex-shrink:0;height:20px;width:20px}@keyframes ouraSpin{to{transform:rotate(1turn)}}@media (max-width:480px){.oura-status-row{align-items:flex-start;flex-direction:column;gap:.75rem}.oura-disconnect-btn{text-align:center;width:100%}}.workout-step-editor-v2{display:flex;flex-direction:column;gap:1rem}.steps-toolbar{display:flex;gap:.75rem;justify-content:flex-end}.btn-add-repeat,.btn-add-step{align-items:center;border-radius:6px;cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.375rem;padding:.625rem 1rem;transition:all .2s}.btn-add-step{background:var(--primary);border:none;color:#0d0d0d}.btn-add-step:hover{box-shadow:0 4px 12px #ffd7004d;transform:translateY(-1px)}.btn-add-repeat{background:#0000;border:1px solid var(--border);color:var(--text)}.btn-add-repeat:hover{border-color:var(--primary);color:var(--primary)}.steps-list-v2{display:flex;flex-direction:column;gap:.5rem}.no-steps-hint{color:var(--text-light);font-size:.875rem;margin:0;padding:2rem 1rem;text-align:center}.step-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.step-card.editing{border-color:#3182ce;border-width:2px}.step-card-header{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:.75rem;padding:.75rem 1rem}.step-card.editing .step-card-header{border-bottom:none;padding-bottom:.5rem}.drag-handle{grid-gap:3px;cursor:grab;display:grid;gap:3px;grid-template-columns:repeat(2,4px);padding:.25rem}.drag-handle span{background:var(--text-light);border-radius:50%;height:4px;width:4px}.step-editing-label,.step-type-label{color:var(--text);flex:1 1;font-size:.9375rem;font-weight:600}.step-editing-label{color:var(--text-light);font-style:italic}.step-actions{align-items:center;display:flex;gap:.5rem}.btn-edit-step{background:none;border:none;color:#3182ce;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:600;padding:.25rem .5rem;transition:color .2s}.btn-edit-step:hover{color:#4299e1}.btn-delete-step{align-items:center;background:none;border:none;color:var(--text-light);cursor:pointer;display:flex;padding:.25rem;transition:color .2s}.btn-delete-step:hover{color:#dc2626}.step-card-body{align-items:center;display:flex;gap:1.5rem;padding:.75rem 1rem}.step-stat{display:flex;flex-direction:column}.stat-value{font-size:1.125rem;font-weight:700}.stat-label{font-size:.75rem}.step-pace-badge{background:#ffd70026;border-radius:4px;color:var(--primary);font-size:.75rem;font-weight:600;margin-left:auto;padding:.375rem .75rem}.step-card.run{border-left:4px solid #3182ce}.step-card.recover{border-left:4px solid #718096}.step-card.warmup{border-left:4px solid #48bb78}.step-card.cooldown{border-left:4px solid #38b2ac}.step-card.rest{border-left:4px solid #a0aec0}.step-edit-form{display:flex;flex-direction:column;gap:1.25rem;padding:1rem}.edit-section h4{color:var(--text);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.edit-row{align-items:center;display:flex;gap:1rem;margin-bottom:.75rem}.edit-row label{color:var(--text-light);font-size:.8125rem;min-width:80px}.edit-row input[type=number]:not(.time-input),.edit-row select{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;min-width:150px;padding:.625rem .75rem}.edit-row input:not(.time-input):focus,.edit-row select:focus{border-color:#3182ce;outline:none}.duration-inputs{display:flex;gap:.5rem}.duration-inputs input{width:80px}.duration-inputs select{min-width:70px}.time-row{align-items:flex-start;flex-direction:column;gap:.5rem}.time-inputs{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;display:inline-flex;gap:.25rem;padding:.5rem .75rem}.time-input{-moz-appearance:textfield;background:#0000;border:none;color:var(--text);font-family:inherit;font-size:.875rem;max-width:2.5rem;min-width:2.5rem;padding:.25rem .125rem;text-align:center;width:2.5rem}.time-input::-webkit-inner-spin-button,.time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.time-input:focus{background:var(--bg-surface)!important;border-radius:4px;outline:none}.time-separator{color:var(--text);flex-shrink:0;font-size:1rem;font-weight:600;-webkit-user-select:none;user-select:none}.time-hint{color:var(--text-light);font-size:.75rem;margin-top:.25rem}.edit-section textarea{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;min-height:60px;padding:.75rem;resize:vertical;width:100%}.edit-section textarea:focus{border-color:#3182ce;outline:none}.char-count,.edit-section textarea::placeholder{color:var(--text-light)}.char-count{display:block;font-size:.75rem;margin-top:.25rem;text-align:right}.edit-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.btn-cancel{background:#0000;border:1px solid var(--border);border-radius:6px;padding:.625rem 1.25rem}.btn-cancel,.btn-done{cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s}.btn-done{background:#3182ce;border:none;border-radius:6px;color:#fff;padding:.625rem 1.5rem}.btn-done:hover{background:#4299e1}.repeat-block{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.repeat-header{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;gap:.75rem;padding:.75rem 1rem}.repeat-label{color:var(--text);font-size:.9375rem;font-weight:600}.repeat-count-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:inherit;font-size:.875rem;padding:.375rem .5rem;text-align:center;width:50px}.repeat-count-input:focus{border-color:var(--primary);outline:none}.repeat-times{color:var(--text);flex:1 1;font-size:.875rem}.repeat-steps{gap:.5rem;padding:.75rem}.workout-summary{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;display:flex;gap:2rem;justify-content:flex-end;padding:1rem}.summary-stat{align-items:flex-end;display:flex;flex-direction:column}.summary-value{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1.25rem}.summary-label{color:var(--text-light);font-size:.75rem}@media (max-width:640px){.steps-toolbar{flex-direction:column}.btn-add-repeat,.btn-add-step{justify-content:center;width:100%}.step-card-body{flex-wrap:wrap;gap:1rem}.step-pace-badge{margin-left:0;text-align:center;width:100%}.edit-row{align-items:flex-start;flex-direction:column;gap:.5rem}.duration-inputs,.edit-row input[type=number]:not(.time-input),.edit-row select{width:100%}.duration-inputs input{flex:1 1;width:auto}.repeat-header{flex-wrap:wrap;gap:.5rem}.workout-summary{align-items:flex-end;flex-direction:column;gap:.75rem}}@media (max-width:480px){.step-card-body,.step-card-header{padding:.625rem .75rem}.step-actions{align-items:flex-end;flex-direction:column;gap:.25rem}.btn-edit-step{font-size:.75rem}}.confirm-dialog-overlay{align-items:center;animation:confirmFadeIn .15s ease-out;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:9999}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{animation:confirmSlideUp .2s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-width:400px;padding:1.75rem;text-align:center;width:100%}@keyframes confirmSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-dialog-icon{align-items:center;border-radius:50%;display:flex;height:56px;justify-content:center;margin:0 auto 1.25rem;width:56px}.confirm-dialog-icon svg{height:28px;width:28px}.confirm-dialog-icon.danger{background:#ef444426;color:#ef4444}.confirm-dialog-icon.warning{background:#fbbf2426;color:#fbbf24}.confirm-dialog-icon.default{background:#3b82f626;color:#3b82f6}.confirm-dialog-title{color:var(--text);font-size:1.25rem;font-weight:700;margin:0 0 .75rem}.confirm-dialog-message{color:var(--text-light);font-size:.9375rem;line-height:1.5;margin:0 0 1.5rem}.confirm-dialog-actions{display:flex;gap:.75rem}.confirm-dialog-btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.875rem 1.25rem;transition:all .2s}.confirm-dialog-btn-cancel{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-light)}.confirm-dialog-btn-cancel:hover{background:var(--bg-card-hover);color:var(--text)}.confirm-dialog-btn-confirm{color:#fff}.confirm-dialog-btn-confirm.danger{background:#ef4444}.confirm-dialog-btn-confirm.danger:hover{background:#dc2626;box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.confirm-dialog-btn-confirm.warning{background:#f59e0b;color:#0d0d0d}.confirm-dialog-btn-confirm.warning:hover{background:#d97706;box-shadow:0 4px 12px #f59e0b66;transform:translateY(-1px)}.confirm-dialog-btn-confirm.default{background:var(--primary);color:#0d0d0d}.confirm-dialog-btn-confirm.default:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}@media (max-width:480px){.confirm-dialog{margin:0 1rem;padding:1.5rem}.confirm-dialog-actions{flex-direction:column-reverse}.confirm-dialog-btn{width:100%}}.workout-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.workout-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.modal-close{align-items:center;background:#0000001a;border-radius:50%;color:#0d0d0d;display:flex;height:32px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:32px;z-index:10}.modal-close:hover{background:#0003}.modal-header{background:var(--primary);border-radius:16px 16px 0 0;color:#0d0d0d!important}.modal-header h2{color:#0d0d0d!important;font-size:1.5rem;margin:0 0 .25rem}.modal-date{color:#0d0d0d!important;font-size:.9375rem}.modal-body{padding:1.5rem}.workout-modal .pace-zones-display{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1.25rem;padding:1rem}.workout-modal .pace-zones-display h4{align-items:center;color:var(--text);display:flex;font-size:.875rem;gap:.5rem;margin:0 0 .75rem}.workout-modal .vdot-badge{background:var(--primary);border-radius:4px;color:#0d0d0d;font-size:.75rem;font-weight:700;padding:.125rem .5rem}.workout-modal .pace-zones-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr)}.workout-modal .pace-zone{align-items:center;border-left:3px solid;border-radius:8px;display:flex;flex-direction:column;padding:.5rem}.workout-modal .pace-zone.easy{background:#48bb781a;border-left-color:#48bb78}.workout-modal .pace-zone.marathon{background:#38b2ac1a;border-left-color:#38b2ac}.workout-modal .pace-zone.threshold{background:#ed89361a;border-left-color:#ed8936}.workout-modal .pace-zone.interval{background:#f565651a;border-left-color:#f56565}.workout-modal .pace-zone.repetition{background:#9f7aea1a;border-left-color:#9f7aea}.workout-modal .zone-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.workout-modal .zone-pace{color:var(--text);font-size:.75rem;font-weight:600;margin-top:.125rem}.workout-modal .steps-section{margin-top:.5rem}.workout-modal .steps-section h4{color:var(--text);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.form-group{margin-bottom:1.25rem}.form-group input,.form-group textarea{border:2px solid var(--border);font-size:1rem;padding:.75rem 1rem;width:100%}.form-group textarea{min-height:80px}.type-selector{grid-gap:.5rem;gap:.5rem;grid-template-columns:repeat(4,1fr)}.type-option{background:#0000;border-radius:8px;color:var(--text);font-family:inherit;padding:.625rem .5rem}.type-option:hover{border-color:var(--type-color)}.type-option.selected{border-color:#0000;color:#fff}.type-label{font-size:.8125rem}.modal-actions{align-items:center;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:1.5rem;padding-top:1.5rem}.modal-actions-right{display:flex;gap:.75rem}.btn-cancel,.btn-delete,.btn-save{border-radius:8px;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel,.btn-save{border:none}.btn-save{background:var(--primary);color:#0d0d0d}.btn-save:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.btn-cancel:disabled,.btn-delete:disabled,.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-delete{background:#0000;border:2px solid #dc2626;color:#dc2626}.btn-delete:hover{background:#dc2626;color:#fff}.recommended-pace-hint{align-items:center;background:#ffd7001a;border-radius:6px;display:flex;font-size:.8125rem;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem}.recommended-pace-hint .hint-label{color:var(--text-light);font-weight:500}.recommended-pace-hint .hint-value{color:var(--primary);flex:1 1;font-weight:700}.recommended-pace-hint .btn-use-pace{background:var(--primary);border:none;border-radius:4px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:.25rem .75rem;transition:all .2s}.recommended-pace-hint .btn-use-pace:hover{box-shadow:0 2px 8px #ffd70066;transform:translateY(-1px)}@media (max-width:640px){.workout-modal .pace-zones-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:480px){.workout-modal{margin:.5rem;max-height:calc(100vh - 1rem)}.modal-body,.modal-header{padding:1.25rem}.type-selector{grid-template-columns:repeat(3,1fr)}.workout-modal .pace-zones-grid{grid-template-columns:repeat(2,1fr)}.modal-actions{flex-direction:column;gap:.75rem}.btn-delete{order:1;width:100%}.modal-actions-right{order:0;width:100%}.btn-cancel,.btn-save{flex:1 1}}.workout-importer-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.workout-importer{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.workout-importer .modal-close{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:var(--text-light);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:32px;z-index:10}.workout-importer .modal-close:hover{background:#fff3;color:var(--text)}.importer-header{border-bottom:1px solid var(--border);padding:1.5rem}.importer-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .25rem}.importer-header p{color:var(--text-light);font-size:.875rem;margin:0}.importer-body{padding:1.5rem}.importer-error{background:#dc262626;border-radius:8px;color:#f87171;font-size:.875rem;padding:.75rem 1rem}.importer-error,.workout-importer .form-group{margin-bottom:1rem}.workout-importer .form-group label{color:var(--text);display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.workout-importer .form-group input[type=date]{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9375rem;padding:.75rem;width:100%}.workout-importer .form-group input[type=date]:focus{border-color:var(--primary);outline:none}.workout-importer .json-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8125rem;min-height:200px;padding:.75rem;resize:vertical;width:100%}.workout-importer .json-input:focus{border-color:var(--primary);outline:none}.workout-importer .json-input::placeholder{color:var(--text-light);opacity:.5}.btn-parse{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-bottom:1rem;padding:.75rem;transition:all .2s;width:100%}.btn-parse:hover{background:#ffd7001a;border-color:var(--primary)}.workout-preview{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1rem;padding:1rem}.workout-preview h3{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;margin:0 0 .75rem;text-transform:uppercase}.preview-name{color:var(--text);font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.preview-description{color:var(--text-light);font-size:.875rem;margin-bottom:.75rem}.preview-steps h4{color:var(--text);font-size:.8125rem;font-weight:600;margin:0 0 .5rem}.preview-steps ul{margin:0;padding-left:1.25rem}.preview-steps li{color:var(--text);font-size:.875rem;line-height:1.4;margin-bottom:.25rem}.importer-actions{display:flex;gap:.75rem;margin-bottom:1.5rem}.importer-actions .btn-cancel{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem;transition:all .2s}.importer-actions .btn-cancel:hover{background:var(--bg-card-hover)}.importer-actions .btn-import{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem;transition:all .2s}.importer-actions .btn-import:hover:not(:disabled){box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.importer-actions .btn-import:disabled{cursor:not-allowed;opacity:.5}.format-help{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1rem}.format-help h4{color:var(--text-light);letter-spacing:.05em;text-transform:uppercase}.format-help h4,.format-help pre{font-size:.75rem;margin:0 0 .75rem}.format-help pre{background:#0000004d;border-radius:8px;color:var(--text);font-family:Monaco,Menlo,Ubuntu Mono,monospace;overflow-x:auto;padding:.75rem}.format-notes{color:var(--text-light);font-size:.75rem}.format-notes p{margin:0 0 .25rem}.format-notes strong{color:var(--text)}@media (max-width:480px){.workout-importer{border-radius:0;max-height:100vh}.importer-body,.importer-header{padding:1rem}.importer-actions{flex-direction:column}}.calendar-view{background:var(--bg-card);border-radius:20px;box-shadow:0 4px 20px #0000004d;padding:2rem}.calendar-header{align-items:center;border-bottom:2px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.month-year{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.btn-create-plan{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:700;padding:.5rem 1.25rem;transition:all .2s;white-space:nowrap}.btn-create-plan:hover{box-shadow:0 2px 8px #ffd7004d;transform:translateY(-1px)}.calendar-header-actions{align-items:center;display:flex;gap:.75rem}.btn-create-workout{align-items:center;background:var(--primary);border:none;border-radius:50%;color:#0d0d0d;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-create-workout:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.btn-create-workout svg{stroke:#0d0d0d}.btn-import-workout{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;color:var(--text);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-import-workout:hover{background:#ffd7001a;border-color:var(--primary);color:var(--primary)}.btn-import-workout svg{stroke:currentColor}.calendar-scroll-container{max-height:340px;overflow-x:hidden;overflow-y:auto;scroll-behavior:smooth}.calendar-scroll-container::-webkit-scrollbar{width:4px}.calendar-scroll-container::-webkit-scrollbar-track{background:#0000}.calendar-scroll-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.calendar-month-section{margin-bottom:.5rem}.calendar-month-label{color:var(--text-light);font-family:Archivo Black,sans-serif;font-size:.875rem;letter-spacing:.5px;padding:.5rem 0 .375rem;text-transform:uppercase}.calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem}.weekday{color:var(--text-light);font-size:.875rem;font-weight:600;padding:.5rem;text-align:center}.calendar-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.calendar-day{background:var(--bg-surface);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;height:80px;overflow:hidden;padding:.5rem;position:relative;transition:all .2s}.calendar-day:hover{background:var(--bg-card-hover);transform:translateY(-2px)}.day-add-workout{align-items:center;background:var(--primary);border:none;border-radius:50%;cursor:pointer;display:flex;height:22px;justify-content:center;opacity:0;position:absolute;right:6px;top:6px;transform:scale(.8);transition:all .2s;width:22px;z-index:2}.day-add-workout svg{stroke:#0d0d0d}.calendar-day:hover .day-add-workout{opacity:1;transform:scale(1)}.day-add-workout:hover{box-shadow:0 2px 8px #ffd70080;transform:scale(1.1)}.calendar-day.other-month{opacity:.4}.calendar-day.today{background:#ffd70026;border:2px solid var(--primary)}.calendar-day.race-day{background:linear-gradient(135deg,#ffd7004d,#ffed4a33)}.calendar-day.has-workout{cursor:pointer}.calendar-day.drag-over{background:#ffd7004d;border:2px dashed var(--primary);transform:scale(1.02)}.calendar-day.dragging{opacity:.5}.day-number{color:var(--text);font-size:.875rem;font-weight:600}.calendar-day.today .day-number{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;display:flex;height:24px;justify-content:center;width:24px}.workout-indicator{align-items:center;cursor:grab;display:flex;flex-direction:row;width:100%}.workout-indicator:first-of-type{margin-top:auto}.workout-indicator+.workout-indicator{margin-top:2px}.workout-indicator:active{cursor:grabbing}.workout-indicator:hover{opacity:.85}.workout-badge{background:var(--primary)!important;border-radius:4px;color:#0d0d0d!important;font-size:.75rem;font-weight:700;overflow:hidden;padding:2px 6px;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%}.workout-distance{color:var(--text-light);font-size:.7rem;font-weight:500}.race-badge{background:var(--primary);border-radius:4px;color:#0d0d0d;font-size:.625rem;font-weight:700;padding:.1875rem .375rem;position:absolute;right:4px;text-transform:uppercase;top:4px}.calendar-legend{border-top:2px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.legend-title{color:var(--text);font-size:.875rem;font-weight:600;margin-bottom:.75rem}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border-radius:4px;height:16px;width:16px}.legend-label{color:var(--text-light);font-size:.8125rem}.workout-popup-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.workout-popup{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-width:400px;overflow:hidden;width:100%}.popup-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:32px}.popup-close:hover{background:#ffffff4d}.popup-header{background:var(--primary)!important;color:#0d0d0d!important;padding:1.5rem;position:relative}.popup-type{display:block;font-family:Archivo Black,sans-serif;font-size:1.5rem;margin-bottom:.25rem}.popup-date{font-size:.9375rem;opacity:.9}.popup-body{padding:1.5rem}.popup-stat{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:.75rem 0}.popup-stat:last-child{border-bottom:none}.stat-label{color:var(--text-light);font-size:.875rem;font-weight:500}.stat-value{color:var(--text);font-size:1rem;font-weight:600}.popup-description{padding-top:.75rem}.popup-description .stat-label{display:block;margin-bottom:.5rem}.popup-description p{color:var(--text);font-size:.9375rem;line-height:1.6;margin:0}.popup-steps{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.popup-steps .stat-label{display:block;margin-bottom:.5rem}.step-list-display{display:flex;flex-direction:column;gap:.375rem}.step-display-item{align-items:center;background:var(--bg-surface);border-radius:6px;display:flex;font-size:.8125rem;gap:.5rem;padding:.5rem .75rem}.step-badge{background:#718096;border-radius:4px;color:#fff;font-size:.6875rem;font-weight:600;padding:.125rem .5rem;text-transform:uppercase}.step-badge--warmup{background:#48bb78}.step-badge--active{background:#4299e1}.step-badge--interval{background:#f56565}.step-badge--recovery{background:#9f7aea}.step-badge--cooldown{background:#38b2ac}.step-badge--rest{background:#718096}.step-duration{color:var(--text)}.step-pace{background:var(--bg-card);border-radius:4px;color:var(--text-light);display:inline-flex;flex-direction:column;font-size:.6875rem;font-weight:600;padding:.25rem .5rem}.step-pace--easy{color:#48bb78}.step-pace--marathon{color:#38b2ac}.step-pace--threshold{color:#ed8936}.step-pace--interval{color:#f56565}.step-pace--repetition{color:#9f7aea}.pace-details{color:var(--text-light);display:block;font-size:.625rem;font-weight:500;margin-top:.125rem;opacity:.85}.step-display-repeat{align-items:flex-start;background:var(--bg-surface);border-left:3px solid var(--primary);border-radius:6px;gap:.5rem;padding:.5rem .75rem}.repeat-count{color:var(--primary);font-size:.875rem;min-width:2rem}.repeat-steps{gap:.25rem}.repeat-steps .step-display-item{background:#0000;border-radius:0;padding:.25rem 0}.popup-stat.recommended-pace{background:#ffd70014;border-radius:8px;margin:.5rem 0;padding:.75rem}.popup-stat.recommended-pace .stat-label{color:var(--primary);font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.popup-stat.recommended-pace .pace-highlight{color:var(--primary);font-weight:700}.popup-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;margin-top:1.25rem;padding-top:1rem}.popup-btn{border-radius:8px;cursor:pointer;flex:1 1;font-family:inherit;font-size:.875rem;font-weight:600;padding:.75rem 1rem;transition:all .2s}.popup-btn-edit{background:var(--primary);border:none;color:#0d0d0d}.popup-btn-edit:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.popup-btn-delete{background:#0000;border:2px solid #dc2626;color:#dc2626}.popup-btn-delete:hover{background:#dc2626;color:#fff}@media (max-width:768px){.calendar-view{padding:1rem}.month-year{font-size:1.125rem}.btn-import-workout{display:none}.calendar-scroll-container{max-height:280px}.weekday{font-size:.75rem;padding:.25rem}.calendar-day{height:62px;padding:.25rem}.day-number{font-size:.75rem}.workout-badge{padding:1px 4px}.workout-badge,.workout-distance{font-size:.625rem}.legend-items{gap:.5rem}.legend-item{font-size:.75rem}.legend-color{height:12px;width:12px}}@media (max-width:480px){.month-year,.nav-arrow{font-size:1rem}.nav-arrow{padding:.25rem}.calendar-day{aspect-ratio:auto;min-height:50px}.workout-distance{display:none}}.create-plan-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.create-plan-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:520px;overflow-y:auto;position:relative;width:100%}.create-plan-modal .modal-close{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;color:var(--text-light);cursor:pointer;display:flex;font-size:1.25rem;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s;width:32px;z-index:10}.create-plan-modal .modal-close:hover{background:var(--bg-card-hover);color:var(--text)}.create-plan-modal .modal-header{padding:1.5rem 1.5rem 0}.create-plan-modal .modal-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.create-plan-modal .modal-header p{color:var(--text-light);font-size:.9375rem;margin:0}.create-plan-modal .modal-body{padding:1.5rem}.create-plan-modal .modal-error{background:#dc262626;border-radius:8px;color:#f87171;font-size:.875rem;margin-bottom:1rem;padding:.75rem 1rem}.create-plan-modal .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.create-plan-modal .form-group{display:flex;flex-direction:column;margin-bottom:1rem}.create-plan-modal .checkbox-group{margin-bottom:1rem}.create-plan-modal .checkbox-label{align-items:center;color:var(--text);cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.75rem}.create-plan-modal .checkbox-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer;height:20px;width:20px}.create-plan-modal .checkbox-label span{margin-bottom:0}.create-plan-modal .form-group label{color:var(--text);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.create-plan-modal .form-group input,.create-plan-modal .form-group select{background:var(--bg-surface);border:2px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s}.create-plan-modal .form-group input:focus,.create-plan-modal .form-group select:focus{border-color:var(--primary);outline:none}.create-plan-modal .form-group input[type=date]{color-scheme:dark}.create-plan-modal .form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7}.create-plan-modal .form-group input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.create-plan-modal .form-hint{color:var(--text-light);font-size:.75rem;margin-top:.25rem}.create-plan-modal .modal-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem}.create-plan-modal .btn-cancel,.create-plan-modal .btn-save{border-radius:8px;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.create-plan-modal .btn-cancel{background:var(--bg-surface);border:none;color:var(--text)}.create-plan-modal .btn-cancel:hover{background:var(--bg-card-hover)}.create-plan-modal .btn-save{background:var(--primary);border:none;color:#0d0d0d}.create-plan-modal .btn-save:hover:not(:disabled){box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.create-plan-modal .btn-cancel:disabled,.create-plan-modal .btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:520px){.create-plan-modal .form-row{gap:0;grid-template-columns:1fr}.create-plan-modal .form-group{margin-bottom:1rem}.create-plan-modal .modal-actions{flex-direction:column}.create-plan-modal .btn-cancel,.create-plan-modal .btn-save{text-align:center;width:100%}}.workout-builder-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.workout-builder{background:var(--bg-card);border-radius:16px;box-shadow:0 8px 32px #0006;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.workout-builder-header{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.workout-builder-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.workout-builder-date{color:var(--text-light);flex:1 1;font-size:.875rem;font-weight:500;text-align:center}.workout-builder-header .close-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:1.5rem;line-height:1;padding:.25rem .5rem;transition:color .2s}.workout-builder-header .close-btn:hover{color:var(--text)}.workout-builder form{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.loading-paces{color:var(--text-light);padding:3rem;text-align:center}.pace-zones-display{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1rem}.pace-zones-display h4{align-items:center;color:var(--text);display:flex;font-size:.875rem;gap:.5rem;margin:0 0 .75rem}.vdot-badge{background:var(--primary);border-radius:4px;color:#0d0d0d;font-size:.75rem;font-weight:700;padding:.125rem .5rem}.pace-zones-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr)}.pace-zone{align-items:center;border-left:3px solid;border-radius:8px;display:flex;flex-direction:column;padding:.5rem}.pace-zone.easy{background:#48bb781a;border-left-color:#48bb78}.pace-zone.marathon{background:#38b2ac1a;border-left-color:#38b2ac}.pace-zone.threshold{background:#ed89361a;border-left-color:#ed8936}.pace-zone.interval{background:#f565651a;border-left-color:#f56565}.pace-zone.repetition{background:#9f7aea1a;border-left-color:#9f7aea}.zone-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.zone-pace{color:var(--text);font-size:.75rem;font-weight:600;margin-top:.125rem}.steps-section h4,.templates-section h4{color:var(--text);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.steps-section{margin-top:.5rem}.templates-grid{grid-gap:.5rem;gap:.5rem;grid-template-columns:repeat(2,1fr)}.template-btn{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;padding:.75rem;transition:all .2s}.template-btn:hover{background:#ffd7001a;border-color:var(--primary)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text)}.form-group input,.form-group textarea{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9375rem;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-light)}.schedule-group{position:relative}.schedule-hint{color:var(--text-light);font-size:.75rem}.error-message{background:#dc26261a;border:1px solid #dc26264d;border-radius:8px;color:#dc2626}.error-message,.success-message{font-size:.875rem;padding:.75rem 1rem}.success-message{background:#48bb781a;border:1px solid #48bb784d;border-radius:8px;color:#48bb78}.form-actions{display:flex;gap:1rem;padding-top:.5rem}.btn-secondary{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.875rem;transition:all .2s}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover)}.btn-primary{align-items:center;background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem;transition:all .2s}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-primary .spinner{animation:spin .8s linear infinite;border:2px solid #0003;border-radius:50%;border-top-color:#0d0d0d;height:16px;width:16px}.btn-garmin{background:#007aff;color:#fff}.btn-garmin:hover:not(:disabled){background:#0062cc;box-shadow:0 4px 12px #007aff66}.btn-success{align-items:center;background:#28a745;border:none;border-radius:8px;color:#fff;display:flex;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;opacity:.8;padding:.875rem}.garmin-required-hint{color:var(--text-light);font-size:.8125rem;margin:0;text-align:center}@media (max-width:640px){.workout-builder{border-radius:0;max-height:100vh}.pace-zones-grid{grid-template-columns:repeat(3,1fr)}.pace-zones-grid .pace-zone:nth-child(4),.pace-zones-grid .pace-zone:nth-child(5){grid-column:span 1}.templates-grid{grid-template-columns:1fr}}@media (max-width:480px){.workout-builder form,.workout-builder-header{padding:1rem}.pace-zones-grid{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column}}.training-plan-view{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.training-plan-container{margin:0 auto;max-width:1000px}.plan-main-column,.training-plan-layout{display:flex;flex-direction:column}.plan-main-column{gap:1.5rem}.plan-overview-header{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;color:var(--text);padding:1.5rem 2rem}.plan-overview-header h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.75rem;margin:0 0 1rem}.plan-progress-bar{align-items:center;display:flex;gap:1rem}.progress-track{background:#fff3;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-track .progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s ease}.progress-label{color:#ffffffe6;font-size:.875rem;white-space:nowrap}.week-summary-card{border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.25rem 1.5rem}.week-summary-card,.week-summary-card.retest{background:var(--bg-card)}.week-summary-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.week-summary-info{align-items:center;display:flex;gap:.75rem}.week-summary-info h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .25rem}.week-summary-title-row{align-items:center;display:flex;gap:.75rem}.btn-current-week{background:var(--bg-surface);border:none;border-radius:12px;color:var(--primary);cursor:pointer;font-family:inherit;font-size:.6875rem;font-weight:600;padding:.25rem .625rem;transition:all .2s}.btn-current-week:hover{background:var(--primary);color:#0d0d0d}.week-summary-phase{color:var(--text-light);font-size:.8125rem;font-weight:500}.week-summary-dates{color:var(--text-light);display:block;font-size:.75rem;margin-top:.25rem}.week-summary-stats{align-items:center;display:flex;gap:1.25rem}.unit-toggle-group{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;display:flex;overflow:hidden}.unit-toggle-btn{background:#0000;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:.25rem .625rem;text-transform:uppercase;transition:all .2s}.unit-toggle-btn:first-child{border-right:1px solid var(--border)}.unit-toggle-btn:hover:not(.active){background:var(--bg-card-hover);color:var(--text)}.unit-toggle-btn.active{background:var(--primary);color:#0d0d0d}.summary-stat{text-align:center}.summary-stat-value{color:var(--primary);display:block;font-family:Archivo Black,sans-serif;font-size:1.5rem;line-height:1}.summary-stat-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.retest-badge-small{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:12px;color:#fff;font-size:.6875rem;font-weight:700;padding:.25rem .625rem}.week-navigation{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:4px;margin-bottom:1rem;padding-bottom:.75rem;width:100%}.week-nav-pill{align-items:center;background:var(--bg-surface);border:none;border-radius:6px;color:var(--text-light);cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:.6875rem;font-weight:600;height:28px;justify-content:center;margin:0 2px;min-width:0;padding:0;transition:all .2s}.week-nav-pill:hover{background:var(--bg-card-hover);color:var(--text)}.week-nav-pill.active{background:var(--primary);color:#0d0d0d}.week-nav-pill.current:not(.active){background:#ffd7001a;border:2px solid var(--primary)}.week-workout-row{display:flex;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;width:100%}.workout-day-card{align-items:center;background:var(--bg-surface);border-radius:10px;display:flex;flex:1 1;flex-direction:column;gap:.375rem;justify-content:center;min-width:0;padding:.75rem .5rem;transition:all .2s}.workout-day-card:hover{background:var(--bg-card-hover)}.workout-day-card.today{background:#ffd70026;border:2px solid var(--primary)}.card-day{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.workout-day-card.today .card-day{color:var(--secondary)}.card-type{background:var(--primary);border-radius:6px;color:#0d0d0d;font-size:.6875rem;font-weight:700;max-width:100%;padding:.25rem .5rem;text-align:center;word-break:break-word}.card-distance{color:var(--text);font-size:.8125rem;font-weight:700}.card-pace-info{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem;padding-top:.375rem;width:100%}.pace-row{align-items:center;display:flex;flex-wrap:wrap;font-size:.625rem;gap:.375rem;justify-content:center}.pace-label{color:var(--text-light);font-weight:500;min-width:35px;text-transform:uppercase}.pace-value{color:var(--primary);font-weight:600}.pace-value.secondary{color:var(--text-light);opacity:.7}.week-summary-header-row{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.week-summary-toggle{-webkit-tap-highlight-color:transparent;align-items:center;border:none;display:flex;flex:1 1;gap:.75rem;min-width:0;padding:.5rem 0;pointer-events:auto;text-align:left}.btn-create-plan-inline,.week-summary-toggle{background:#0000;cursor:pointer;font-family:inherit}.btn-create-plan-inline{border:1px solid var(--border);border-radius:8px;color:var(--text-light);flex-shrink:0;font-size:.75rem;font-weight:600;padding:.375rem .75rem;transition:all .2s;white-space:nowrap}.btn-create-plan-inline:hover{border-color:var(--primary);color:var(--primary)}.week-summary-toggle:hover{opacity:.9}.week-summary-toggle:active{opacity:.8}.week-summary-toggle-left{align-items:center;display:flex;gap:.75rem}.week-summary-toggle-left h3{font-size:1.5rem}.week-summary-toggle h3,.week-summary-toggle-left h3{color:var(--primary);font-family:Archivo Black,sans-serif;margin:0}.week-summary-toggle h3{font-size:1.25rem}.week-toggle-arrow{color:var(--text-light);font-size:.75rem}.week-summary-phase-inline{color:var(--text-light);display:block;font-size:.8125rem;font-weight:500;margin-top:.25rem}.week-summary-toggle-right{align-items:center;display:flex;gap:.75rem}.week-summary-stat-inline{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1rem}.week-summary-content{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.week-summary-focus{color:var(--text);font-size:.8125rem;line-height:1.4;margin:0}.btn-retest-compact{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:700;margin-top:.75rem;padding:.5rem 1rem;transition:all .2s}.btn-retest-compact:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}@media (max-width:768px){.training-plan-view{min-height:100vh;padding:1rem}.plan-overview-header{padding:1.25rem 1.5rem}.plan-overview-header h1{font-size:1.5rem}.week-summary-header{align-items:flex-start;flex-direction:column;gap:.75rem}.week-summary-stats{align-self:flex-start}.week-summary-toggle-left h3{font-size:1.125rem}.week-navigation{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto;padding-bottom:.875rem;scrollbar-width:none}.week-navigation::-webkit-scrollbar{display:none}.week-nav-pill{flex:0 0 auto;font-size:.5625rem;height:26px;min-width:30px}.week-workout-row{flex-direction:column;gap:.375rem}.workout-day-card{align-items:center;border-radius:10px;flex-direction:row;gap:.75rem;justify-content:flex-start;padding:.75rem 1rem}.card-day{flex-shrink:0;min-width:36px;text-align:left}.card-type{flex:1 1;text-align:left;word-break:break-word}.card-distance{flex-shrink:0;font-size:.875rem}}.pace-breakdown{background:var(--bg-surface);border-radius:12px;margin:1rem 0;padding:1rem}.pace-breakdown h4{color:var(--text-light);font-size:.8125rem;font-weight:600;letter-spacing:.5px;margin:0 0 .75rem;text-transform:uppercase}.pace-bar{background:var(--bg);border-radius:6px;display:flex;height:12px;margin-bottom:.75rem;overflow:hidden}.pace-segment{min-width:2px;transition:width .3s ease}.pace-segment:first-child{border-radius:6px 0 0 6px}.pace-segment:last-child{border-radius:0 6px 6px 0}.pace-segment:only-child{border-radius:6px}.pace-legend{display:flex;flex-wrap:wrap;gap:.75rem 1rem}.pace-legend-item{align-items:center;display:flex;font-size:.75rem;gap:.375rem}.pace-breakdown .pace-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.pace-breakdown .pace-label{color:var(--text-light);font-weight:500}.pace-breakdown .pace-value{color:var(--text);font-weight:600}@media (max-width:480px){.pace-breakdown{padding:.75rem}.pace-legend{flex-direction:column;gap:.5rem}.pace-legend-item{font-size:.6875rem}.pace-breakdown .pace-dot{height:8px;width:8px}}.settings-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.settings-header{align-items:center;border-bottom:2px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem 2rem}.settings-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.settings-modal .close-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.75rem;line-height:1;padding:0;transition:all .2s}.settings-modal .close-btn:hover{color:var(--primary)}.settings-tabs{border-bottom:2px solid var(--border);display:flex;padding:0 2rem}.tab-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 1.5rem;position:relative;transition:color .2s}.tab-btn.active,.tab-btn:hover{color:var(--text)}.tab-btn.active:after{background:var(--primary);border-radius:3px 3px 0 0;bottom:-2px;content:"";height:3px;left:0;position:absolute;right:0}.settings-form{padding:2rem}.tab-content{min-height:300px}.settings-form .form-group{margin-bottom:1.5rem}.settings-form label{color:var(--text-light);display:block;font-size:.9375rem;font-weight:600;margin-bottom:.5rem}.settings-form input,.settings-form select{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;box-sizing:border-box;color:var(--text);font-family:inherit;font-size:1rem;padding:.875rem;transition:all .2s;width:100%}.settings-form input::placeholder{color:var(--text-light)}.settings-form input:focus,.settings-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.settings-form select option{background:var(--bg-surface);color:var(--text)}.settings-form small{color:var(--text-light);display:block;font-size:.8125rem;margin-top:.375rem}.settings-form .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.settings-form .form-row .form-group{margin-bottom:1.5rem}.profile-image-section{align-items:center;border-bottom:2px solid var(--border);display:flex;flex-direction:column;margin-bottom:2rem;padding-bottom:1.5rem}.profile-image-preview{align-items:center;background:var(--bg-surface);border:3px solid var(--border);border-radius:50%;cursor:pointer;display:flex;height:120px;justify-content:center;overflow:hidden;transition:all .2s;width:120px}.profile-image-preview:hover{border-color:var(--primary);transform:scale(1.02)}.profile-image-preview img{height:100%;object-fit:cover;width:100%}.profile-image-placeholder{align-items:center;color:var(--text-light);display:flex;flex-direction:column;justify-content:center}.profile-image-placeholder span:first-child{font-size:2rem;margin-bottom:.25rem}.profile-image-placeholder .placeholder-text{font-size:.75rem;font-weight:600}.change-photo-btn{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-top:.75rem;padding:.5rem 1rem;transition:all .2s}.change-photo-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-light);color:var(--text)}.change-photo-btn:disabled{cursor:not-allowed;opacity:.6}.profile-image-preview.uploading{cursor:not-allowed;opacity:.7}.upload-spinner{animation:spin 1s linear infinite;font-size:2rem;margin-bottom:.25rem}.height-imperial{align-items:center;display:flex;gap:.5rem}.height-imperial input{text-align:center;width:70px}.height-imperial .height-unit{color:var(--text-light);font-size:.875rem;font-weight:500}.race-time-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.training-level-options{display:flex;flex-direction:column;gap:.75rem}.training-level-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;padding:1rem;transition:all .2s}.training-level-option:hover{background:var(--bg-card-hover);border-color:var(--text-light)}.training-level-option.selected{background:#ffd7001a;border-color:var(--primary)}.training-level-option input[type=radio]{accent-color:var(--primary);cursor:pointer;height:20px;margin-right:1rem;width:20px}.level-content{display:flex;flex-direction:column}.level-name{color:var(--text);font-size:1rem;font-weight:600}.level-desc{color:var(--text-light);font-size:.8125rem;margin-top:.125rem}.pb-hint{margin-bottom:.75rem!important;margin-top:0!important}.pb-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.pb-input-group{display:flex;flex-direction:column;gap:.25rem}.pb-input-group label{color:var(--text-light);font-size:.75rem;font-weight:600;margin-bottom:0}.pb-input-group input{font-size:.9375rem;padding:.625rem .75rem}.settings-form input[type=date]{background:var(--bg-surface);color:var(--text);color-scheme:dark}.settings-form input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7}.settings-form input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.settings-form .datepicker-input{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s;width:100%}.settings-form .datepicker-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.settings-form .react-datepicker-wrapper{width:100%}.settings-form .react-datepicker__input-container{align-items:center;display:flex;position:relative}.settings-form .react-datepicker__calendar-icon{fill:var(--text-light);height:20px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px}.settings-form .react-datepicker__input-container .datepicker-input{padding-right:40px}.privacy-info{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;display:flex;gap:1rem;margin-top:1.5rem;padding:1rem}.privacy-info__icon{flex-shrink:0}.privacy-info__icon svg{color:var(--primary);height:24px;width:24px}.privacy-info__text{display:flex;flex-direction:column;gap:.25rem}.privacy-info__text strong{color:var(--text);font-size:.9375rem}.privacy-info__text p{color:var(--text-light);font-size:.8125rem;line-height:1.4;margin:0}.settings-error{background:#ef44441a;border-left:4px solid #ef4444;color:#f87171}.settings-error,.settings-success{border-radius:10px;margin-bottom:1.5rem;padding:1rem}.settings-success{background:#48bb781a;border-left:4px solid #48bb78;color:#68d391}.settings-footer{border-top:2px solid var(--border);display:flex;gap:1rem;margin-top:1rem;padding-top:1rem}.settings-footer .btn-primary,.settings-footer .btn-secondary{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-family:inherit;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .2s}.settings-footer .btn-primary{background:var(--primary);color:#0d0d0d}.settings-footer .btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #ffd70066;transform:translateY(-2px)}.settings-footer .btn-primary:disabled{cursor:not-allowed;opacity:.6}.settings-footer .btn-secondary{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-light)}.settings-footer .btn-secondary:hover{background:var(--bg-card-hover);color:var(--text)}@media (max-width:768px){.settings-modal{margin:.5rem;max-height:95vh;max-width:100%}.settings-header{padding:1rem 1.5rem}.settings-header h2{font-size:1.25rem}.settings-tabs{padding:0 1rem}.tab-btn{font-size:.9375rem;padding:.75rem 1rem}.settings-form{padding:1.5rem}.pb-grid,.race-time-row,.settings-form .form-row{grid-template-columns:1fr}.height-imperial{flex-wrap:wrap}.height-imperial input{width:60px}.profile-image-preview{height:100px;width:100px}.settings-footer{flex-direction:column-reverse}.settings-footer .btn-primary,.settings-footer .btn-secondary{width:100%}}.training-paces-display{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.vdot-display{border-bottom:1px solid var(--border);justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.vdot-display,.vdot-label{align-items:center;display:flex}.vdot-label{color:var(--text);font-size:.9375rem;font-weight:600}.vdot-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.75rem}.paces-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr)}.pace-item{align-items:center;border-radius:8px;display:flex;flex-direction:column;padding:.75rem .5rem;text-align:center}.pace-item.easy{background:#48bb7826}.pace-item.marathon{background:#38b2ac26}.pace-item.threshold{background:#ed893626}.pace-item.interval{background:#f5656526}.pace-item.repetition{background:#9f7aea26}.pace-zone{color:var(--text-light);font-size:.6875rem;font-weight:600;letter-spacing:.5px;margin-bottom:.25rem;text-transform:uppercase}.pace-value{color:var(--text);font-size:.875rem;font-weight:700}.pace-item.easy .pace-value{color:#48bb78}.pace-item.marathon .pace-value{color:#38b2ac}.pace-item.threshold .pace-value{color:#ed8936}.pace-item.interval .pace-value{color:#f56565}.pace-item.repetition .pace-value{color:#9f7aea}.pace-unit{font-size:.6875rem;margin-top:.125rem}.pace-speed,.pace-unit{color:var(--text-light)}.pace-speed{font-size:.625rem;margin-top:.25rem;opacity:.8}.vdot-changed-badge{background:var(--primary);border-radius:10px;color:#0d0d0d;display:inline-block;font-size:.625rem;font-weight:700;letter-spacing:.5px;margin-left:.5rem;padding:.125rem .5rem;text-transform:uppercase}.training-paces-display.preview{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}@media (max-width:768px){.paces-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:480px){.paces-grid{grid-template-columns:repeat(2,1fr)}.vdot-display{flex-direction:column;gap:.5rem;text-align:center}}.community-dropdown{position:relative}.community-trigger{align-items:center;display:flex;gap:.375rem}.dropdown-arrow{height:16px;transition:transform .2s ease;width:16px}.dropdown-arrow.open{transform:rotate(180deg)}.community-menu{animation:slideDown .15s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 30px #0006;left:50%;min-width:220px;padding:.5rem;position:absolute;top:calc(100% + 8px);transform:translateX(-50%);z-index:100}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.community-item{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;text-align:left;transition:background .15s ease;width:100%}.community-item:hover{background:var(--bg-surface)}.community-item:hover .community-item__title{color:var(--primary)}.community-item.active{background:#ffd70026}.community-item__icon{flex-shrink:0;font-size:1.25rem}.community-item__content{display:flex;flex-direction:column;gap:.125rem}.community-item__title{color:var(--secondary);font-size:.9375rem;font-weight:600}.community-item__desc{color:var(--text-light);font-size:.75rem}@media (max-width:768px){.community-menu{left:auto;right:-1rem;transform:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}}.global-search{flex:0 0 auto;margin:0 .5rem;position:relative}.global-search--expanded{flex:1 1;margin:0 1.5rem;max-width:450px}.global-search__trigger{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;height:40px;justify-content:center;transition:background-color .2s;width:40px}.global-search__trigger:hover{background:var(--bg-surface)}.global-search__trigger svg{color:var(--text-light);height:20px;transition:color .2s;width:20px}.global-search__trigger:hover svg{color:var(--primary)}.global-search__input-wrapper{align-items:center;display:flex;position:relative}.global-search__icon{color:var(--text-light);height:18px;left:.75rem;pointer-events:none;position:absolute;width:18px}.global-search__input{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.875rem;outline:none;padding:.5rem 2.5rem;transition:border-color .2s,background-color .2s;width:100%}.global-search__input:focus{background:var(--bg-card);border-color:var(--primary)}.global-search__input::placeholder{color:var(--text-light)}.global-search__spinner{animation:search-spin .8s linear infinite;border:2px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:16px;position:absolute;right:.75rem;width:16px}@keyframes search-spin{to{transform:rotate(1turn)}}.global-search__dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0000004d;left:0;max-height:400px;min-width:350px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.global-search__no-results{color:var(--text-light);font-size:.875rem;padding:1.5rem;text-align:center}.global-search__section{padding:.5rem 0}.global-search__section:not(:last-child){border-bottom:1px solid var(--border)}.global-search__section-header{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase}.global-search__result{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:.75rem;padding:.625rem 1rem;text-align:left;transition:background-color .15s;width:100%}.global-search__result:hover{background:var(--bg-surface)}.global-search__result-avatar{align-items:center;background:var(--bg-surface);border-radius:50%;color:var(--primary);display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:36px;justify-content:center;overflow:hidden;width:36px}.global-search__result-avatar img{height:100%;object-fit:cover;width:100%}.global-search__result-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:.875rem;font-weight:700;height:36px;justify-content:center;width:36px}.global-search__result-icon.club{background:#6366f126;color:#818cf8}.global-search__result-icon.group{background:#22c55e26;color:#4ade80}.global-search__result-icon.race{background:#fbbf2426;color:#fbbf24}.global-search__result-info{flex:1 1;min-width:0}.global-search__result-name{color:var(--text);font-size:.875rem;font-weight:600}.global-search__result-meta,.global-search__result-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.global-search__result-meta{color:var(--text-light);font-size:.75rem}.global-search__user-result{align-items:center;display:flex;gap:.5rem;justify-content:space-between;padding:.625rem 1rem;transition:background-color .15s}.global-search__user-result:hover{background:var(--bg-surface)}.global-search__user-info{align-items:center;display:flex;flex:1 1;gap:.75rem;min-width:0}.global-search__user-actions{align-items:center;display:flex;flex-shrink:0;gap:.375rem}.global-search__action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-family:inherit;font-size:.75rem;font-weight:600;justify-content:center;transition:all .15s}.global-search__action-btn.follow{background:var(--primary);color:#0d0d0d;padding:.375rem .75rem}.global-search__action-btn.follow:hover{filter:brightness(1.1)}.global-search__action-btn.following{background:#0000;border:1px solid var(--border);color:var(--text-light);padding:.375rem .75rem}.global-search__action-btn.following:hover{border-color:#ef4444;color:#ef4444}.global-search__action-btn.message,.global-search__action-btn.profile{background:var(--bg-surface);color:var(--text-light);height:28px;width:28px}.global-search__action-btn.message:hover,.global-search__action-btn.profile:hover{background:var(--primary);color:#0d0d0d}.global-search__action-btn svg{height:14px;width:14px}.global-search__action-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.global-search{margin:0;position:static}.global-search--expanded{margin:0;max-width:none;position:static}.global-search--expanded .global-search__input-wrapper{background:var(--bg-card);border-bottom:1px solid var(--border);height:auto;left:0;padding:1rem;position:fixed;right:0;top:0;width:100%;z-index:1001}.global-search--expanded .global-search__input{padding:.75rem 2.5rem}.global-search--expanded .global-search__icon{left:1.75rem}.global-search--expanded .global-search__dropdown{border-radius:0;left:0;max-height:calc(100vh - 70px);position:fixed;right:0;top:70px}}.challenges-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.challenges-container{margin:0 auto;max-width:1200px}.challenges-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.challenges-header__left h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .25rem}.challenges-header__left p{color:var(--text-light);margin:0}.btn-create-challenge{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.btn-create-challenge:hover{box-shadow:0 2px 8px #ffd70066;transform:translateY(-1px)}.challenges-tabs{background:var(--bg-card);border-radius:10px;display:inline-flex;margin-bottom:1.5rem;padding:4px}.challenges-tabs .tab{background:#0000;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;font-size:.9375rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.challenges-tabs .tab:hover:not(.active){color:var(--text)}.challenges-tabs .tab.active{background:var(--primary);color:#0d0d0d}.challenges-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.challenges-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;grid-column:1/-1;padding:3rem;text-align:center}.challenges-empty p{color:var(--text-light);margin-bottom:1rem}.challenges-empty .btn-primary,.challenges-empty .btn-secondary{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.challenges-empty .btn-primary{background:var(--primary);color:#0d0d0d}.challenges-empty .btn-secondary{background:var(--bg-surface);color:var(--text)}.challenges-loading{color:var(--text-light);padding:3rem;text-align:center}.challenge-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.challenge-card__header{align-items:flex-start;display:flex;justify-content:space-between}.challenge-card__title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.challenge-card__badge{border-radius:20px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.challenge-card__badge--distance{background:var(--primary);color:#0d0d0d}.challenge-card__badge--streak{background:#fef3c7;color:#92400e}.challenge-card__badge--specific{background:#dcfce7;color:#166534}.challenge-card__description{color:var(--text-light);font-size:.9375rem;line-height:1.5;margin:0}.challenge-card__meta{color:var(--text-light);display:flex;font-size:.875rem;gap:1.5rem}.challenge-card__target{align-items:baseline;display:flex;gap:.25rem}.challenge-card__target-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem}.challenge-card__target-unit{color:var(--text-light);font-size:.875rem}.challenge-card__progress{display:flex;flex-direction:column;gap:.5rem}.challenge-card__progress-bar{background:var(--bg-surface);border-radius:4px;height:8px;overflow:hidden}.challenge-card__progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s ease}.challenge-card__progress-text{color:var(--text-light);display:flex;font-size:.75rem;justify-content:space-between}.challenge-card__footer{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem;margin-top:auto;padding-top:1rem}.challenge-card__footer-row{display:flex;gap:.75rem}.challenge-card__footer button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.625rem 1rem;transition:all .2s}.challenge-card__footer .btn-join{background:var(--bg-surface);border:1px solid var(--border);color:var(--primary)}.challenge-card__footer .btn-join:hover{background:var(--bg-card-hover);border-color:var(--primary)}.challenge-card__footer .btn-leave{background:#dc2626;color:#fff}.challenge-card__footer .btn-leave:hover{background:#b91c1c}.challenge-card__footer .btn-leaderboard{background:var(--primary);color:#0d0d0d}.challenge-card__footer .btn-leaderboard:hover{box-shadow:0 4px 12px #ffd70066}.challenge-card__footer .btn-edit{background:var(--bg-surface);border:1px solid var(--border);color:var(--primary)}.challenge-card__footer .btn-edit:hover{background:var(--bg-card-hover);border-color:var(--primary)}.challenge-card__footer .btn-delete{background:#dc2626;color:#fff}.challenge-card__footer .btn-delete:hover{background:#b91c1c}.challenge-card__participants{color:var(--text-light);font-size:.75rem}.monthly-challenges-section{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;margin-bottom:2rem;padding:1.5rem}.monthly-header{margin-bottom:1.25rem}.monthly-header h2{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .25rem}.monthly-subtitle{color:var(--text-light);font-size:.875rem}.monthly-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.monthly-challenge-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .2s}.monthly-challenge-card:hover{background:var(--bg-card-hover);border-color:var(--primary)}.monthly-challenge-card.joined{background:#ffd7000d;border-color:var(--primary)}.monthly-challenge-card.completed{background:linear-gradient(135deg,#ffd70026,#ffd7000d);border-color:var(--primary)}.monthly-challenge-icon{flex-shrink:0;font-size:2rem}.monthly-challenge-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.monthly-challenge-title{color:var(--text);font-size:.9375rem;font-weight:700}.monthly-challenge-target{color:var(--text-light);font-size:.8125rem}.monthly-progress{margin-top:.5rem}.monthly-progress .progress-bar{background:var(--bg-card);border-radius:3px;height:6px;margin-bottom:.25rem;overflow:hidden}.monthly-progress .progress-fill{background:var(--primary);border-radius:3px;height:100%;transition:width .3s ease}.monthly-progress .progress-text{color:var(--text-light);font-size:.75rem}.monthly-challenge-actions{flex-shrink:0}.btn-join-small,.btn-leave-small{border:none;border-radius:8px;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.btn-join-small{background:var(--primary);color:#0d0d0d}.btn-join-small:hover{box-shadow:0 2px 8px #ffd70066}.btn-leave-small{background:#dc262626;color:#f87171}.btn-leave-small:hover{background:#dc262640}.completed-badge{background:var(--primary);border-radius:20px;color:#0d0d0d;display:inline-block;font-size:.75rem;font-weight:700;padding:.375rem .75rem}.challenges-empty__actions{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.create-challenge-modal{max-width:560px}.challenge-type-options{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.type-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;padding:1rem .5rem;text-align:center;transition:all .2s}.type-option input{display:none}.type-option:hover{background:var(--bg-card-hover);border-color:var(--primary)}.type-option.selected{background:#ffd7001a;border-color:var(--primary)}.type-icon{font-size:1.5rem}.type-label{color:var(--text);font-size:.875rem;font-weight:600}.type-desc{color:var(--text-light);font-size:.75rem}.visibility-options{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.visibility-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;gap:.75rem;padding:.875rem;transition:all .2s}.visibility-option input{display:none}.visibility-option:hover{background:var(--bg-card-hover);border-color:var(--primary)}.visibility-option.selected{background:#ffd7001a;border-color:var(--primary)}.visibility-icon{flex-shrink:0;font-size:1.25rem}.visibility-text{display:flex;flex-direction:column;gap:.125rem}.visibility-label{color:var(--text);font-size:.875rem;font-weight:600}.visibility-desc{color:var(--text-light);font-size:.6875rem}.form-hint{color:var(--text-light);display:block;font-size:.75rem;margin-top:.375rem}@media (max-width:768px){.challenges-page{padding:1rem}.challenges-header{align-items:stretch;flex-direction:column;gap:1rem}.btn-create-challenge{width:100%}.challenges-grid,.monthly-grid{grid-template-columns:1fr}.monthly-challenge-card{flex-wrap:wrap}.monthly-challenge-info{flex:1 1 60%}.monthly-challenge-actions{flex:0 0 auto}.challenges-empty__actions{flex-direction:column}.challenge-type-options,.visibility-options{grid-template-columns:1fr}}.clubs-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.clubs-container{margin:0 auto;max-width:1200px}.clubs-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.clubs-header__left h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .25rem}.clubs-header__left p{color:var(--text-light);margin:0}.clubs-header__actions{display:flex;gap:.75rem}.clubs-header__actions .btn-primary,.clubs-header__actions .btn-secondary{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.clubs-header__actions .btn-primary{background:var(--primary);color:#0d0d0d}.clubs-header__actions .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.clubs-header__actions .btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text)}.clubs-header__actions .btn-secondary:hover{background:var(--bg-card-hover)}.clubs-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.clubs-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:4rem 2rem;text-align:center}.clubs-empty__icon{font-size:3rem;margin-bottom:1rem}.clubs-empty h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.clubs-empty p{color:var(--text-light);margin:0 0 1.5rem}.clubs-empty .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.clubs-loading{color:var(--text-light);padding:3rem;text-align:center}.club-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;cursor:pointer;display:flex;flex-direction:column;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.club-card:hover{box-shadow:0 8px 30px #0006;transform:translateY(-4px)}.club-card__header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between}.club-card__title-row{display:flex;flex-direction:column;gap:.375rem}.club-card__title{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.club-card__role{border-radius:20px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase;white-space:nowrap}.club-card__role--super_admin{background:var(--primary);color:#0d0d0d}.club-card__role--admin{background:#fef3c7;color:#92400e}.club-card__role--member{background:#e0e7ff;color:#3730a3}.club-card__description{color:var(--text-light);font-size:.9375rem;line-height:1.5;margin:0}.club-card__stats{display:flex;gap:1.5rem}.club-card__stat{display:flex;flex-direction:column;gap:.125rem}.club-card__stat-value{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem}.club-card__stat-label{color:var(--text-light);font-size:.75rem}.club-card__footer{border-top:1px solid var(--border);display:flex;gap:.75rem;margin-top:auto;padding-top:1rem}.club-card__footer button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.625rem 1rem;transition:all .2s}.club-card__footer .btn-view{background:var(--primary);color:#0d0d0d}.club-card__footer .btn-leave{background:#dc262626;color:#f87171}.modal-small{max-width:400px}.join-form{padding:1rem 0}.create-club-modal{max-width:500px}.type-selector{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.type-btn{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.375rem;padding:1rem;transition:all .2s}.type-btn:hover{background:var(--bg-card-hover);border-color:var(--primary)}.type-btn.active{background:#ffd7001a;border-color:var(--primary)}.type-btn .type-icon{font-size:2rem;line-height:1}.type-btn .type-label{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1rem}.type-btn .type-desc{color:var(--text-light);font-size:.75rem}.type-btn.active .type-label{color:var(--primary)}.club-extended-fields{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1rem;padding:1rem}.club-extended-fields .form-group:last-child{margin-bottom:0}.club-type-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;padding:.25rem .5rem}.club-type-badge--club{background:#ffd70026;color:var(--primary)}.club-type-badge--group{background:#6366f126;color:#818cf8}@media (max-width:768px){.clubs-page{padding:1rem}.clubs-header{flex-direction:column;gap:1rem}.clubs-header__actions{width:100%}.clubs-header__actions .btn-primary,.clubs-header__actions .btn-secondary{flex:1 1}.clubs-grid{grid-template-columns:1fr}}.races-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.races-container{margin:0 auto;max-width:1200px}.races-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.races-header__left h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .25rem}.races-header__left p{color:var(--text-light);margin:0}.races-header__actions .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.races-header__actions .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.races-tabs{background:var(--bg-card);border-radius:10px;display:inline-flex;margin-bottom:1.5rem;padding:4px}.races-tabs .tab{background:#0000;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;font-size:.9375rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.races-tabs .tab:hover:not(.active){color:var(--text)}.races-tabs .tab.active{background:var(--primary);color:#0d0d0d}.races-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:4rem 2rem;text-align:center}.races-empty__icon{font-size:3rem;margin-bottom:1rem}.races-empty h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.races-empty p{color:var(--text-light);margin:0 0 1.5rem}.races-empty .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.races-loading{color:var(--text-light);padding:3rem;text-align:center}.goal-races-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.goal-race-card{background:var(--bg-card);border-left:6px solid var(--border);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem;position:relative}.goal-race-card.primary{border-left-color:var(--primary)}.goal-race-card.past{opacity:.7}.primary-badge{background:#fef3c7;border-radius:20px;color:#92400e;font-size:.75rem;font-weight:600;padding:.25rem .75rem;position:absolute;right:1rem;top:1rem}.goal-race-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.goal-race-card__header h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.distance-badge{background:var(--primary);border-radius:20px;color:#0d0d0d;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.goal-race-card__date{align-items:center;color:var(--text-light);display:flex;font-size:1rem;gap:.75rem;margin-bottom:.75rem}.days-until{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--primary);font-size:.75rem;font-weight:600;padding:.25rem .5rem}.goal-race-card__target{color:var(--text);font-size:.9375rem;margin-bottom:.5rem}.goal-race-card__notes{color:var(--text-light);font-size:.875rem;font-style:italic;margin-bottom:1rem}.goal-race-card__footer{border-top:1px solid var(--border);display:flex;gap:.75rem;padding-top:1rem}.btn-edit{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--primary);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.btn-edit:hover{background:var(--bg-card-hover);border-color:var(--primary)}.btn-delete{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.btn-delete:hover{background:#b91c1c}.results-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.result-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem}.result-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.result-card__header h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.result-card__date{color:var(--text-light);font-size:.875rem;margin-bottom:.75rem}.result-card__time{align-items:center;display:flex;gap:.75rem;margin-bottom:.75rem}.time-value{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem}.position{background:#fef3c7;border-radius:4px;color:#92400e;font-size:.875rem;font-weight:600;padding:.25rem .5rem}.result-card__notes{color:var(--text-light);font-size:.875rem;font-style:italic;margin-bottom:1rem}.result-card__footer{border-top:1px solid var(--border);display:flex;gap:.75rem;padding-top:1rem}@media (max-width:768px){.races-page{padding:1rem}.races-header{flex-direction:column;gap:1rem}.races-header__actions .btn-primary{width:100%}.goal-races-list,.results-list{grid-template-columns:1fr}}.messages-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.messages-container{margin:0 auto;max-width:800px}.messages-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.messages-header h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0}.btn-new-message{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-new-message:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.messages-loading{color:var(--text-light);padding:3rem;text-align:center}.messages-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:4rem 2rem;text-align:center}.messages-empty__icon{margin-bottom:1rem}.messages-empty__icon svg{color:var(--text-light);height:64px;width:64px}.messages-empty h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.messages-empty p{color:var(--text-light);margin:0 0 1.5rem}.messages-empty .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.conversations-list{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;gap:.5rem;overflow:hidden}.conversation-item{align-items:center;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:1rem;padding:1rem 1.25rem;transition:background .2s}.conversation-item:last-child{border-bottom:none}.conversation-item:hover{background:var(--bg-surface)}.conversation-item--unread{background:#ffd7000d}.conversation-item--unread:hover{background:#ffd7001a}.conversation-item__avatar{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:48px;justify-content:center;overflow:hidden;width:48px}.conversation-item__avatar.has-image{background:var(--bg-surface)}.conversation-item__avatar img{height:100%;object-fit:cover;width:100%}.conversation-item__content{flex:1 1;min-width:0}.conversation-item__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem}.conversation-item__name{color:var(--text);font-weight:600}.conversation-item--unread .conversation-item__name{color:var(--primary)}.conversation-item__time{color:var(--text-light);font-size:.75rem}.conversation-item__preview{align-items:center;display:flex;gap:.5rem}.conversation-item__message{color:var(--text-light);flex:1 1;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item__message--empty{font-style:italic}.conversation-item__badge{background:var(--primary);border-radius:10px;color:#0d0d0d;font-size:.75rem;font-weight:700;min-width:20px;padding:.125rem .5rem;text-align:center}.conversation-view{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;height:calc(100vh - 73px - 4rem);overflow:hidden}.conversation-header{align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;gap:1rem;padding:1rem 1.25rem}.conversation-header .back-button{background:none;border:none;color:var(--primary);cursor:pointer;font-size:1rem;padding:0}.conversation-header .back-button:hover{opacity:.8}.conversation-header__avatar{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;overflow:hidden;width:40px}.conversation-header__avatar.has-image{background:var(--bg-surface)}.conversation-header__avatar img{height:100%;object-fit:cover;width:100%}.conversation-header__name{color:var(--text);font-weight:600}.messages-thread{display:flex;flex:1 1;flex-direction:column;gap:.75rem;overflow-y:auto;padding:1rem}.messages-empty-thread{align-items:center;color:var(--text-light);display:flex;flex:1 1;justify-content:center}.message-bubble{display:flex;flex-direction:column;max-width:70%}.message-bubble--sent{align-self:flex-end}.message-bubble--received{align-self:flex-start}.message-bubble__content{word-wrap:break-word;border-radius:16px;line-height:1.4;padding:.75rem 1rem}.message-bubble--sent .message-bubble__content{background:var(--primary);border-bottom-right-radius:4px;color:#0d0d0d}.message-bubble--received .message-bubble__content{background:var(--bg-surface);border-bottom-left-radius:4px;color:var(--text)}.message-bubble__meta{display:flex;gap:.5rem;margin-top:.25rem;padding:0 .5rem}.message-bubble--sent .message-bubble__meta{justify-content:flex-end}.message-bubble__time{color:var(--text-light);font-size:.625rem}.message-bubble__read{color:var(--primary);font-size:.625rem}.message-input-form{background:var(--bg-surface);border-top:1px solid var(--border);display:flex;gap:.75rem;padding:1rem}.message-input{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;color:var(--text);flex:1 1;font-family:inherit;font-size:.9375rem;padding:.75rem 1rem}.message-input:focus{border-color:var(--primary);outline:none}.message-input::placeholder{color:var(--text-light)}.btn-send{align-items:center;background:var(--primary);border:none;border-radius:50%;color:#0d0d0d;cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .2s;width:44px}.btn-send:hover:not(:disabled){transform:scale(1.05)}.btn-send:disabled{cursor:not-allowed;opacity:.5}.btn-send svg{height:20px;width:20px}.selected-user{align-items:center;background:var(--bg-surface);border-radius:8px;display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.selected-user__label{color:var(--text-light);font-size:.875rem}.selected-user__name{color:var(--primary);flex:1 1;font-weight:600}.selected-user__remove{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.25rem;line-height:1;padding:0}.selected-user__remove:hover{color:var(--text)}.search-results{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.search-result-item{align-items:center;background:var(--bg-surface);border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:background .2s}.search-result-item:hover{background:var(--bg-card-hover)}.search-result-avatar{align-items:center;background:var(--border);border-radius:50%;color:var(--text);display:flex;flex-shrink:0;font-weight:600;height:40px;justify-content:center;overflow:hidden;width:40px}.search-result-avatar.has-image{background:var(--bg-surface)}.search-result-avatar img{height:100%;object-fit:cover;width:100%}.search-result-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.search-result-name{color:var(--text);font-weight:600}.search-result-email{color:var(--text-light);font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-empty,.search-loading{color:var(--text-light);padding:1rem;text-align:center}@media (max-width:768px){.messages-page{padding:1rem}.messages-header{align-items:stretch;flex-direction:column;gap:1rem}.messages-header h1{font-size:1.5rem}.conversation-view{height:calc(100vh - 73px - 2rem)}.message-bubble{max-width:85%}.conversation-item{padding:.875rem 1rem}.conversation-item__avatar{height:44px;width:44px}}.workout-templates-test{background:#1a1a2e;bottom:0;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.test-header{align-items:center;background:#1a1a2e;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:10px 0;position:-webkit-sticky;position:sticky;top:0;z-index:10}.test-header h2{color:#fff;margin:0}.filter-buttons{display:flex;gap:8px}.filter-buttons button{background:#2a2a3e;border:1px solid #444;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px}.filter-buttons button.active{background:#6366f1;border-color:#6366f1}.filter-buttons button:hover:not(.active){background:#3a3a4e}.close-btn{background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-left:auto;padding:8px 16px}.error,.loading{color:#fff;padding:40px;text-align:center}.error{color:#ef4444}.templates-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.template-card{background:#2a2a3e;border:1px solid #3a3a4e;border-radius:8px;padding:16px}.template-header{border-bottom:1px solid #3a3a4e;margin-bottom:12px;padding-bottom:12px}.template-header h3{color:#fff;font-size:16px;margin:8px 0 4px}.template-meta{color:#888;font-size:12px}.workout-type{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:2px 8px}.workout-type--R{background:#9333ea33;color:#a78bfa}.workout-type--M{background:#22c55e33;color:#4ade80}.workout-type--T{background:#eab30833;color:#fbbf24}.workout-type--I{background:#ef444433;color:#f87171}.template-steps{display:flex;flex-direction:column;gap:8px}.step-item{align-items:center;background:#1a1a2e;border-radius:4px;display:flex;gap:8px;padding:6px 10px}.step-item.single{border-left:3px solid #0000}.step-display-repeat{background:#6366f11a;border-left:3px solid #6366f1;border-radius:4px;display:flex;gap:8px;padding:8px}.repeat-count{color:#6366f1;font-size:14px;font-weight:700;min-width:30px}.repeat-steps{display:flex;flex:1 1;flex-direction:column;gap:4px}.repeat-steps .step-item{background:#0000;padding:4px 8px}.step-duration{color:#fff;font-weight:500;min-width:60px}.step-pace{border-radius:3px;font-size:13px;padding:2px 6px}.step-pace--easy{background:#22c55e33;color:#4ade80}.step-pace--marathon{background:#22c55e4d;color:#22c55e}.step-pace--threshold{background:#eab30833;color:#fbbf24}.step-pace--interval{background:#ef444433;color:#f87171}.step-pace--repetition{background:#9333ea33;color:#a78bfa}.step-display-set-repeat{background:#f973161a;border-left:4px solid #f97316;border-radius:4px;display:flex;flex-direction:column;gap:8px;padding:10px}.set-count{color:#f97316;font-size:16px;font-weight:700}.set-recovery-label{color:#888;font-size:12px;margin-left:8px}.set-inner-steps{border-left:2px solid #f973164d;display:flex;flex-direction:column;gap:6px;padding-left:8px}.set-inner-steps .step-display-repeat{background:#6366f126}.set-inner-steps .step-item{padding:4px 8px}.App{background:var(--bg);display:flex;flex-direction:column;min-height:100vh}.app-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:16px 24px}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:2rem}.header-right{align-items:center;display:flex;gap:.5rem}.header-logo{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;font-weight:700;margin:0}.header-logo-img{height:40px;width:auto}.header-nav{align-items:center;display:flex;gap:.5rem}.nav-link{background:#0000;border:none;border-radius:6px;color:#fff9;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:500;padding:8px 16px;position:relative;transition:all .2s}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{color:var(--primary);font-weight:600}.nav-link.active:after{background:var(--primary);border-radius:2px;bottom:-4px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:20px}.header-message-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;padding:0;position:relative;transition:all .2s;width:40px}.header-message-btn:hover{border-color:var(--primary);color:var(--primary)}.header-message-btn svg{height:20px;width:20px}.message-badge{background:#dc2626;border-radius:10px;color:#fff;font-size:.625rem;font-weight:700;line-height:1.2;min-width:18px;padding:.125rem .375rem;position:absolute;right:-4px;text-align:center;top:-4px}.profile-menu-container{position:relative}.profile-avatar{align-items:center;background:linear-gradient(135deg,var(--primary) 0,#e6c300 100%);border:2px solid #fff3;border-radius:50%;color:#0d0d0d;cursor:pointer;display:flex;font-family:Archivo Black,sans-serif;font-size:1rem;font-weight:700;height:40px;justify-content:center;transition:all .2s;width:40px}.profile-avatar:hover{border-color:var(--primary);box-shadow:0 4px 12px #ffd7004d;transform:scale(1.05)}.profile-avatar.has-image{overflow:hidden;padding:0}.profile-avatar-img{height:100%;object-fit:cover;width:100%}.profile-menu-backdrop{bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.profile-menu{animation:menuSlideDown .2s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 40px #00000080;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}@keyframes menuSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.profile-menu-header{background:var(--bg-surface);padding:16px}.profile-menu-email{color:var(--text-light);display:block;font-size:.875rem;word-break:break-all}.profile-menu-name{color:var(--secondary);display:block;font-size:1rem;font-weight:600;margin-top:4px}.profile-menu-divider{background:var(--border);height:1px}.profile-menu-item{align-items:center;background:none;border:none;color:var(--text);cursor:pointer;display:flex;font-family:inherit;font-size:.9375rem;gap:12px;padding:12px 16px;text-align:left;transition:all .15s;width:100%}.profile-menu-item:hover{background:var(--bg-card-hover)}.profile-menu-item svg{color:var(--text-light);height:18px;width:18px}.profile-menu-item.logout,.profile-menu-item.logout svg{color:#dc2626}.profile-menu-item.logout:hover{background:#dc262626}.app-main{flex:1 1}.loading-screen{align-items:center;background:var(--bg);color:var(--text);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-logo{height:80px;margin-bottom:2rem;width:auto}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top:3px solid var(--primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.mobile-tab-bar,.mobile-top-bar{display:none}@media (max-width:768px){.mobile-tab-bar{background:var(--bg-card);border-top:1px solid var(--border);bottom:0;display:flex;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;z-index:200}.tab-item{align-items:center;background:none;border:none;color:var(--text-light);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:inherit;font-size:.625rem;font-weight:500;gap:3px;justify-content:center;min-height:56px;padding:8px 4px;position:relative;transition:color .15s}.tab-item.active{color:var(--primary)}.tab-item span{line-height:1}.tab-badge{background:#dc2626;border-radius:10px;color:#fff;font-size:.5625rem;font-weight:700;left:50%;line-height:1.3;margin-left:4px;min-width:16px;padding:1px 4px;position:absolute;text-align:center;top:6px}.app-header{display:none}.mobile-top-bar{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:calc(10px + env(safe-area-inset-top)) 16px 10px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.mobile-top-bar-left,.mobile-top-bar-right{align-items:center;display:flex;gap:8px}.mobile-top-icon{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;display:flex;height:40px;justify-content:center;transition:color .15s;width:40px}.mobile-top-icon.active{color:var(--primary)}.profile-menu--mobile{left:0;right:auto;top:calc(100% + 8px)}.app-main{padding-bottom:calc(64px + env(safe-area-inset-bottom))}}@media (max-width:480px){.header-content{gap:8px}.header-left{gap:.75rem}.header-logo{font-size:1.25rem}.profile-menu{min-width:200px;right:-8px}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .2s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.modal-close{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.5rem;line-height:1;padding:0}.modal-close:hover{color:var(--secondary)}.modal-content form{padding:1.5rem}.modal-error{background:#dc262626;border-radius:8px;color:#f87171;font-size:.875rem;padding:.75rem 1rem}.form-group,.modal-error{margin-bottom:1rem}.form-group label{color:var(--secondary);display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group select option{background:var(--bg-card);color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{resize:vertical}input[type=date]{background:var(--bg-surface);color:var(--text);color-scheme:dark}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7;-webkit-transition:opacity .2s;transition:opacity .2s}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}input[type=date]::-moz-calendar-picker-indicator{filter:invert(1)}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-checkbox label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.form-checkbox input[type=checkbox]{width:auto}.input-with-unit{align-items:center;display:flex;gap:.5rem}.input-with-unit input{flex:1 1}.input-with-unit .unit{color:var(--text-light);font-size:.875rem}.modal-footer{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.btn-cancel,.btn-submit{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel{background:var(--bg-surface);color:var(--text)}.btn-cancel:hover{background:var(--bg-card-hover)}.btn-submit{background:var(--primary);color:#0d0d0d}.btn-submit:hover{box-shadow:0 4px 12px #ffd70066}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.leaderboard-modal{max-width:450px}.leaderboard-challenge{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:1rem 1.5rem}.leaderboard-challenge h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1rem;margin:0 0 .25rem}.leaderboard-challenge p{color:var(--text-light);font-size:.875rem;margin:0}.leaderboard-empty,.leaderboard-loading{color:var(--text-light);padding:2rem;text-align:center}.leaderboard-list{max-height:400px;overflow-y:auto;padding:1rem 1.5rem}.leaderboard-item{align-items:center;border-radius:8px;display:flex;gap:1rem;margin-bottom:.5rem;padding:.75rem}.leaderboard-item:hover{background:var(--bg-card-hover)}.leaderboard-item.completed{background:#10b98126}.leaderboard-rank{font-size:1.125rem;font-weight:700;text-align:center;width:32px}.leaderboard-user{flex:1 1}.leaderboard-name{color:var(--secondary);display:block;font-weight:600;margin-bottom:.25rem}.leaderboard-progress-bar{background:var(--bg-surface);border-radius:2px;height:4px;overflow:hidden}.leaderboard-progress-fill{background:var(--primary);height:100%}.leaderboard-stats{text-align:right}.leaderboard-value{color:var(--secondary);display:block;font-weight:600}.leaderboard-percent{color:var(--text-light);font-size:.75rem}.leaderboard-my-rank{background:#ffd70026;color:var(--primary);font-weight:600;padding:1rem 1.5rem;text-align:center}@media (max-width:480px){.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}
/*# sourceMappingURL=main.76dc0de6.css.map*/