@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px #f0060b33}50%{box-shadow:0 8px 24px #f0060b59}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes milestonePopIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes recordPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes recordTitleGlow{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}@keyframes valuePopIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes badgeSlideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes trophyBounce{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-20px) rotate(-10deg)}50%{transform:translateY(-10px) rotate(10deg)}75%{transform:translateY(-15px) rotate(-5deg)}}.milestone-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;border-radius:16px;font-size:1.5rem;font-weight:700;box-shadow:0 10px 40px #667eea66;z-index:1000;animation:milestonePopIn .5s ease-out;pointer-events:none;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.confetti-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:999;overflow:hidden}.confetti-piece{position:absolute;top:-10%;width:10px;height:10px;background:var(--bright-blue);animation:confetti-fall 3s linear forwards}.confetti-piece:nth-child(2n){background:var(--vivid-pink)}.confetti-piece:nth-child(3n){background:#fbbf24}.confetti-piece:nth-child(5n){background:#4ade80}.back-btn,.back-home-btn{position:absolute;top:1rem;left:1rem;padding:.5rem 1rem;background:#fff;border:2px solid var(--gray-400);border-radius:8px;color:var(--gray-900);text-decoration:none;font-weight:600;font-size:.9rem;transition:all .2s;z-index:10;box-shadow:0 2px 8px #0000001a}.back-btn:hover,.back-home-btn:hover{background:var(--gray-100);border-color:var(--bright-blue);color:var(--bright-blue);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.type-selector{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.type-btn{padding:.6rem 1.2rem;background:#fff;border:2px solid var(--gray-400);border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.4rem}.type-btn:hover{border-color:#a78bfa;background:#a78bfa0d}.type-btn.active{background:linear-gradient(135deg,#a78bfa,#8b5cf6);color:#fff;border-color:#8b5cf6}.type-icon{font-size:1rem;line-height:1;font-weight:700;font-family:Courier New,monospace}.type-label{line-height:1}.primary-btn{background:var(--bright-blue);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:transform .2s}.primary-btn:hover{transform:translateY(-1px)}.secondary-btn{background:#e5e7eb;color:var(--gray-900);border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:transform .2s}.secondary-btn:hover{transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:8px;cursor:pointer;text-decoration:none;font-weight:600;transition:all .3s ease;text-align:center}.btn-primary{background:var(--red-to-pink-to-purple-horizontal-gradient);color:#fff;box-shadow:0 4px 12px #f0060b33}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f0060b4d}.btn-secondary{background:#fff;color:var(--bright-blue);border:2px solid var(--bright-blue)}.btn-secondary:hover{background:var(--bright-blue);color:#fff}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .65rem;border-radius:6px;font-size:.95rem;font-weight:700}.badge-correct{background:#27ae6026;color:#1e8449}.badge-incorrect{background:#c0392b26;color:#a93226}.badge-total{background:#0000000f;color:var(--gray-900)}.type-badge{display:inline-flex;align-items:center;gap:.2rem;padding:.3rem .6rem;border-radius:5px;font-size:.85rem;font-weight:700}.type-correct{background:#27ae601f;color:#1e8449}.type-incorrect{background:#c0392b1f;color:#a93226}.stats-badges{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;justify-content:center}.goal-reached-badge{margin-top:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border-radius:8px;text-align:center;font-weight:600}.personal-best-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:1.5rem;border-radius:12px;text-align:center;margin:1rem 0;box-shadow:0 4px 16px #fbbf2466;animation:badgeSlideIn .5s ease-out .3s backwards;display:flex;flex-direction:column;align-items:center;gap:.5rem}.stats-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:1.5rem;box-shadow:0 6px 20px #0000000f;width:100%;max-width:520px;text-align:center;margin:0 auto 2rem}.stats-card h2{margin-bottom:1rem;color:var(--gray-900)}.stats-by-type{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.08)}.type-stats{display:grid;gap:.75rem}.type-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#00000008;border-radius:8px;transition:background .2s ease}.type-item:hover{background:#0000000f}.type-name{font-weight:600;color:var(--gray-900);font-size:.95rem}.type-badges{display:flex;gap:.5rem}.goal-section{margin-top:1.5rem}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.goal-label{font-weight:600;color:var(--gray-900)}.goal-edit-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;transition:transform .2s}.goal-edit-btn:hover{transform:scale(1.1)}.progress-bar-container{width:100%;height:24px;background:#f0f0f0;border-radius:12px;overflow:hidden;border:2px solid #ddd}.progress-bar-fill{height:100%;background:var(--bright-blue);transition:width .3s ease;border-radius:10px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.results-modal{background:#fff;padding:2rem;border-radius:16px;max-width:500px;width:90%;box-shadow:0 8px 32px #00000026;position:relative;overflow:hidden;animation:modalSlideUp .3s ease-out}.results-modal h2{text-align:center;margin-top:0;color:var(--gray-900);font-size:1.8rem}.results-modal.new-record{border:3px solid #fbbf24;box-shadow:0 8px 32px #fbbf2466,0 0 0 6px #fbbf241a;animation:modalSlideUp .3s ease-out,recordPulse 1.5s ease-in-out .3s}.results-modal.new-record h2{background:linear-gradient(135deg,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:recordTitleGlow 2s ease-in-out infinite}.results-stats{margin:1.5rem 0}.results-actions{display:flex;gap:1rem;margin-top:1.5rem}.results-actions button,.results-actions a{flex:1;padding:.75rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s;font-size:1rem;text-decoration:none;display:flex;align-items:center;justify-content:center}.results-actions button:hover,.results-actions a:hover{transform:translateY(-1px)}.goal-editor-modal{background:#fff;padding:2rem;border-radius:16px;max-width:400px;width:90%;box-shadow:0 4px 20px #00000026}.goal-editor-modal h3{margin-top:0;color:var(--gray-900)}.goal-editor-modal p{color:var(--gray-700);margin-bottom:1rem}.goal-editor-modal input{width:100%;padding:.75rem;font-size:1.2rem;border:2px solid #ddd;border-radius:8px;margin:1rem 0}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-actions button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s}.modal-actions button:hover{transform:translateY(-1px)}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden}div,section,main,article,aside,header,footer,nav{box-sizing:border-box}.home-page,.overview-page,.exercise-container,.achievements-container{overflow-x:hidden;width:100%}:root{--bright-blue: oklch(51.01% .274 263.83deg);--electric-violet: oklch(53.18% .28 296.97deg);--french-violet: oklch(47.66% .246 305.88deg);--vivid-pink: oklch(69.02% .277 332.77deg);--hot-red: oklch(61.42% .238 15.34deg);--orange-red: oklch(63.32% .24 31.68deg);--gray-900: oklch(19.37% .006 300.98deg);--gray-700: oklch(36.98% .014 302.71deg);--gray-400: oklch(70.9% .015 304.04deg);--gray-100: oklch(96% .01 300deg);--red-to-pink-to-purple-vertical-gradient: linear-gradient( 180deg, var(--orange-red) 0%, var(--vivid-pink) 50%, var(--electric-violet) 100% );--red-to-pink-to-purple-horizontal-gradient: linear-gradient( 90deg, var(--orange-red) 0%, var(--vivid-pink) 50%, var(--electric-violet) 100% );font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{width:100%;height:100%}main{min-height:100vh;display:flex;flex-direction:column;position:relative}.home-page{display:flex;flex-direction:column;min-height:100vh}router-outlet{display:contents}app-exercise{display:flex;width:100%;height:100vh}.content-area{flex:1;max-width:1200px;margin:0 auto;width:100%;padding:2rem}.exercises-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.exercise-card{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease;cursor:pointer}.exercise-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--bright-blue)}.exercise-icon{font-size:3rem;margin-bottom:1rem}.exercise-card h3{font-size:1.3rem;color:var(--gray-900);margin-bottom:.5rem}.exercise-card p{color:var(--gray-700);margin-bottom:1.5rem;font-size:.95rem}.exercise-card a{display:inline-block;padding:.6rem 1.2rem;background:color-mix(in srgb,var(--bright-blue) 10%,transparent);color:var(--bright-blue);text-decoration:none;border-radius:6px;font-weight:600;transition:all .3s ease}.exercise-card a:hover{background:var(--bright-blue);color:#fff}footer{background:var(--gray-900);color:#fff;padding:2rem;text-align:center;font-size:.9rem}.hero{display:flex;justify-content:center;align-items:center;padding:3rem 2rem 2rem;background:linear-gradient(135deg,#3382bf0d,#9902100d)}.hero-content{text-align:center;max-width:600px}.hero h1{font-size:3rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem;font-family:Inter Tight,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;line-height:1.2}.hero p{font-size:1rem;color:var(--gray-700);line-height:1.6}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;max-width:900px;margin:0 auto}.action-card{background:#fff;border:2px solid rgba(0,0,0,.1);border-radius:16px;padding:2rem;text-align:center;text-decoration:none;color:var(--gray-900);transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.75rem}.action-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.practice-card:hover{border-color:var(--bright-blue);background:color-mix(in srgb,var(--bright-blue) 5%,white)}.timetrial-card:hover{border-color:#10b981;background:color-mix(in srgb,#10b981 5%,white)}.achievements-card:hover{border-color:#fbbf24;background:color-mix(in srgb,#fbbf24 5%,white)}.card-icon{font-size:3.5rem;line-height:1}.action-card h3{font-size:1.3rem;margin:0;font-weight:700}.action-card p{font-size:.95rem;color:var(--gray-700);margin:0}@media (max-width: 900px){.content-area{padding:1.5rem 1rem}.hero{padding:2rem 1.5rem 1.5rem}.exercises-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}.action-cards{gap:1rem}}@media (max-width: 768px){.hero h1{font-size:2.5rem}.hero p{font-size:.95rem}.cta-buttons{flex-direction:column}.btn{width:100%}.action-cards{grid-template-columns:1fr}}@media (max-width: 600px){.hero h1{font-size:2rem}.hero p{font-size:.9rem}.hero{padding:1.5rem 1rem 1rem}.content-area{padding:.75rem}footer{padding:1rem;font-size:.8rem}.stats-card{padding:.75rem;border-radius:8px;margin-bottom:1.5rem}.stats-card h2{font-size:1rem;margin-bottom:.5rem}.stats-badges{gap:.4rem}.badge{font-size:.8rem;padding:.25rem .5rem}.stats-by-type{margin-top:.75rem;padding-top:.75rem}.type-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem}.type-item{flex-direction:column;gap:.2rem;align-items:center;padding:.4rem;text-align:center}.type-name{font-size:.75rem;width:100%}.type-badges{gap:.3rem;justify-content:center}.type-badge{font-size:.7rem;padding:.2rem .4rem}}
