:root{--primary:#0d47a1;--primary-hover:#1565c0;--secondary:#1e88e5;--accent:#00bfa5;--warning:#ff6d00;--error:#d32f2f;--bg-light:#fafbfc;--bg-dark:#0a1628;--text-dark:#1a1a2e;--text-gray:#6b7280;--border:#e5e7eb;--font-mono:"JetBrains Mono", monospace;--font-sans:"Inter", -apple-system, sans-serif;--font-code:"Fira Code", monospace;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-card:0 2px 8px #00000014;--shadow-hover:0 4px 16px #0000001f}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg-light);color:var(--text-dark);min-height:100vh;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--secondary);text-decoration:none}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none}.container{max-width:1200px;margin:0 auto;padding:0 24px}.btn{border-radius:var(--radius-md);justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{color:var(--secondary);border:2px solid var(--secondary);background:#fff}.btn-secondary:hover{background:#e3f2fd}.btn-success{background:var(--accent);color:#fff}.btn-success:hover{background:#00a695}.card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);background:#fff;padding:24px;transition:all .2s}.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.input{border-radius:var(--radius-md);border:1px solid #d1d5db;width:100%;padding:12px 16px;font-size:1rem;transition:all .2s}.input:focus{border-color:var(--secondary);outline:none;box-shadow:0 0 0 3px #1e88e533}.progress-bar{background:var(--border);border-radius:var(--radius-sm);height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent), var(--secondary));border-radius:var(--radius-sm);height:100%;transition:width .3s}.badge{border-radius:999px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}h1{font-size:2.5rem;font-weight:700}h2{font-size:1.75rem;font-weight:600}h3{font-size:1.25rem;font-weight:600}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.mt-xl{margin-top:32px}.text-gray{color:var(--text-gray)}.text-center{text-align:center}.navbar{z-index:100;border-bottom:1px solid var(--border);background:#fff;height:64px;position:sticky;top:0}.navbar-container{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 24px;display:flex}.navbar-logo{color:var(--primary);align-items:center;gap:8px;font-size:1.25rem;font-weight:700;display:flex}.navbar-links{gap:32px;display:flex}.navbar-links a{color:var(--text-gray);padding:8px 0;font-weight:500;transition:color .2s;position:relative}.navbar-links a:hover,.navbar-links a.active{color:var(--primary)}.navbar-links a.active:after{content:"";background:var(--primary);height:2px;position:absolute;bottom:0;left:0;right:0}.navbar-actions .user-menu{border-radius:var(--radius-md);color:var(--text-dark);align-items:center;gap:8px;padding:8px 12px;text-decoration:none;transition:background .2s;display:flex}.navbar-actions .user-menu:hover{background:var(--bg-light)}.navbar-actions .user-avatar-small{background:var(--primary);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.navbar-actions .user-avatar-small img{object-fit:cover;width:100%;height:100%}.navbar-actions .avatar-placeholder-small{color:#fff;font-size:.875rem;font-weight:600}.navbar-actions .user-name{font-size:.875rem;font-weight:500}.navbar-actions{gap:12px;display:flex}.home{flex-direction:column;min-height:100vh;display:flex}.hero{background:linear-gradient(135deg, var(--bg-dark) 0%, #1a365d 100%);color:#fff;text-align:center;padding:80px 0}.hero-content{max-width:800px;margin:0 auto}.hero h1{margin-bottom:16px;font-size:2.5rem}.hero-subtitle{color:#fffc;margin-bottom:32px;font-size:1.125rem;line-height:1.8}.hero-actions{justify-content:center;gap:16px;display:flex}.hero-actions .btn-primary{background:var(--accent)}.hero-actions .btn-primary:hover{background:#00a695}.quick-stats{border-bottom:1px solid var(--border);background:#fff;padding:32px 0}.stats-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.stat-card{text-align:center;padding:16px}.stat-card .stat-icon{margin-bottom:8px;font-size:2rem;display:block}.stat-card .stat-value{color:var(--primary);font-size:1.5rem;font-weight:700;display:block}.stat-card .stat-label{color:var(--text-gray);font-size:.875rem}.features-overview{background:var(--bg-light);padding:48px 0}.features-overview h2{text-align:center;margin-bottom:24px}.features-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.feature-card{text-align:center;color:inherit;text-decoration:none;transition:all .2s;display:block}.feature-card .feature-icon{margin-bottom:16px;font-size:2.5rem}.feature-card h3{margin-bottom:8px}.feature-badge{color:var(--secondary);background:#e3f2fd;border-radius:999px;margin-top:12px;padding:4px 12px;font-size:.75rem;display:inline-block}.recent-resources{background:#fff;padding:48px 0}.section-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.see-more{color:var(--secondary);font-weight:500}.resources-preview{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.resource-preview{color:inherit;padding:16px;text-decoration:none;transition:all .2s;display:block}.resource-source-badge{color:var(--secondary);background:#e3f2fd;border-radius:999px;margin-bottom:8px;padding:2px 8px;font-size:.75rem;display:inline-block}.resource-preview h3{margin-bottom:4px;font-size:1rem}.resource-preview p{font-size:.875rem}.top-skills{background:var(--bg-light);padding:48px 0}.skills-preview{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.skill-preview{align-items:flex-start;gap:16px;display:flex}.skill-rank-badge{color:#fff;background:linear-gradient(135deg,gold,orange);border-radius:50%;justify-content:center;align-items:center;min-width:40px;height:40px;font-size:.875rem;font-weight:700;display:flex}.skill-info{flex:1}.skill-info h3{margin-bottom:4px;font-size:1rem}.skill-info p{font-size:.875rem}.skill-mini-stats{gap:12px;margin-top:8px;font-size:.875rem;display:flex}.skill-mini-stats .trend{color:#2e7d32}.footer{background:var(--bg-dark);color:#fff9;text-align:center;margin-top:auto;padding:24px 0}.footer p{margin:4px 0}@media (width<=768px){.stats-grid,.features-grid,.resources-preview,.skills-preview{grid-template-columns:1fr}.hero h1{font-size:1.75rem}.hero-actions{flex-direction:column;align-items:center}}.resources-page{flex-direction:column;min-height:100vh;display:flex}.resources-main{flex:1;padding:48px 0}.resources-header{margin-bottom:32px}.resources-header h1{margin-bottom:8px}.resources-filters{border-radius:var(--radius-lg);border:1px solid var(--border);background:#fff;flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:16px;display:flex}.filter-buttons{flex-wrap:wrap;gap:8px;display:flex}.filter-btn{border:1px solid var(--border);color:var(--text-gray);background:#fff;border-radius:999px;padding:6px 12px;font-size:.875rem;transition:all .2s}.resources-stats{color:var(--text-gray);justify-content:space-between;margin-bottom:16px;font-size:.875rem;display:flex}.resources-list{gap:16px;display:grid}.resource-card{transition:all .2s}.resource-date{color:var(--text-gray);font-size:.75rem}.resource-title{margin-bottom:8px}.resource-tags{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tag{color:var(--secondary);background:#e3f2fd;border-radius:999px;padding:2px 8px;font-size:.75rem}.resource-stats{color:var(--text-gray);gap:16px;font-size:.875rem;display:flex}.resource-actions{gap:8px;display:flex}@media (width<=768px){.resources-filters{flex-direction:column}.filter-group{flex-direction:column;align-items:flex-start}.resource-footer{flex-direction:column;align-items:flex-start;gap:12px}}.course-sets-page{flex-direction:column;min-height:100vh;display:flex}.course-sets-main{flex:1;padding:48px 0}.course-sets-header{margin-bottom:32px}.course-sets-header h1{margin-bottom:8px}.course-sets-filters{flex-wrap:wrap;gap:12px;margin-bottom:32px;display:flex}.course-sets-list{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;display:grid}.course-set-card{flex-direction:column;display:flex}.course-set-category{color:var(--secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.course-set-info h3{margin:4px 0}.course-set-courses{background:var(--bg-light);border-radius:var(--radius-md);margin-bottom:16px;padding:12px}.course-set-actions{gap:12px;margin-top:auto;display:flex}.course-set-actions .btn{flex:1;padding:10px 16px;font-size:.875rem}@media (width<=768px){.course-sets-list{grid-template-columns:1fr}.course-set-actions{flex-direction:column}}.skills-page{flex-direction:column;min-height:100vh;display:flex}.skills-main{flex:1;padding:48px 0}.skills-header{margin-bottom:32px}.skills-header h1{margin-bottom:8px}.skills-filters{border-radius:var(--radius-lg);border:1px solid var(--border);background:#fff;gap:24px;margin-bottom:24px;padding:16px;display:flex}.filter-group{align-items:center;gap:12px;display:flex}.filter-label{color:var(--text-gray);font-weight:500}.skills-stats{color:var(--text-gray);justify-content:space-between;margin-bottom:16px;font-size:.875rem;display:flex}.skills-list{flex-direction:column;gap:16px;display:flex}.skill-card{align-items:flex-start;gap:24px;padding:24px;display:flex}.skill-rank{min-width:60px}.rank-badge{background:var(--bg-light);width:40px;height:40px;color:var(--text-gray);border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;font-weight:600;display:inline-flex}.rank-badge.top3{color:#fff;background:linear-gradient(135deg,gold,orange)}.skill-main{flex:1}.skill-header{align-items:baseline;gap:12px;margin-bottom:8px;display:flex}.skill-name{font-size:1.125rem}.skill-name a{color:var(--text-dark);text-decoration:none}.skill-name a:hover{color:var(--primary)}.skill-author{color:var(--text-gray);font-size:.875rem}.skill-desc{color:var(--text-gray);margin-bottom:16px;font-size:.875rem;line-height:1.6}.skill-stats{gap:32px;margin-bottom:16px;display:flex}.stat-item{flex-direction:column;align-items:center;gap:4px;display:flex}.stat-icon{font-size:1.25rem}.stat-value{font-size:1.125rem;font-weight:600}.stat-item.trend .stat-value.positive{color:#2e7d32}.stat-item.trend .stat-value.negative{color:#c62828}.skill-meta{gap:16px;font-size:.875rem;display:flex}.skill-category{color:var(--secondary);background:#e3f2fd;border-radius:999px;padding:2px 8px}.skill-update{color:var(--text-gray)}.skill-actions{min-width:120px}.skill-actions .btn{width:100%}@media (width<=768px){.skill-card{flex-direction:column}.skill-rank{align-self:flex-start}.skill-stats{flex-wrap:wrap;gap:16px}.skill-actions{width:100%}}.learning{flex-direction:column;min-height:100vh;display:flex}.learning-main{flex:1;padding:48px 0}.learning-header{margin-bottom:32px}.learning-header h1{margin-bottom:8px}.category-filter{flex-wrap:wrap;gap:12px;margin-bottom:32px;display:flex}.filter-btn{border:1px solid var(--border);color:var(--text-gray);background:#fff;border-radius:999px;padding:8px 20px;font-weight:500;transition:all .2s}.filter-btn:hover{border-color:var(--secondary);color:var(--secondary)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.courses-list{flex-direction:column;gap:16px;display:flex}.course-item{color:inherit;justify-content:space-between;align-items:center;text-decoration:none;display:flex}.course-item-left{align-items:center;gap:16px;display:flex}.course-icon{font-size:2rem}.course-info h3{margin-bottom:4px}.course-info p{color:var(--text-gray);font-size:.875rem}.course-item-right{align-items:center;gap:16px;display:flex}.course-duration{color:var(--text-gray);font-size:.875rem}.course-status{color:var(--secondary);background:#e3f2fd;border-radius:999px;padding:4px 12px;font-size:.75rem;font-weight:600}.course-detail{flex-direction:column;min-height:100vh;display:flex}.course-detail-main{flex:1;padding:24px 0 48px}.course-detail-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;display:flex}.course-tag{color:var(--secondary);margin-bottom:8px;font-size:.875rem;display:inline-block}.course-detail-header h1{margin-bottom:8px}.course-content{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff;padding:32px}.markdown-content{line-height:1.8}.markdown-content h1{border-bottom:1px solid var(--border);margin:32px 0 16px;padding-bottom:8px;font-size:1.75rem}.markdown-content h2{margin:24px 0 12px;font-size:1.375rem}.markdown-content h3{margin:20px 0 8px;font-size:1.125rem}.markdown-content p{margin:12px 0}.markdown-content li{margin:8px 0 8px 24px}.markdown-content code{font-family:var(--font-code);background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:.875em}.markdown-content pre{color:#e2e8f0;border-radius:var(--radius-md);background:#1e293b;margin:16px 0;padding:16px;overflow-x:auto}.markdown-content pre code{color:inherit;background:0 0;padding:0}.course-nav{border-top:1px solid var(--border);justify-content:space-between;margin-top:32px;padding-top:24px;display:flex}.evaluation{flex-direction:column;min-height:100vh;display:flex}.evaluation-main{flex:1;padding:48px 0}.evaluation-header{text-align:center;margin-bottom:32px}.evaluation-header h1{margin-bottom:8px}.evaluation-form{max-width:700px;margin:0 auto 32px}.evaluation-form label{margin-bottom:8px;font-weight:500;display:block}.input-group{gap:12px;display:flex}.input-group .input{flex:1}.evaluation-result{max-width:700px;margin:0 auto 32px}.evaluation-result h2{margin-bottom:24px}.result-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px;display:grid}.result-item{text-align:center;background:var(--bg-light);border-radius:var(--radius-md);padding:16px}.result-label{color:var(--text-gray);margin-bottom:8px;font-size:.875rem;display:block}.result-value{font-size:1.25rem;font-weight:600}.result-value.success{color:var(--accent)}.result-value.warning{color:var(--warning)}.result-value.score{color:var(--primary)}.result-issues{border-top:1px solid var(--border);padding-top:16px}.result-issues h3{margin-bottom:12px;font-size:1rem}.result-issues ul{margin-left:20px}.result-issues li{color:var(--warning);margin:8px 0}.result-note{text-align:center;margin-top:16px;font-size:.875rem}.evaluation-info{max-width:700px;margin:0 auto}.info-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.info-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;padding:16px}.info-card h4{margin-bottom:4px}.info-card p{font-size:.875rem}@media (width<=768px){.auth-required{text-align:center;max-width:500px;margin:0 auto 32px;padding:48px}.auth-icon{margin-bottom:16px;font-size:3rem}.auth-required h3{margin-bottom:8px}.auth-required .btn{margin-top:16px}.evaluation-note{text-align:center;margin-top:16px}.result-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.result-info h3{margin-bottom:4px}.result-pending{text-align:center;padding:32px}.pending-animation{flex-direction:column;align-items:center;gap:16px;display:flex}.spinner{border:4px solid var(--border);border-top-color:var(--secondary);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.result-content{margin-top:16px}.result-details{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px;display:grid}.detail-section{background:var(--bg-light);border-radius:var(--radius-md);padding:16px}.detail-section h4{margin-bottom:12px;font-size:.875rem}.detail-list{margin-left:20px}.detail-list li{color:var(--text-gray);margin:8px 0;font-size:.875rem}.result-actions{text-align:center;margin-top:24px}.result-value.error{color:var(--error)}.result-grid,.info-grid{grid-template-columns:1fr}}.user-page{flex-direction:column;min-height:100vh;display:flex}.user-main{flex:1;padding:48px 0}.auth-card{text-align:center;max-width:400px;margin:0 auto}.auth-card h1{margin-bottom:8px}.auth-form{flex-direction:column;gap:12px;margin-top:24px;display:flex}.auth-note{margin-top:16px;font-size:.875rem}.user-header{align-items:center;gap:24px;margin-bottom:32px;display:flex}.user-avatar{font-size:3rem}.user-info{flex:1}.user-info h2{margin-bottom:4px}.user-meta{color:var(--text-gray);font-size:.875rem}.user-stats{gap:32px;display:flex}.stat{text-align:center}.stat-value{color:var(--primary);font-size:1.5rem;font-weight:700;display:block}.user-tabs{border-bottom:1px solid var(--border);gap:16px;margin-bottom:24px;display:flex}.tab-btn{color:var(--text-gray);background:0 0;border-bottom:2px solid #0000;padding:12px 24px;font-weight:500;transition:all .2s}.courses-list,.evaluations-list{flex-direction:column;gap:16px;display:flex}.course-progress-item{justify-content:space-between;align-items:center;display:flex}.course-progress-info{flex:1;margin-right:16px}.course-progress-info h3{margin-bottom:8px;font-size:1rem}.course-progress-value{color:var(--accent);font-weight:600}.evaluation-item{justify-content:space-between;align-items:center;display:flex}.evaluation-info h3{word-break:break-all;margin-bottom:4px;font-size:1rem}.evaluation-score{text-align:center;min-width:60px}.score-value{color:var(--primary);font-size:1.5rem;font-weight:700;display:block}.score-label{color:var(--text-gray);font-size:.75rem}.btn-admin{color:#fff;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffffff1a}.btn-admin:hover{background:linear-gradient(135deg,#16213e,#0f3460);transform:translateY(-1px)}@media (width<=768px){.user-header{text-align:center;flex-direction:column}.user-stats{justify-content:center}}.user-evaluations-page{flex-direction:column;min-height:100vh;display:flex}.evaluations-list{flex-direction:column;gap:16px;display:flex}.evaluation-card{padding:24px}.evaluation-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.evaluation-info h3{margin-bottom:4px}.evaluation-result{border-top:1px solid var(--border);grid-template-columns:150px 1fr;gap:24px;padding-top:16px;display:grid}.result-summary{justify-content:center;align-items:center;display:flex}.score-circle{background:linear-gradient(135deg, var(--accent), var(--secondary));color:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.score-circle.score-high{background:linear-gradient(135deg,#2e7d32,#4caf50)}.score-circle.score-medium{background:linear-gradient(135deg,#ff9800,#ffc107)}.score-circle.score-low{background:linear-gradient(135deg,#d32f2f,#f44336)}.score-value{font-size:2rem;font-weight:700}.score-label{font-size:.875rem}.result-details{flex-direction:column;gap:16px;display:flex}.detail-section{background:var(--bg-light);border-radius:var(--radius-md);padding:12px}.detail-section h4{margin-bottom:8px;font-size:.875rem}.check-status{margin-bottom:8px;font-weight:600}.check-status.passed{color:#2e7d32}.check-status.failed{color:#d32f2f}.detail-list{color:var(--text-gray);margin-left:20px;font-size:.875rem}.detail-list li{margin:4px 0}.dependency-stats{gap:16px;font-size:.875rem;display:flex}.dependency-stats .warning{color:#d32f2f}.dependency-stats .info{color:#ff9800}.evaluation-pending{background:var(--bg-light);border-radius:var(--radius-md);align-items:center;gap:16px;padding:16px;display:flex}.pending-spinner{border:3px solid var(--border);border-top-color:var(--secondary);border-radius:50%;width:24px;height:24px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.evaluation-result{grid-template-columns:1fr}.result-summary{justify-content:flex-start}.score-circle{width:100px;height:100px}.score-value{font-size:1.5rem}}.user-collections-page{flex-direction:column;min-height:100vh;display:flex}.page-main{flex:1;padding:48px 0}.page-header{margin-bottom:32px}.back-link{color:var(--text-gray);margin-bottom:16px;display:inline-block}.page-header h1{margin-bottom:8px}.collections-tabs{border-bottom:1px solid var(--border);gap:16px;margin-bottom:24px;display:flex}.tab-btn{color:var(--text-gray);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 24px;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.empty-state{text-align:center;padding:48px}.empty-icon{margin-bottom:16px;font-size:3rem}.empty-state h3{margin-bottom:8px}.empty-state .btn{margin-top:16px}.resources-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px;display:grid}.resource-card{padding:16px}.resource-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.resource-source{color:var(--secondary);font-size:.875rem}.action-btn{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:999px;padding:4px 12px;font-size:.75rem;transition:all .2s}.action-btn:hover{background:#f5f5f5}.action-btn.like:hover{background:#ffebee;border-color:#ef5350}.action-btn.like.active{color:#ef5350;background:#ffebee;border-color:#ef5350}.action-btn.collect:hover{background:#fff8e1;border-color:#ffc107}.action-btn.collect.active{color:#ffc107;background:#fff8e1;border-color:#ffc107}.resource-title{margin-bottom:8px;font-size:1rem}.resource-title a{color:var(--text-dark);text-decoration:none}.resource-title a:hover{color:var(--primary)}.resource-desc{color:var(--text-gray);margin-bottom:12px;font-size:.875rem;line-height:1.6}.resource-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.resource-stats{color:var(--text-gray);font-size:.875rem}.course-sets-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px;display:grid}.course-set-card{padding:16px}.course-set-header{align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.course-set-icon{font-size:2rem}.course-set-info{flex:1}.course-set-info h3{margin-bottom:4px;font-size:1rem}.course-set-category{color:var(--secondary);text-transform:uppercase;font-size:.75rem}.btn-sm{padding:4px 12px;font-size:.75rem}.course-set-desc{color:var(--text-gray);margin-bottom:12px;font-size:.875rem;line-height:1.6}.course-set-stats{color:var(--text-gray);gap:16px;margin-bottom:12px;font-size:.875rem;display:flex}.course-set-courses{background:var(--bg-light);border-radius:var(--radius-md);padding:12px}.mini-course{align-items:center;gap:8px;padding:6px 0;font-size:.875rem;display:flex}.mini-course-index{background:var(--border);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;display:flex}.mini-course-title{color:var(--text-dark);flex:1}.mini-course.more{color:var(--text-gray);border-top:1px dashed var(--border);justify-content:center;margin-top:4px;padding-top:8px}@media (width<=768px){.resources-grid,.course-sets-grid{grid-template-columns:1fr}}.admin-layout{min-height:100vh;display:flex}.admin-sidebar{color:#fff;background:#1a1a2e;flex-direction:column;width:250px;height:100vh;display:flex;position:fixed;overflow-y:auto}.admin-logo{border-bottom:1px solid #ffffff1a;padding:20px}.admin-logo a{color:#fff;align-items:center;gap:10px;font-size:1.25rem;font-weight:600;text-decoration:none;display:flex}.logo-icon{font-size:1.5rem}.admin-nav{flex:1;padding:20px 0}.admin-nav a{color:#ffffffb3;align-items:center;gap:12px;padding:12px 20px;text-decoration:none;transition:all .2s;display:flex}.admin-nav a:hover{color:#fff;background:#ffffff1a}.admin-nav a.active{color:#fff;background:#ffffff26;border-left:3px solid #00bfa5}.nav-icon{font-size:1.25rem}.admin-footer{border-top:1px solid #ffffff1a;padding:20px}.back-to-site{color:#ffffffb3;border-radius:8px;align-items:center;gap:10px;padding:10px;text-decoration:none;transition:all .2s;display:flex}.back-to-site:hover{color:#fff;background:#ffffff1a}.admin-user{border-top:1px solid #ffffff1a;margin-top:15px;padding-top:15px}.user-email{color:#ffffff80;font-size:.875rem}.admin-main{background:#f5f7fa;flex:1;min-height:100vh;margin-left:250px}.admin-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loading-spinner{border:3px solid #e5e7eb;border-top-color:#0d47a1;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.admin-page{padding:30px}.admin-header{margin-bottom:30px}.admin-header h1{margin-bottom:8px;font-size:1.75rem}.admin-header p{color:#6b7280}.admin-card{background:#fff;border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 2px 8px #00000014}.admin-card h2{border-bottom:1px solid #e5e7eb;margin-bottom:16px;padding-bottom:16px;font-size:1.25rem}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.stat-icon{margin-bottom:12px;font-size:2rem}.stat-value{color:#0d47a1;font-size:2rem;font-weight:700}.stat-label{color:#6b7280;font-size:.875rem}.admin-table{border-collapse:collapse;width:100%}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:12px}.admin-table th{color:#374151;background:#f9fafb;font-weight:600}.admin-table tr:hover{background:#f9fafb}.admin-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.admin-btn-primary{color:#fff;background:#0d47a1}.admin-btn-primary:hover{background:#1565c0}.admin-btn-success{color:#fff;background:#00bfa5}.admin-btn-success:hover{background:#00a693}.admin-btn-warning{color:#fff;background:#ff9800}.admin-btn-warning:hover{background:#f57c00}.admin-btn-danger{color:#fff;background:#d32f2f}.admin-btn-danger:hover{background:#c62828}.admin-btn-secondary{color:#374151;background:#e5e7eb}.admin-btn-secondary:hover{background:#d1d5db}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-input{border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 14px;font-size:.875rem;transition:all .2s}.admin-input:focus{border-color:#0d47a1;outline:none;box-shadow:0 0 0 3px #0d47a11a}.admin-select{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 14px;font-size:.875rem}.admin-badge{border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:#065f46;background:#d1fae5}.badge-warning{color:#92400e;background:#fef3c7}.badge-error{color:#991b1b;background:#fee2e2}.badge-info{color:#1e40af;background:#dbeafe}.admin-form-group{margin-bottom:20px}.admin-form-group label{color:#374151;margin-bottom:8px;font-weight:500;display:block}.admin-form-group .help-text{color:#6b7280;margin-top:4px;font-size:.75rem}.admin-actions{gap:12px;margin-top:20px;display:flex}.toggle-switch{cursor:pointer;background:#d1d5db;border-radius:12px;width:48px;height:24px;transition:all .2s;position:relative}.toggle-switch.active{background:#00bfa5}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:all .2s;position:absolute;top:2px;left:2px}.toggle-switch.active:after{left:26px}@media (width<=768px){.admin-sidebar{width:100%;height:auto;position:relative}.admin-main{margin-left:0}.admin-layout{flex-direction:column}}.loading-state{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px;display:flex}.stat-link{color:#0d47a1;margin-top:12px;font-size:.875rem;text-decoration:none;display:block}.stat-link:hover{text-decoration:underline}.quick-actions{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.quick-action{color:#374151;background:#f9fafb;border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:24px;text-decoration:none;transition:all .2s;display:flex}.quick-action:hover{background:#f3f4f6;transform:translateY(-2px)}.action-icon{font-size:2rem}.action-text{font-weight:500}.status-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.status-item{background:#f9fafb;border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.status-label{color:#374151}.admin-message{border-radius:8px;margin-bottom:20px;padding:12px 16px}.admin-message.success{color:#065f46;background:#d1fae5}.admin-message.error{color:#991b1b;background:#fee2e2}.config-list{flex-direction:column;gap:16px;display:flex}.config-item{background:#f9fafb;border-radius:8px;justify-content:space-between;align-items:center;gap:20px;padding:16px;display:flex}.config-info{flex:1}.config-info label{color:#374151;margin-bottom:4px;font-weight:500;display:block}.config-key{color:#6b7280;font-family:monospace;font-size:.75rem}.config-value{min-width:200px}.env-list{flex-direction:column;gap:8px;display:flex}.env-item{background:#f9fafb;border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.env-name{color:#374151;font-family:monospace}.env-status{color:#065f46;background:#d1fae5;border-radius:4px;padding:4px 8px;font-size:.75rem}.help-text{color:#6b7280;margin-bottom:16px;font-size:.875rem}code{background:#f3f4f6;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:.875rem}.schedule-info{flex-direction:column;gap:16px;display:flex}.schedule-item{background:#f9fafb;border-radius:8px;padding:16px}.schedule-item h4{color:#374151;margin-bottom:8px}.schedule-item p{color:#6b7280;font-size:.875rem;line-height:1.6}.collection-actions{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:30px;display:grid}.collection-card{text-align:center}.collection-icon{margin-bottom:12px;font-size:3rem}.collection-card h3{border:none;margin-bottom:8px;padding:0}.collection-card p{color:#6b7280;margin-bottom:16px;font-size:.875rem;line-height:1.6}.empty-logs{text-align:center;color:#6b7280;padding:40px}.log-list{flex-direction:column;gap:12px;display:flex}.log-item{background:#f9fafb;border-radius:8px;gap:12px;padding:12px 16px;display:flex}.log-item.log-success{border-left:3px solid #00bfa5}.log-item.log-error{border-left:3px solid #d32f2f}.log-item.log-running{border-left:3px solid #ff9800}.log-icon{flex-shrink:0;font-size:1.25rem}.log-content{flex:1}.log-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.log-time{color:#9ca3af;font-size:.75rem}.log-message{color:#4b5563;font-size:.875rem}.card-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.card-header h2{border:none;margin:0;padding:0}.add-admin-form{background:#f9fafb;border-radius:8px;margin-bottom:20px;padding:20px}.form-row{grid-template-columns:1fr 1fr 150px auto;align-items:end;gap:16px;display:grid}.form-actions{flex-direction:column;display:flex}.role-select{width:auto;min-width:120px}.roles-info{flex-direction:column;gap:16px;display:flex}.role-item{background:#f9fafb;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;display:flex}.role-item p{color:#4b5563;margin:0;font-size:.875rem}@media (width<=768px){.form-row{grid-template-columns:1fr}}
