.home-page{max-width:1200px;margin:0 auto;padding:3rem 2rem}.home-hero{text-align:center;margin-bottom:4rem}.home-hero h1{font-size:3rem;font-weight:700;color:#e0e0e0;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:1rem}.home-hero .header-icon{width:48px;height:48px;display:block}.home-subtitle{font-size:1.25rem;color:#999;max-width:600px;margin:0 auto}.home-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.home-option-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem 2rem;background:#1a1a1a;text-decoration:none;color:inherit;transition:background-color .2s;border-radius:0}.home-option-card:hover{background:#252525}.home-option-icon{width:80px;height:80px;margin-bottom:1.5rem;object-fit:contain}.home-option-card h2{font-size:1.75rem;font-weight:600;color:#e0e0e0;margin-bottom:1rem}.home-option-card p{font-size:1rem;color:#999;line-height:1.6}.home-actions{text-align:center}.home-submit-button{display:inline-block;padding:1rem 2rem;background:#4a9eff;color:#fff;text-decoration:none;border-radius:0;font-size:1.1rem;font-weight:500;transition:background-color .2s}.home-submit-button:hover{background:#3a8eef}@media (max-width: 768px){.home-hero h1{font-size:2rem}.home-subtitle{font-size:1rem}.home-options{grid-template-columns:1fr}.home-option-card{padding:2rem 1.5rem}}.plan-card-wrapper{position:relative;height:100%}.plan-card{display:flex;flex-direction:column;background:#1a1a1a;border-radius:0;padding:1.5rem;transition:background-color .2s;text-decoration:none;color:inherit;height:100%}.plan-card:hover{background:#252525}.plan-card-header{margin-bottom:.75rem}.plan-card-title{font-size:1.25rem;font-weight:600;color:#e0e0e0;margin:0 0 .5rem}.plan-card-activities{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:.75rem}.plan-card-activity{font-size:.875rem;font-weight:500;color:#999;background:#2a2a2a;padding:.25rem .75rem;border-radius:12px;white-space:nowrap}.plan-card-overview{font-size:.9rem;color:#999;line-height:1.5;margin-bottom:1rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word;overflow-wrap:break-word}.plan-card-stats{display:flex;gap:1.5rem;margin-bottom:1rem;padding-top:1rem;border-top:1px solid #333}.plan-card-stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.plan-card-stat .stat-value{font-size:.9rem;font-weight:600;color:#e0e0e0}.plan-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid #333;gap:1.5rem}.plan-card-tags{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;flex-shrink:1;min-width:0}.plan-card-meta{display:flex;gap:1.5rem;font-size:.875rem;color:#999;align-items:center;flex-wrap:nowrap;flex-shrink:0}.plan-card-views,.plan-card-rating{display:flex;align-items:center;gap:.25rem}.plan-card-rating-empty{color:#666}.plan-card-tag{font-size:.75rem;padding:.25rem .5rem;background:#2a2a2a;color:#4a9eff;border-radius:4px;font-weight:500}.plan-card-delete{position:absolute;top:.75rem;right:.75rem;background:#0009;border:none;border-radius:4px;padding:.5rem;cursor:pointer;font-size:1rem;opacity:.7;transition:opacity .2s,background .2s;z-index:10}.plan-card-delete:hover{opacity:1;background:#dc2626cc}.dual-range-slider{margin-bottom:1.5rem}.dual-range-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.dual-range-slider-label{font-size:.9rem;font-weight:500;color:#e0e0e0}.dual-range-slider-values{font-size:.9rem;color:#1976d2;font-weight:600;background:#1976d21a;padding:.25rem .5rem;border-radius:4px}.dual-range-slider-container{position:relative;height:50px;display:flex;align-items:center;padding:0}.dual-range-slider-input{position:absolute;width:100%;left:0;height:20px;top:50%;transform:translateY(-50%);background:none;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:3;margin:0;padding:0}.dual-range-slider-input::-webkit-slider-thumb{height:20px;width:20px;border-radius:50%;background:#fff;border:3px solid #1976d2;cursor:pointer;pointer-events:all;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-shadow:0 2px 6px #0000004d,0 0 0 4px #1976d21a;transition:all .2s ease;position:relative;margin-top:-7px}.dual-range-slider-input::-webkit-slider-thumb:hover{border-color:#1565c0;box-shadow:0 2px 8px #0006,0 0 0 4px #1976d226;transform:scale(1.15)}.dual-range-slider-input::-webkit-slider-thumb:active{transform:scale(1.1);box-shadow:0 1px 4px #0000004d,0 0 0 4px #1976d233}.dual-range-slider-input::-moz-range-thumb{height:20px;width:20px;border-radius:50%;background:#fff;border:3px solid #1976d2;cursor:pointer;pointer-events:all;-moz-appearance:none;-webkit-appearance:none;appearance:none;box-shadow:0 2px 6px #0000004d,0 0 0 4px #1976d21a;transition:all .2s ease;margin-top:-7px}.dual-range-slider-input::-moz-range-thumb:hover{border-color:#1565c0;box-shadow:0 2px 8px #0006,0 0 0 4px #1976d226;transform:scale(1.15)}.dual-range-slider-input::-moz-range-thumb:active{transform:scale(1.1);box-shadow:0 1px 4px #0000004d,0 0 0 4px #1976d233}.dual-range-slider-input::-webkit-slider-runnable-track{height:6px;background:transparent}.dual-range-slider-input::-moz-range-track{height:6px;background:transparent;border:none}.dual-range-slider-track{position:absolute;width:100%;left:0;height:6px;top:50%;transform:translateY(-50%);background:#333;border-radius:6px;z-index:1}.dual-range-slider-range{position:absolute;height:6px;top:50%;transform:translateY(-50%);background:linear-gradient(90deg,#1976d2,#42a5f5);border-radius:6px;z-index:2;box-shadow:inset 0 1px 2px #ffffff1a;left:0}.filter-panel{background:#1a1a1a;border-radius:0;padding:1.5rem;margin-bottom:2rem}.filter-section{margin-bottom:1.5rem}.filter-section:last-child{margin-bottom:0}.filter-section-header{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:none;padding:0;cursor:pointer;margin-bottom:.75rem}.filter-section-header:hover .filter-section-title{color:#1976d2}.filter-section-title{font-size:1rem;font-weight:600;margin:0;color:#e0e0e0;transition:color .2s}.filter-section-toggle{color:#999;font-size:.8rem;transition:transform .2s,color .2s}.filter-section-header:hover .filter-section-toggle{color:#1976d2}.filter-options{display:flex;flex-direction:column;gap:.5rem}.filter-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;padding:.5rem;border-radius:4px;transition:background-color .2s}.filter-option:hover{background-color:#252525}.filter-option input[type=checkbox],.filter-option input[type=radio]{cursor:pointer;width:20px;height:20px;min-width:20px;min-height:20px;margin:0;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:#1a1a1a;border:2px solid #555;border-radius:4px;position:relative;transition:all .2s}.filter-option input[type=checkbox]:hover,.filter-option input[type=radio]:hover{border-color:#1976d2}.filter-option input[type=checkbox]:checked,.filter-option input[type=radio]:checked{background:#1976d2;border-color:#1976d2}.filter-option input[type=checkbox]:checked:after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.filter-option input[type=checkbox]:disabled,.filter-option input[type=radio]:disabled{cursor:not-allowed;opacity:.5}.filter-option span{-webkit-user-select:none;user-select:none}.filter-clear{width:100%;padding:.75rem;background:#2a2a2a;border:1px solid #333;border-radius:4px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:1rem;color:#e0e0e0}.filter-clear:hover{background:#333}.library-view{width:100%;max-width:100%;overflow-x:hidden}.library-header{margin-bottom:2rem}.library-header h2{font-size:2rem;font-weight:600;margin-bottom:.5rem;color:#e0e0e0}.library-header p{font-size:1rem;color:#999;margin-bottom:1rem}.library-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem}.library-search-input{flex:1;max-width:600px;padding:.75rem 1rem;font-size:1rem;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#e0e0e0;transition:border-color .2s}.library-search-input:focus{outline:none;border-color:#1976d2}.library-search-input::placeholder{color:#666}.library-view-controls{display:flex;align-items:center;gap:.5rem}.library-view-toggle{padding:.5rem;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#999;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.library-view-toggle:hover{border-color:#1976d2;color:#e0e0e0}.library-view-toggle.active{background:#1976d2;border-color:#1976d2;color:#fff}.library-sort-wrapper{position:relative;display:flex;align-items:center}.library-sort-select{padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#e0e0e0;cursor:pointer;transition:border-color .2s;min-width:150px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23999' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.library-sort-select:focus{outline:none;border-color:#1976d2}.library-sort-select option{background:#1a1a1a;color:#e0e0e0}.library-sort-icon{display:none}.library-search-results{text-align:center;padding:1rem;margin-top:1rem}.library-search-count{color:#999;font-size:.9rem}.library-content{display:grid;grid-template-columns:280px 1fr;gap:2rem}.library-sidebar{position:sticky;top:2rem;height:fit-content}.library-main{min-height:400px}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.library-loading,.library-error,.library-empty{text-align:center;padding:3rem;background:#1a1a1a;border-radius:0}.library-error{color:#d32f2f}.library-error button{margin-top:1rem;padding:.5rem 1rem;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.library-error button:hover{background:#1565c0}.library-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;background:#1a1a1a;border-radius:0}.library-pagination button{padding:.5rem 1rem;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.library-pagination button:hover:not(:disabled){background:#1565c0}.library-pagination button:disabled{background:#ccc;cursor:not-allowed}.library-pagination span{font-size:.9rem;color:#999}@media (max-width: 1024px){.library-content{grid-template-columns:1fr}.library-sidebar{position:static}.library-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}.library-list{width:100%;overflow-x:auto}.library-list-table{width:100%;border-collapse:collapse;background:#1a1a1a}.library-list-table thead{background:#252525}.library-list-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.9rem;color:#999;border-bottom:1px solid #333}.library-list-table td{padding:.75rem 1rem;border-bottom:1px solid #252525;color:#e0e0e0;font-size:.9rem}.library-list-row{transition:background-color .2s}.library-list-row:hover{background:#252525}.library-list-name a{color:#1976d2;text-decoration:none;font-weight:500;display:block}.library-list-name a:hover{text-decoration:underline}.library-list-overview{font-size:.85rem;color:#999;margin-top:.25rem;line-height:1.4}.library-list-activity,.library-list-duration,.library-list-volume,.library-list-rating,.library-list-views,.library-list-types{white-space:nowrap}@media (max-width: 768px){.library-header{margin-bottom:1.5rem}.library-header h2{font-size:1.5rem}.library-header p{font-size:.9rem}.library-controls{flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap}.library-search-input{flex:1;min-width:0;max-width:100%;width:100%;order:1}.library-view-controls{display:none}.library-sort-wrapper{position:relative;flex-shrink:0}.library-sort-select{min-width:0;width:40px;height:40px;padding:0;text-indent:-9999px;overflow:hidden;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M3 6h14M6 10h8M9 14h2' stroke='%23999' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:center;background-size:20px 20px;border-color:#333}.library-sort-select:focus,.library-sort-select:hover{border-color:#1976d2;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M3 6h14M6 10h8M9 14h2' stroke='%231976d2' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E")}.library-sort-icon{display:none}.library-content{gap:1.5rem}.library-grid{grid-template-columns:1fr}.library-list-table{font-size:.75rem}.library-list-table th,.library-list-table td{padding:.5rem .25rem}.library-list-table th:nth-child(n+3),.library-list-table td:nth-child(n+3){display:none}.library-list-table th:nth-child(1),.library-list-table td:nth-child(1),.library-list-table th:nth-child(2),.library-list-table td:nth-child(2){display:table-cell}}@media (max-width: 480px){.library-list-table{font-size:.7rem}.library-list-table th,.library-list-table td{padding:.4rem .2rem}}.workout-calendar{margin-top:2rem}.workout-calendar h2{color:#e0e0e0;margin-bottom:1.5rem;font-size:1.5rem}.calendar-weeks{display:flex;flex-direction:column;gap:2rem}.calendar-week{background:#1a1a1a;border-radius:0;padding:1.5rem}.week-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #333}.week-header h3{color:#e0e0e0;margin:0;font-size:1.25rem}.week-days-range{color:#999;font-size:.875rem}.week-days{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.calendar-day{background:#252525;border-radius:0;padding:1rem;border-left:3px solid #4a9eff}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #333}.day-name{font-weight:600;color:#4a9eff;font-size:1rem}.day-number{color:#999;font-size:.875rem}.day-workouts{display:flex;flex-direction:column;gap:.75rem}.day-workout-card{background:#1f1f1f;border-radius:0;padding:.75rem;border:1px solid #333}.workout-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.workout-name{font-weight:500;color:#e0e0e0;font-size:.95rem}.workout-activity{background:#333;color:#999;padding:.25rem .5rem;border-radius:0;font-size:.75rem}.workout-metric{display:flex;gap:.5rem;margin-top:.25rem;font-size:.875rem}.metric-label{color:#666}.metric-value{color:#999}.workout-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.workout-tag{background:#2a2a2a;color:#4a9eff;padding:.25rem .5rem;border-radius:0;font-size:.75rem}.plan-detail{max-width:900px;margin:0 auto}.plan-detail-back{display:inline-block;margin-bottom:1.5rem;color:#4a9eff;text-decoration:none;font-weight:500;transition:opacity .2s}.plan-detail-back:hover{opacity:.8}.plan-detail-loading,.plan-detail-error{text-align:center;padding:3rem;background:#1a1a1a;border-radius:0}.plan-detail-error{color:#d32f2f}.plan-detail-error a{display:inline-block;margin-top:1rem;color:#4a9eff;text-decoration:none}.plan-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:#1a1a1a;border-radius:0}.plan-detail-header h1{font-size:2rem;font-weight:600;margin-bottom:1rem;color:#e0e0e0}.plan-detail-meta{display:flex;gap:1rem;flex-wrap:wrap}.plan-detail-activities{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.plan-detail-activity,.plan-detail-difficulty,.plan-detail-duration{font-size:.875rem;padding:.5rem 1rem;border-radius:20px;font-weight:500}.plan-detail-activity{background:#2a2a2a;color:#4a9eff}.plan-detail-difficulty{background:#2a2a2a;color:#b794f6}.plan-detail-duration{background:#2a2a2a;color:#68d391}.plan-detail-coros-button{padding:.75rem 1.5rem;background:#4a9eff;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.plan-detail-coros-button:hover{background:#3a8eef}.plan-detail-section{margin-bottom:2rem;padding:2rem;background:#1a1a1a;border-radius:0}.plan-detail-section h2{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#e0e0e0}.plan-detail-section p{line-height:1.6;color:#999;word-break:break-word;overflow-wrap:break-word}.plan-detail-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.plan-detail-stat{display:flex;flex-direction:column;padding:1.5rem;background:#1a1a1a;border-radius:0}.plan-detail-stat .stat-label{font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.plan-detail-stat .stat-value{font-size:1.5rem;font-weight:600;color:#e0e0e0}.plan-detail-tags{display:flex;flex-wrap:wrap;gap:.5rem}.plan-detail-tag{font-size:.875rem;padding:.5rem 1rem;background:#2a2a2a;color:#4a9eff;border-radius:20px;font-weight:500}.plan-detail-workouts{display:flex;flex-direction:column;gap:1rem}.plan-detail-workout{padding:1rem;background:#252525;border-radius:6px;border-left:3px solid #4a9eff}.workout-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.workout-header h3{font-size:1rem;font-weight:600;color:#e0e0e0}.workout-activity{font-size:.75rem;padding:.25rem .75rem;background:#2a2a2a;border-radius:12px;color:#999}.workout-tags{display:flex;gap:.5rem;flex-wrap:wrap}.workout-tag{font-size:.75rem;padding:.25rem .5rem;background:#2a2a2a;color:#4a9eff;border-radius:4px}.workout-more{text-align:center;color:#999;font-style:italic;margin-top:.5rem}.workout-meta{margin-top:.5rem;font-size:.875rem;color:#999}.workout-exercises{margin-top:1rem;padding-top:1rem;border-top:1px solid #333}.workout-exercises h4{color:#e0e0e0;font-size:1rem;margin-bottom:.75rem}.exercise-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.exercise-item{padding:.75rem;background:#2a2a2a;border-left:3px solid #4a9eff;border-radius:0}.exercise-item.exercise-warmup{border-left-color:#ff9800}.exercise-item.exercise-cooldown{border-left-color:#2196f3}.exercise-item.exercise-rest{border-left-color:#9e9e9e;background:#1f1f1f}.exercise-item.exercise-training{border-left-color:#4caf50}.exercise-repeat-header{padding:.75rem;background:#2a2a2a;border-left:3px solid #666;border-radius:0;margin-top:1rem;margin-bottom:.5rem}.exercise-repeat-label{font-weight:600;color:#999;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.exercise-repeat-container{list-style:none;margin:0;padding:0;margin-bottom:1rem}.exercise-repeat-box{background:#252525;border:2px solid #4a9eff;border-radius:0;padding:1rem;margin-left:0}.exercise-repeat-list{list-style:none;margin:0;padding:0}.exercise-repeat-list .exercise-item{margin-bottom:.75rem}.exercise-repeat-list .exercise-item:last-child{margin-bottom:0}.exercise-repeat-item{margin-left:1.5rem;border-left:2px solid #333;padding-left:.5rem}.exercise-name{font-weight:600;color:#e0e0e0;margin-bottom:.25rem}.exercise-intensity{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #333;display:flex;flex-direction:column;gap:.25rem;font-size:.875rem}.intensity-type{color:#4a9eff;font-weight:500}.intensity-zone{color:#e0e0e0;font-weight:600;font-size:.9rem}.intensity-value{color:#999}.exercise-overview{font-size:.875rem;color:#999;margin-top:.25rem}.exercise-target,.exercise-sets{font-size:.875rem;color:#4a9eff;margin-top:.25rem}.plan-detail-rating-form{display:flex;flex-direction:column;gap:1rem}.rating-stars{display:flex;gap:.5rem}.rating-star{font-size:2rem;background:none;border:none;cursor:pointer;padding:0;opacity:.3;transition:opacity .2s,transform .2s}.rating-star:hover,.rating-star.hover{opacity:.6;transform:scale(1.1)}.rating-star.active,.rating-star.active.hover{opacity:1}.no-ratings{color:#666;font-style:italic}.rating-comment{width:100%;padding:.75rem;border:1px solid #333;border-radius:4px;font-family:inherit;font-size:.9rem;resize:vertical;background:#252525;color:#e0e0e0}.rating-submit{padding:.75rem 1.5rem;background:#4a9eff;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;align-self:flex-start}.rating-submit:hover:not(:disabled){background:#3a8eef}.rating-submit:disabled{background:#ccc;cursor:not-allowed}.plan-detail-ratings{display:flex;flex-direction:column;gap:1rem}.plan-detail-rating-item{padding:1rem;background:#252525;border-radius:6px}.rating-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.rating-item-stars{font-size:1.2rem}.rating-item-date{font-size:.875rem;color:#999}.rating-item-comment{color:#999;line-height:1.5}@media (max-width: 768px){.plan-detail-header{flex-direction:column;gap:1rem}.plan-detail-coros-button{width:100%}.plan-detail-stats{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#1a1a1a;border-radius:0;padding:2rem;max-width:500px;width:90%;color:#e0e0e0}.modal-content h2{margin:0 0 1rem;color:#e0e0e0}.modal-description{color:#999;margin-bottom:1.5rem;font-size:.9rem}.modal-field{margin-bottom:1.5rem}.modal-field label{display:block;margin-bottom:.5rem;color:#e0e0e0;font-weight:500}.modal-field input{width:100%;padding:.75rem;background:#252525;border:1px solid #333;border-radius:0;color:#e0e0e0;font-size:1rem;font-family:inherit}.modal-field input:focus{outline:none;border-color:#4a9eff}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-button{padding:.75rem 1.5rem;border:none;border-radius:0;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.modal-button-cancel{background:#333;color:#e0e0e0}.modal-button-cancel:hover{background:#444}.modal-button-confirm{background:#4a9eff;color:#fff}.modal-button-confirm:hover:not(:disabled){background:#3a8ee0}.modal-button-confirm:disabled{background:#333;color:#666;cursor:not-allowed}.submit-plan{max-width:700px;margin:0 auto}.submit-plan-container{background:#1a1a1a;border-radius:0;padding:2rem}.submit-plan h1{font-size:2rem;font-weight:600;margin-bottom:.5rem;color:#e0e0e0}.submit-plan-description{font-size:1rem;color:#999;margin-bottom:2rem}.submit-plan-form{display:flex;flex-direction:column;gap:1.5rem}.submit-plan-field{display:flex;flex-direction:column;gap:.5rem}.submit-plan-field label{font-size:.9rem;font-weight:500;color:#e0e0e0}.submit-plan-field input{padding:.75rem;border:1px solid #333;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s;background:#252525;color:#e0e0e0}.submit-plan-field input:focus{outline:none;border-color:#4a9eff}.submit-plan-field input:disabled{background:#2a2a2a;cursor:not-allowed}.submit-plan-hint{font-size:.875rem;color:#999;font-style:italic}.submit-plan-error{padding:1rem;background:#3a1a1a;color:#ff6b6b;border-radius:4px;border-left:3px solid #ff6b6b}.submit-plan-button{padding:.75rem 1.5rem;background:#4a9eff;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;align-self:flex-start}.submit-plan-button:hover:not(:disabled){background:#3a8eef}.submit-plan-button:disabled{background:#ccc;cursor:not-allowed}.submit-plan-info{margin-top:3rem;padding-top:2rem;border-top:1px solid #333}.submit-plan-info h2{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:#e0e0e0}.submit-plan-info ol{margin-left:1.5rem;margin-bottom:1rem;line-height:1.8;color:#999}.submit-plan-note{padding:1rem;background:#2a2a2a;color:#4a9eff;border-radius:4px;font-size:.9rem;line-height:1.6}.admin-portal{max-width:1400px;margin:0 auto;padding:2rem}.admin-login{max-width:400px;margin:4rem auto;background:#1a1a1a;padding:2rem;border-radius:0}.admin-login h1{color:#e0e0e0;margin-bottom:.5rem}.admin-login p{color:#999;margin-bottom:1.5rem;font-size:.9rem}.admin-login-field{margin-bottom:1.5rem}.admin-login-field label{display:block;color:#e0e0e0;margin-bottom:.5rem;font-weight:500}.admin-login-field input{width:100%;padding:.75rem;background:#252525;border:1px solid #333;border-radius:0;color:#e0e0e0;font-size:1rem;font-family:inherit}.admin-login-field input:focus{outline:none;border-color:#4a9eff}.admin-login-field input:disabled{background:#333;color:#666;cursor:not-allowed}.admin-login-button{width:100%;padding:.75rem;background:#4a9eff;color:#fff;border:none;border-radius:0;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.admin-login-button:hover:not(:disabled){background:#3a8ee0}.admin-login-button:disabled{background:#333;color:#666;cursor:not-allowed}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #333}.admin-header h1{color:#e0e0e0;margin:0}.admin-logout-button{padding:.5rem 1rem;background:#2a2a2a;color:#e0e0e0;border:1px solid #333;border-radius:0;cursor:pointer;font-size:.875rem;transition:background-color .2s}.admin-logout-button:hover{background:#333}.admin-loading,.admin-error{background:#1a1a1a;padding:1.5rem;border-radius:0;margin-bottom:2rem;text-align:center}.admin-loading{color:#999}.admin-error{background:#4a1c1c;color:#ff8a80;border-left:3px solid #d32f2f}.admin-stats{background:#1a1a1a;padding:1.5rem;border-radius:0;margin-bottom:2rem}.admin-stats h2{color:#e0e0e0;margin-bottom:1.5rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.admin-stat-card{background:#252525;padding:1.5rem;border-radius:0;border-left:3px solid #4a9eff}.stat-value{font-size:2rem;font-weight:700;color:#4a9eff;margin-bottom:.5rem}.stat-label{color:#999;font-size:.875rem}.admin-stats-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.stats-section h3{color:#e0e0e0;margin-bottom:1rem;font-size:1rem}.stats-section ul{list-style:none;padding:0;margin:0}.stats-section li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #333;color:#999}.stat-type{color:#e0e0e0}.stat-count{color:#4a9eff;font-weight:600}.admin-plans{background:#1a1a1a;padding:1.5rem;border-radius:0}.admin-plans-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.admin-plans-header h2{color:#e0e0e0;margin:0}.admin-refresh-button{padding:.5rem 1rem;background:#2a2a2a;color:#e0e0e0;border:1px solid #333;border-radius:0;cursor:pointer;font-size:.875rem;transition:background-color .2s}.admin-refresh-button:hover{background:#333}.admin-plans-table{overflow-x:auto}.admin-plans-table table{width:100%;border-collapse:collapse}.admin-plans-table thead{background:#252525}.admin-plans-table th{padding:.75rem;text-align:left;color:#e0e0e0;font-weight:600;font-size:.875rem;text-transform:uppercase;border-bottom:2px solid #333}.admin-plans-table td{padding:.75rem;color:#999;border-bottom:1px solid #333}.admin-plans-table tbody tr:hover{background:#252525}.plan-name-cell a{color:#4a9eff;text-decoration:none}.plan-name-cell a:hover{text-decoration:underline}.admin-delete-button{padding:.5rem 1rem;background:#4a1c1c;color:#ff8a80;border:1px solid #d32f2f;border-radius:0;cursor:pointer;font-size:.875rem;transition:background-color .2s}.admin-delete-button:hover:not(:disabled){background:#5a2c2c}.admin-delete-button:disabled{opacity:.5;cursor:not-allowed}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#1a1a1a;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.app-header h1{font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.header-icon{width:32px;height:32px;display:block}.app-header nav{display:flex;gap:1.5rem}.app-header nav a{color:#fff;text-decoration:none;font-weight:500;transition:opacity .2s}.app-header nav a:hover{opacity:.8}.app-main{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}.app-footer{background-color:#1a1a1a;border-top:1px solid #333;padding:1.5rem 2rem;text-align:center;margin-top:auto}.app-footer p{margin:0;color:#999;font-size:.875rem}@media (max-width: 768px){.app-header{flex-direction:column;gap:1rem;padding:1rem}.app-main,.app-footer{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0f0f0f;color:#e0e0e0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
