:root{--bg: #0f1419;--surface: #1a2129;--surface-2: #232c37;--line: #2e3a47;--text: #eef3f8;--muted: #8b97a5;--accent: #4ade80;--accent-dim:#1f3d2b;--blue: #38bdf8;--amber: #fbbf24;--danger: #f87171;--radius: 14px}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased}input,select,button,textarea{font:inherit}.loading{display:grid;place-items:center;min-height:100vh;color:var(--muted)}.muted{color:var(--muted)}.navbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--line)}.navbar-brand{font-weight:700;font-size:1rem;white-space:nowrap}.navbar-links{display:flex;gap:.25rem;flex:1}.navbar-link{padding:.4rem .75rem;border-radius:8px;color:var(--muted);text-decoration:none;font-size:.875rem}.navbar-link:hover,.navbar-link.active{background:var(--surface-2);color:var(--text)}.navbar-logout{margin-left:auto;padding:.4rem .75rem;border-radius:8px;background:none;border:1px solid var(--line);color:var(--muted);cursor:pointer;font-size:.875rem}.navbar-logout:hover{border-color:var(--danger);color:var(--danger)}.main-content{max-width:900px;margin:0 auto;padding:1.5rem 1rem 4rem}.page-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.page-header h2{margin:0;font-size:1.25rem}.page-title{font-size:1.35rem;font-weight:700;margin:0 0 1.5rem}.section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem}.section-title{font-size:1rem;font-weight:600;margin:0 0 1rem}.btn-primary{display:block;width:100%;padding:.875rem 1rem;background:var(--accent);color:#0a1a0f;border:none;border-radius:var(--radius);font-weight:700;font-size:.9375rem;cursor:pointer;margin-top:.75rem}.btn-primary:hover:not(:disabled){filter:brightness(1.1)}.btn-primary:disabled{opacity:.5}.btn-secondary{display:inline-block;padding:.65rem 1.25rem;background:var(--surface-2);color:var(--text);border:1px solid var(--line);border-radius:var(--radius);font-weight:600;cursor:pointer}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:none;border:1px dashed var(--line);color:var(--muted);border-radius:var(--radius);padding:.6rem 1rem;cursor:pointer;width:100%;margin-top:.5rem}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.icon-btn{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.4rem .75rem;color:var(--text);cursor:pointer;font-size:1rem}.icon-btn:hover{border-color:var(--accent)}.icon-btn-sm{background:none;border:1px solid var(--line);border-radius:6px;padding:.2rem .5rem;color:var(--muted);cursor:pointer;font-size:.8rem}.icon-btn-sm:hover{border-color:var(--accent);color:var(--text)}.icon-btn-sm.danger:hover{border-color:var(--danger);color:var(--danger)}.form{display:flex;flex-direction:column;gap:.75rem}.form label{display:flex;flex-direction:column;gap:.3rem;font-size:.875rem;color:var(--muted)}.form input{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.65rem .75rem;color:var(--text)}.form input:focus{outline:none;border-color:var(--accent)}.form-err{color:var(--danger);font-size:.85rem;margin:0}.form-hint{color:var(--muted);font-size:.8rem;text-align:center;margin-top:.25rem}.checkbox-label{flex-direction:row!important;align-items:center;gap:.5rem!important}input,select{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.6rem .75rem;color:var(--text)}input:focus,select:focus{outline:none;border-color:var(--accent)}select option{background:var(--surface-2)}.search-input{width:100%}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:1rem}.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:2rem}.login-title{font-size:1.5rem;font-weight:800;margin:0 0 .25rem;text-align:center}.login-sub{color:var(--muted);font-size:.875rem;text-align:center;margin:0 0 1.5rem}.tab-bar{display:flex;gap:.25rem;background:var(--surface-2);border-radius:10px;padding:.25rem;margin-bottom:1.25rem}.tab-btn{flex:1;padding:.5rem;border:none;border-radius:8px;background:none;color:var(--muted);cursor:pointer;font-size:.875rem}.tab-btn.active{background:var(--bg);color:var(--text);font-weight:600}.week-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.week-label{font-weight:600}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted)}.empty-state p{margin-bottom:1rem}.day-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}.day-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;cursor:pointer;transition:border-color .15s}.day-card:hover,.day-card.today{border-color:var(--accent)}.day-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.day-label{font-weight:700}.location-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:100px}.location-badge.thuis{background:var(--accent-dim);color:var(--accent)}.location-badge.sportschool{background:#103043;color:var(--blue)}.day-exercises{display:flex;flex-wrap:wrap;gap:.25rem}.ex-chip{font-size:.72rem;padding:2px 7px;background:var(--surface-2);border-radius:6px;color:var(--muted)}.plan-actions{text-align:center;margin-top:.5rem}.avail-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.avail-row{display:flex;align-items:center;gap:1rem;padding:.5rem .75rem;border-radius:8px;border:1px solid var(--line)}.avail-row.active{border-color:var(--accent)}.avail-check{display:flex;align-items:center;gap:.5rem;cursor:pointer}.avail-check input{width:16px;height:16px;cursor:pointer}.loc-toggle{display:flex;gap:.25rem;margin-left:auto}.loc-btn{padding:.3rem .65rem;border:1px solid var(--line);border-radius:6px;background:none;color:var(--muted);cursor:pointer;font-size:.8rem}.loc-btn.sel{background:var(--surface-2);color:var(--text);border-color:var(--accent)}.block-weeks-row{display:flex;align-items:center;margin-bottom:.5rem}.block-weeks-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted)}.block-weeks-label .select-input{width:auto;padding:.35rem .5rem;font-size:.85rem}.generate-row{display:flex;gap:.5rem;align-items:stretch;margin-top:.75rem}.generate-row .btn-primary{flex:1;margin-top:0}.generate-row .btn-secondary{flex-shrink:0}.day-plan-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.day-plan-header h3{margin:0;font-size:1rem}.plan-ex-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--line)}.plan-ex-row:last-of-type{border-bottom:none}.plan-ex-name{flex:1;display:flex;flex-direction:column;gap:.1rem}.plan-ex-name strong{font-size:.9rem}.plan-ex-name .muted{font-size:.78rem}.plan-ex-targets{display:flex;gap:.5rem}.plan-ex-targets label{display:flex;flex-direction:column;gap:.15rem;font-size:.72rem;color:var(--muted)}.plan-ex-targets input{width:52px;padding:.3rem .4rem;font-size:.8rem;text-align:center}.plan-ex-actions{display:flex;gap:.25rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:grid;place-items:center;z-index:200;padding:1rem}.modal{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:1.5rem;width:100%;max-width:420px;max-height:80vh;display:flex;flex-direction:column;gap:.75rem}.modal h3{margin:0}.search-results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.search-result-item{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.6rem .75rem;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:.15rem}.search-result-item:hover{border-color:var(--accent)}.search-result-item strong{font-size:.875rem}.search-result-item .muted{font-size:.78rem}.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.filter-bar .search-input{flex:2;min-width:160px}.filter-bar .select-input{flex:1;min-width:120px}.fav-filter-btn{padding:.5rem .875rem;border-radius:8px;border:1px solid var(--line);background:none;color:var(--muted);cursor:pointer;font-size:.85rem;white-space:nowrap}.fav-filter-btn:hover{border-color:var(--danger);color:var(--danger)}.fav-filter-btn.active{border-color:var(--danger);color:var(--danger);background:#f8717114}.ex-list{display:flex;flex-direction:column;gap:.5rem}.ex-item{display:flex;justify-content:space-between;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.875rem 1rem;gap:.5rem}.ex-item-left{display:flex;flex-direction:column;gap:.2rem}.ex-item-left strong{font-size:.9rem}.ex-item-left .muted{font-size:.78rem}.ex-tags{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.2rem}.ex-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem}.ex-meta{font-size:.78rem;color:var(--muted)}.loc-icons{display:flex;gap:.25rem;font-size:.9rem}.ex-item-actions{display:flex;gap:.35rem;align-items:center;margin-top:.1rem}.fav-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--muted);padding:0 .15rem;line-height:1}.fav-btn:hover,.fav-btn.active{color:var(--danger)}.edit-btn{background:none;border:none;cursor:pointer;font-size:.875rem;color:var(--muted);padding:0 .15rem}.edit-btn:hover{color:var(--accent)}.edit-textarea{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.65rem .75rem;color:var(--text);resize:vertical;font:inherit;margin-top:.3rem}.edit-textarea:focus{outline:none;border-color:var(--accent)}.edit-preview{width:100%;max-height:160px;object-fit:contain;background:var(--surface);border-radius:8px;border:1px solid var(--line)}.modal-footer{display:flex;gap:.5rem;align-items:center;margin-top:.25rem}.modal-footer .btn-ghost{flex-shrink:0;width:auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:1.25rem}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;text-align:center}.stat-val{font-size:1.75rem;font-weight:800;color:var(--accent)}.stat-lbl{font-size:.78rem;color:var(--muted);margin-top:.2rem}.user-list{display:flex;flex-direction:column;gap:.5rem}.user-row{display:flex;justify-content:space-between;align-items:center;padding:.65rem .75rem;background:var(--surface-2);border-radius:8px}.user-row div{display:flex;flex-direction:column;gap:.1rem}.user-row-right{flex-direction:row!important;align-items:center;gap:.5rem}.badge{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:100px}.badge.admin{background:var(--accent-dim);color:var(--accent)}.workout-wrap{min-height:100vh;max-width:420px;margin:0 auto;background:var(--bg);display:flex;flex-direction:column;position:relative;overflow:hidden}.wo-header{padding:1rem 1.25rem .875rem;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.wo-title{font-size:1.0625rem;font-weight:700}.wo-sub{font-size:.78rem;color:var(--muted);margin-top:2px}.wo-close{width:38px;height:38px;border-radius:50%;background:var(--surface-2);border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;display:grid;place-items:center}.pbar{display:flex;gap:5px;padding:.875rem 1.25rem .375rem;flex-shrink:0}.pseg{flex:1;height:4px;border-radius:2px;background:var(--surface-2);overflow:hidden}.pseg.done{background:var(--accent)}.pseg.active{position:relative}.pseg.active:after{content:"";display:block;height:100%;width:var(--p,0%);background:var(--accent);transition:width .3s}.wo-body{flex:1;overflow-y:auto;padding:.5rem 1.25rem 8rem}.ex-tag{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);padding:5px 11px;border-radius:100px;margin:1rem 0 .625rem}.ex-tag.cardio{color:var(--blue);background:#103043}.ex-name{font-size:1.75rem;font-weight:800;letter-spacing:-.5px;line-height:1.1;margin:0 0 .375rem}.ex-meta{font-size:.85rem;color:var(--muted);margin:0 0 .5rem}.wo-ex-thumb{width:100%;max-height:240px;object-fit:contain;background:var(--surface);border-radius:12px;margin:.5rem 0 .75rem}.ex-desc{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.6rem .875rem;margin:.5rem 0 .75rem;font-size:.875rem}.ex-desc summary{cursor:pointer;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.3px;-webkit-user-select:none;user-select:none}.ex-desc p{margin:.5rem 0 0;color:var(--text);line-height:1.55}.ex-target{display:flex;gap:1.25rem;margin:1rem 0 .5rem;padding:.875rem 1rem;background:var(--surface);border-radius:12px;border:1px solid var(--line)}.t-lbl{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.t-val{font-size:1.0625rem;font-weight:700;margin-top:2px}.sets-table{margin:1rem 0 0}.sets-h{display:grid;grid-template-columns:32px 1fr 1fr 40px;gap:.5rem;font-size:.75rem;color:var(--muted);padding:0 .25rem .4rem}.set-row{display:grid;grid-template-columns:32px 1fr 1fr 40px;gap:.5rem;align-items:center;padding:.35rem .25rem;border-radius:8px}.set-row.done{opacity:.55}.set-no{font-size:.85rem;color:var(--muted);text-align:center}.set-input{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.5rem .4rem;text-align:center;color:var(--text);font-size:1rem;font-weight:600;-moz-appearance:textfield}.set-input::-webkit-outer-spin-button,.set-input::-webkit-inner-spin-button{-webkit-appearance:none}.set-input:focus{outline:none;border-color:var(--accent)}.set-input:disabled{opacity:.5}.set-check{width:36px;height:36px;border-radius:50%;border:2px solid var(--line);background:none;color:var(--accent);font-size:1rem;cursor:pointer;display:grid;place-items:center}.set-check:not(:disabled):hover{border-color:var(--accent);background:var(--accent-dim)}.set-check:disabled{border-color:var(--accent);color:var(--accent);opacity:.8;cursor:default}.add-set{width:100%;margin-top:.75rem;padding:.6rem;background:none;border:1px dashed var(--line);border-radius:10px;color:var(--muted);cursor:pointer;font-size:.875rem}.add-set:hover{border-color:var(--accent);color:var(--accent)}.cardio-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.5rem;text-align:center;margin-top:1rem}.cardio-lbl{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.cardio-big{font-size:2.5rem;font-weight:800;color:var(--text);margin-top:.25rem}.rest-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f1419f5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;z-index:50}.rest-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.rest-ring-wrap{position:relative;width:220px;height:220px}.rest-ring-wrap svg{position:absolute;top:0;right:0;bottom:0;left:0}.rest-bg{fill:none;stroke:var(--surface-2);stroke-width:10}.rest-fg{fill:none;stroke:var(--accent);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .5s linear}.rest-time{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:2.25rem;font-weight:800;letter-spacing:-.5px}.rest-btns{display:flex;gap:.75rem}.rest-btn{padding:.6rem 1.25rem;border-radius:100px;border:1px solid var(--line);background:none;color:var(--text);cursor:pointer;font-size:.875rem}.rest-btn:hover{border-color:var(--accent)}.rest-btn.skip{background:var(--accent);color:#0a1a0f;border-color:var(--accent);font-weight:600}.wo-footer{position:sticky;bottom:0;display:flex;gap:.75rem;padding:1rem 1.25rem;background:var(--bg);border-top:1px solid var(--line)}.btn-nav{flex:1;padding:.875rem;border-radius:var(--radius);border:1px solid var(--line);background:none;color:var(--text);cursor:pointer;font-size:.9375rem}.btn-nav:disabled{opacity:.35}.btn-nav.next{background:var(--surface-2)}.btn-nav.finish{background:var(--accent);color:#0a1a0f;font-weight:700;border-color:var(--accent)}.done-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center;gap:1rem}.done-check{font-size:4rem}.done-h{font-size:1.75rem;font-weight:800;margin:0}.done-p{color:var(--muted);margin:0}.done-stats{display:flex;gap:2rem;margin:1.5rem 0}.done-stat{display:flex;flex-direction:column;align-items:center;gap:.2rem}.done-stat .v{font-size:1.5rem;font-weight:800;color:var(--accent)}.done-stat .l{font-size:.78rem;color:var(--muted)}.recharts-default-tooltip{background:var(--surface)!important;border:1px solid var(--line)!important}html,body{max-width:100%;overflow-x:hidden}.navbar{flex-wrap:wrap;gap:.5rem 1rem}.navbar-links{flex-wrap:wrap}@media(max-width:600px){.navbar{padding:.625rem .875rem;gap:.5rem}.navbar-brand{flex:1 1 100%;font-size:.9375rem}.navbar-links{flex:1 1 auto;gap:.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.navbar-link{white-space:nowrap;padding:.4rem .6rem}.navbar-logout{margin-left:0;flex-shrink:0}.main-content{padding:1rem .875rem 4rem}.plan-ex-row{flex-wrap:wrap}.plan-ex-targets{gap:.4rem}.done-stats{gap:1.25rem}}.workout-wrap{width:100%}
