code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.modal-overlay{animation:fadeIn .2s ease-out;background-color:#000000b3;bottom:0;right:0}.modal-content{animation:slideUp .3s ease-out;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:2.5rem}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:1.5rem;height:36px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s;width:36px}.modal-close:hover{background-color:#f5f5f5;color:#333}.modal-content h2{font-size:1.75rem;margin:0 0 .5rem}.modal-subtitle{color:#7f8c8d;font-size:.95rem;margin:0 0 1.5rem}.login-form{margin-top:1.5rem}.form-group label{color:#2c3e50}.form-group label i{color:#3498db;margin-right:.5rem}.form-group input{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;padding:.75rem 1rem;transition:all .2s}.form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.error-message{align-items:center;background-color:#fee;border-left:3px solid #c33;border-radius:8px;color:#c33;display:flex;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.error-message i{margin-right:.5rem}.btn-primary{font-size:1rem;font-weight:600;justify-content:center;padding:.875rem 1.5rem;transition:all .3s;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.7}.btn-primary i.fa-spinner{animation:spin 1s linear infinite}.login-help{border-top:1px solid #e0e0e0;margin-top:1.5rem;padding-top:1.5rem;text-align:center}.login-help p{align-items:center;color:#7f8c8d;display:flex;font-size:.85rem;gap:.5rem;justify-content:center;margin:0}.login-help strong{background-color:#f5f5f5;border-radius:4px;color:#2c3e50;font-family:monospace;padding:.2rem .5rem}@media (max-width:600px){.modal-content{max-width:95%;padding:2rem 1.5rem}.modal-content h2{font-size:1.5rem}}.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 2rem}.navbar-logo{color:#2c5282;font-size:1.5rem;font-weight:700;text-decoration:none}.navbar-menu{display:flex;gap:2rem}.navbar-item{color:#4a5568;font-weight:500;text-decoration:none;transition:color .2s ease}.navbar-item:hover{color:#2c5282}.navbar-actions{align-items:center;display:flex;gap:1rem}.search-button{background:none;border:none;color:#4a5568;cursor:pointer;font-size:1.1rem;padding:.5rem;transition:color .2s ease}.search-button:hover{color:#2c5282}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:20px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1.5rem;transition:transform .2s}.login-button:hover{transform:scale(1.05)}.user-menu{gap:1rem}.user-greeting,.user-menu{align-items:center;display:flex}.user-greeting{color:#2c3e50;font-weight:500;gap:.5rem}.user-greeting i{color:#667eea;font-size:1.2rem}.logout-button{align-items:center;background:#0000;border:1px solid #e74c3c;border-radius:20px;color:#e74c3c;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.logout-button:hover{background:#e74c3c;color:#fff}.admin-link{align-items:center;color:#f39c12!important;display:flex;font-weight:600;gap:.5rem}@media (max-width:768px){.navbar-container{padding:1rem}.navbar-menu{display:none}.navbar-actions{gap:.5rem}.login-button{padding:.5rem}}.course-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:block;margin:16px;overflow:hidden;padding:0;text-decoration:none;transition:all .3s ease}.course-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-4px)}.course-image{background-color:#f7fafc;height:200px;overflow:hidden;position:relative;width:100%}.course-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.course-card:hover .course-image img{transform:scale(1.05)}.image-placeholder{align-items:center;background-color:#f7fafc;color:#a0aec0;display:flex;height:100%;justify-content:center;width:100%}.image-placeholder .fas{font-size:3.5rem}.course-info{padding:20px}.course-header{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.area-badge,.degree-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.degree-badge{background-color:#ebf8ff;color:#2b6cb0}.area-badge{background-color:#f0fff4;color:#2f855a}.course-title{color:#2d3748;font-size:1.25rem;font-weight:600;line-height:1.4;margin:0 0 12px}.institution-name{color:#4a5568;font-size:.95rem;font-weight:500;margin:0 0 12px}.institution-name i{color:#718096;margin-right:6px}.course-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#718096;display:-webkit-box;font-size:.9rem;line-height:1.5;margin-bottom:16px;overflow:hidden}.course-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.meta-item{align-items:center;color:#718096;display:flex;font-size:.85rem}.meta-item i{color:#a0aec0;margin-right:6px}.course-footer{align-items:center;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;padding-top:16px}.start-date{color:#718096;font-size:.85rem}.course-price{color:#2d3748;font-size:1.1rem;font-weight:600}.modality-badge{background-color:#000000b3;border-radius:20px;color:#fff;font-size:.75rem;font-weight:500;letter-spacing:.5px;padding:4px 12px;position:absolute;right:12px;text-transform:uppercase;top:12px}.courses-grid{grid-gap:20px;gap:20px;padding:20px}.course-list h2{color:#333;margin:20px 0}.no-results{color:#666;font-size:1.2em;padding:40px}.category-filters{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:24px 0;padding:0 20px}.category-button{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 1px 2px #0000000d;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.category-button:hover{background-color:#f7fafc;border-color:#cbd5e0;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.category-button.active{background-color:#ebf8ff;border-color:#2b6cb0;color:#2b6cb0;font-weight:600}.category-button i{font-size:.9rem;opacity:.8}.category-button:hover i{opacity:1}.category-button.active i{color:#2b6cb0}.course-category{align-items:center;background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;color:#4a5568;display:inline-flex;font-size:.8rem;font-weight:500;margin-bottom:8px;padding:4px 12px}.course-category i{color:#718096;font-size:.8rem;margin-right:6px}.search-bar{display:flex;justify-content:center;padding:20px}.search-input{border:2px solid #ddd;border-radius:25px;font-size:16px;max-width:600px;outline:none;padding:12px 20px;transition:border-color .3s ease;width:100%}.search-input:focus{border-color:#007bff;box-shadow:0 0 5px #007bff4d}.search-input::placeholder{color:#999}.course-list{margin:0 auto;max-width:1200px;padding:20px}.course-list h2{color:#2d3748;font-size:2rem;font-weight:600;margin:24px 0;text-align:center}.filters-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin:24px 0;padding:24px}.filters{grid-gap:24px;align-items:end;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#4a5568;font-size:.9rem;font-weight:500}.filter-select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;border:1px solid #e2e8f0;border-radius:8px;color:#2d3748;cursor:pointer;font-size:.95rem;padding:10px 40px 10px 16px;transition:all .2s ease}.filter-select:hover{border-color:#cbd5e0}.filter-select:focus{border-color:#2b6cb0;box-shadow:0 0 0 3px #2b6cb01a;outline:none}.courses-grid{grid-gap:24px;gap:24px;margin-top:32px}.no-results{background-color:#f7fafc;border:1px dashed #e2e8f0;border-radius:12px;color:#718096;font-size:1.1rem;grid-column:1/-1;padding:48px}@media (max-width:768px){.filters{grid-template-columns:1fr}.course-list,.filters-container{padding:16px}}.results-info{color:#666;margin-bottom:2rem;text-align:center}.no-results{background:#f8f9fa;border-radius:8px;padding:4rem 2rem;text-align:center}.no-results h3{margin-top:0}.loading-indicator{align-items:center;color:#555;display:flex;gap:1rem;height:100px;justify-content:center;padding:2rem;text-align:center}.spinner{animation:spin 1s ease infinite;border:4px solid #0000001a;border-left-color:#007bff;border-radius:50%;height:36px;width:36px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.search-and-view-controls{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.search-and-view-controls>div:first-child{flex:1 1}.view-mode-toggle{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:.5rem;padding:4px}.view-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:1.1rem;justify-content:center;min-width:44px;padding:10px 16px;transition:all .2s ease}.view-btn:hover{background:#f3f4f6;color:#333}.view-btn.active{background:#2b6cb0;color:#fff}.view-btn i{pointer-events:none}.courses-grid.list-view{display:flex;flex-direction:column;gap:1rem}.courses-grid.list-view .course-card{display:flex;flex-direction:row;height:auto;max-width:100%}.courses-grid.list-view .course-image{flex-shrink:0;height:180px;min-width:200px;width:200px}.courses-grid.list-view .course-info{display:flex;flex:1 1;flex-direction:column;justify-content:space-between}.courses-grid.list-view .course-title{font-size:1.3rem;margin-bottom:.5rem}.courses-grid.list-view .course-description{display:block;max-height:none}.courses-grid.list-view .course-meta{flex-wrap:wrap}@media (max-width:768px){.search-and-view-controls{flex-direction:column}.view-mode-toggle{justify-content:center;width:100%}.courses-grid.list-view .course-card{flex-direction:column}.courses-grid.list-view .course-image{height:200px;width:100%}}.course-detail-container{background-color:#fdfdff;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:2rem auto;max-width:1200px;padding:2rem}.course-detail-breadcrumb{color:#555;font-size:.9rem;margin-bottom:1.5rem}.course-detail-breadcrumb a{color:#007bff;text-decoration:none}.course-detail-breadcrumb a:hover{text-decoration:underline}.course-detail-breadcrumb span{color:#888}.course-detail-header{border-bottom:1px solid #e0e0e0;margin-bottom:2rem;padding-bottom:1.5rem;text-align:left}.course-detail-area-badge{background-color:#e7f3ff;border-radius:50px;color:#007bff;display:inline-block;font-size:.9rem;font-weight:600;margin-bottom:1rem;padding:.4rem .8rem}.course-detail-header h1{font-size:2.8rem;font-weight:700;line-height:1.2;margin:0}.course-detail-institution{color:#555;font-size:1.2rem;margin-top:.5rem}.course-detail-layout{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:1fr}@media (min-width:992px){.course-detail-layout{grid-template-columns:2fr 1fr}}.course-detail-main-image{border-radius:12px;box-shadow:0 8px 25px #0000001a;height:auto;margin-bottom:2rem;object-fit:cover;width:100%}.course-detail-section{background-color:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:2rem;padding:2rem}.course-detail-section h2{align-items:center;color:#2c3e50;display:flex;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;margin-top:0}.course-detail-section h2 i{color:#007bff;margin-right:1rem}.course-detail-section p{font-size:1.1rem;line-height:1.8}.course-detail-list{list-style:none;padding-left:0}.course-detail-list li{background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;font-size:1rem;margin-bottom:.75rem;padding:1rem 1.5rem}.professional-outlook p{font-size:1.1rem;margin-bottom:.5rem}.professional-outlook i{color:#007bff;margin-right:.75rem;width:20px}.course-detail-sidebar .sidebar-card{background-color:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 15px #0000000d;margin-bottom:2rem;padding:1.5rem}.course-detail-sidebar h3{border-bottom:1px solid #eee;font-size:1.4rem;margin-bottom:1.5rem;margin-top:0;padding-bottom:1rem}.summary-card ul{list-style:none;margin:0 0 1.5rem;padding:0}.summary-card li{align-items:center;display:flex;font-size:1rem;margin-bottom:1rem}.summary-card li i{color:#007bff;margin-right:1rem;text-align:center;width:20px}.summary-card li strong{color:#343a40;margin-right:.5rem}.summary-card li span{color:#555}.cta-button{background-color:#007bff;border-radius:5px;color:#fff;display:block;font-size:1.1rem;font-weight:600;padding:1rem;text-align:center;text-decoration:none;transition:background-color .3s ease;width:100%}.cta-button:hover{background-color:#0056b3}.institution-card p{line-height:1.6;margin-bottom:1rem}.institution-card a{color:#007bff;font-weight:600;text-decoration:none}.institution-card a:hover{text-decoration:underline}.course-detail-error{padding:4rem 2rem;text-align:center}.course-detail-error h2{font-size:2rem;margin-bottom:1rem}.course-detail-error button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:.8rem 1.5rem;transition:background-color .3s ease}.course-detail-error button:hover{background-color:#0056b3}.modal-overlay{align-items:center;background-color:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{animation:slide-down .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;max-width:500px;padding:2rem 3rem;position:relative;width:90%}@keyframes slide-down{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-close-button{background:none;border:none;color:#888;cursor:pointer;font-size:1.8rem;position:absolute;right:15px;top:15px}.modal-content h2{color:#2c3e50;font-size:1.8rem;margin-top:0;text-align:center}.modal-content p{color:#555;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{font-weight:600}.form-group input{border:1px solid #ccc;border-radius:6px;font-size:1rem;padding:.8rem;width:100%}.form-group input:read-only{background-color:#f4f4f4;cursor:not-allowed}.submit-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem;transition:background-color .3s ease;width:100%}.submit-button:hover:not(:disabled){background-color:#0056b3}.submit-button:disabled{background-color:#a0a0a0;cursor:not-allowed}.submit-message{background-color:#f0fff4;border-radius:8px;color:#2f855a;font-size:1.1rem;padding:2rem;text-align:center}.institution-card{background-color:#fff;border-radius:12px;box-shadow:0 6px 20px #00000012;color:inherit;display:flex;flex-direction:column;overflow:hidden;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}.institution-card:hover{box-shadow:0 10px 25px #0000001a;transform:translateY(-5px)}.institution-card-image-wrapper{align-items:center;background-color:#f5f5f5;display:flex;height:200px;justify-content:center;overflow:hidden;width:100%}.institution-card-image{display:block;height:100%;object-fit:cover;transition:transform .4s ease;width:100%}.institution-card:hover .institution-card-image{transform:scale(1.05)}.institution-card-content{display:flex;flex-direction:column;flex-grow:1;padding:1.5rem}.institution-card-name{font-size:1.4rem;font-weight:600;margin:0 0 .5rem}.institution-card-location{align-items:center;color:#666;display:flex;font-size:.9rem;margin-bottom:1rem}.institution-card-location i{margin-right:.5rem}.institution-card-description{color:#444;flex-grow:1;font-size:1rem;line-height:1.5;margin-bottom:1.5rem}.institution-card-footer{border-top:1px solid #f0f0f0;color:#007bff;font-size:.9rem;font-weight:500;margin-top:auto;padding-top:1rem}.institution-list-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:2rem auto;max-width:1200px;padding:2rem}.institution-list-header{margin-bottom:3rem;text-align:center}.institution-list-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700}.institution-list-header p{color:#555;font-size:1.2rem;margin:.5rem auto 0;max-width:600px}.institution-detail-container{background-color:#f9fafb;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.institution-detail-header{align-items:center;background-position:50%;background-size:cover;color:#fff;display:flex;height:40vh;justify-content:center;position:relative;text-align:center}.institution-header-overlay{align-items:center;background-color:#0009;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:1}.institution-detail-header h1{font-size:3.5rem;font-weight:700;margin:0;z-index:2}.institution-detail-header p{font-size:1.5rem;z-index:2}.institution-detail-content{margin:0 auto;max-width:1200px;padding:2rem;position:relative;transform:translateY(-80px);z-index:3}.institution-info-bar{background-color:#fff;border-radius:12px;box-shadow:0 8px 25px #00000014;display:flex;flex-wrap:wrap;justify-content:space-around;margin-bottom:2rem;padding:1.5rem}.institution-info-bar p{align-items:center;display:flex;font-size:1rem;margin:.5rem 1rem}.institution-info-bar i{color:#007bff;margin-right:.8rem}.institution-description{margin-bottom:2rem}.institution-courses-section,.institution-description{background-color:#fff;border-radius:8px;padding:2rem}.institution-courses-section h2,.institution-description h2{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:1.5rem;margin-top:0}.courses-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.institution-detail-error{padding:4rem;text-align:center}.country-list-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:2rem auto;max-width:1200px;padding:2rem}.country-list-header{margin-bottom:3rem;text-align:center}.country-list-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700}.country-list-header p{color:#555;font-size:1.2rem;margin:.5rem auto 0;max-width:600px}.country-list-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.country-card{border-radius:12px;box-shadow:0 8px 20px #0000001a;display:block;height:250px;overflow:hidden;position:relative;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}.country-card:hover{box-shadow:0 12px 30px #00000026;transform:translateY(-5px)}.country-card-image{height:100%;object-fit:cover;transition:transform .4s ease;width:100%}.country-card:hover .country-card-image{transform:scale(1.1)}.country-card-overlay{background:linear-gradient(0deg,#000c 0,#0000 60%);color:#fff;display:flex;flex-direction:column;height:100%;justify-content:flex-end;left:0;padding:1.5rem;position:absolute;text-align:left;top:0;width:100%}.country-card-name{font-size:1.8rem;font-weight:700;line-height:1.2;margin:0}.country-card-count{background-color:#fff3;border-radius:5px;display:inline-block;font-size:1rem;margin-top:.5rem;padding:.3rem .6rem}.country-detail-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:2rem auto;max-width:1200px;padding:2rem}.country-detail-header{border-bottom:1px solid #e0e0e0;margin-bottom:3rem;padding-bottom:2rem;text-align:center}.country-detail-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700}.country-detail-header p{color:#555;font-size:1.2rem;margin:.5rem auto 0;max-width:600px}.institution-list-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.country-detail-error{padding:4rem;text-align:center}.web-scraper{display:flex;flex-direction:column;height:100%}.scraper-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px 8px 0 0;color:#fff;margin-bottom:1.5rem;padding:1.5rem}.scraper-header h2{align-items:center;display:flex;font-size:1.5rem;gap:.75rem;margin:0 0 .5rem}.scraper-description{font-size:.95rem;margin:0 0 .75rem;opacity:.9}.mcp-status{display:flex;gap:1rem;margin-top:1rem}.status-indicator{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.5rem 1rem}.status-indicator.connected{background:#2ecc7133;border:1px solid #2ecc7180}.status-indicator.disconnected{animation:blink 2s infinite;background:#e74c3c33;border:1px solid #e74c3c80}.status-indicator.browser{background:#3498db33;border:1px solid #3498db80}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.scraper-content{grid-gap:1.5rem;display:grid;flex:1 1;gap:1.5rem;grid-template-columns:450px 1fr;overflow:hidden}.scraper-left-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-height:calc(100vh - 250px);overflow-y:auto;padding:1.5rem}.scraper-section{border-bottom:1px solid #e0e0e0;margin-bottom:2rem;padding-bottom:2rem}.scraper-section:last-child{border-bottom:none}.scraper-section h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.helper-text,.scraper-section h3{align-items:center;display:flex;gap:.5rem}.helper-text{color:#666;font-size:.85rem;margin:.5rem 0}.extraction-note{align-items:flex-start;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;display:flex;font-size:.9rem;gap:.75rem;margin:1rem 0;padding:1rem}.extraction-note i{font-size:1.2rem;margin-top:.2rem}.url-input-group{display:flex;gap:.5rem;margin-bottom:.5rem}.url-input{border:2px solid #ddd;border-radius:6px;flex:1 1;font-size:.95rem;padding:.75rem;transition:border-color .3s}.url-input:focus{border-color:#667eea;outline:none}.btn-load{align-items:center;background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:background .3s;white-space:nowrap}.btn-load:hover:not(:disabled){background:#5568d3}.btn-load:disabled{cursor:not-allowed;opacity:.6}.extraction-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}.extraction-field{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;display:flex;gap:.75rem;justify-content:space-between;padding:.75rem}.extraction-field label{color:#333;flex:1 1;font-weight:500}.btn-extract{align-items:center;background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s;white-space:nowrap}.btn-extract:hover{background:#667eea;color:#fff}.btn-extract.active{animation:pulse 1.5s infinite;background:#ff9800;border-color:#ff9800;color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.extracted-indicator{align-items:center;color:#27ae60;display:flex;font-size:.85rem;font-weight:600;gap:.25rem}.form-group{margin-bottom:1rem}.form-group label{color:#333;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.form-control{border:2px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:.95rem;padding:.75rem;transition:border-color .3s;width:100%}.form-control:focus{border-color:#667eea;outline:none}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}textarea.form-control{font-family:inherit;resize:vertical}.image-preview{background:#f8f9fa;border-radius:6px;margin-top:.5rem;padding:.5rem;text-align:center}.image-preview img{border-radius:4px;max-height:150px;max-width:100%}.btn-save-course{align-items:center;background:linear-gradient(135deg,#27ae60,#219653);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:1.5rem;padding:1rem;transition:transform .2s,box-shadow .3s;width:100%}.btn-save-course:hover:not(:disabled){box-shadow:0 4px 12px #27ae604d;transform:translateY(-2px)}.btn-save-course:disabled{cursor:not-allowed;opacity:.6;transform:none}.scraper-right-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;overflow:hidden}.preview-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.preview-header h3{align-items:center;color:#333;display:flex;font-size:1.1rem;gap:.5rem;margin:0}.current-url-display{background:#f0f0f0;border-radius:6px;color:#666;max-width:300px;overflow:hidden;padding:.4rem .8rem;text-overflow:ellipsis;white-space:nowrap}.current-url-display,.extraction-mode-indicator{align-items:center;display:flex;font-size:.85rem;gap:.5rem}.extraction-mode-indicator{animation:pulse 1.5s infinite;background:#ff9800;border-radius:20px;color:#fff;font-weight:600;padding:.5rem 1rem}.preview-container{background:#f5f5f5;flex:1 1;overflow:auto;position:relative}.preview-placeholder{align-items:center;color:#999;display:flex;flex-direction:column;height:100%;justify-content:center;padding:2rem;text-align:center}.preview-placeholder i{margin-bottom:1rem;opacity:.5}.preview-placeholder .sub-text{color:#bbb;font-size:.85rem;margin-top:.5rem}.screenshot-preview{background:#f5f5f5;height:100%;overflow:auto;padding:1rem;width:100%}.page-screenshot{border-radius:8px;box-shadow:0 4px 12px #0000001a;display:block;height:auto;margin:0 auto;max-width:100%}.html-preview{background:#fff;cursor:crosshair;min-height:100%;padding:1rem}.html-preview *{pointer-events:auto!important}.preview-footer{background:#fff3cd;border-top:1px solid #ffc107;padding:.75rem 1.5rem}.preview-footer p{align-items:center;color:#856404;display:flex;font-size:.85rem;gap:.5rem;margin:0}.preview-container::-webkit-scrollbar,.scraper-left-panel::-webkit-scrollbar{width:8px}.preview-container::-webkit-scrollbar-track,.scraper-left-panel::-webkit-scrollbar-track{background:#f1f1f1}.preview-container::-webkit-scrollbar-thumb,.scraper-left-panel::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.preview-container::-webkit-scrollbar-thumb:hover,.scraper-left-panel::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:1400px){.scraper-content{grid-template-columns:400px 1fr}}@media (max-width:1200px){.scraper-content{grid-template-columns:1fr;grid-template-rows:auto 1fr}.scraper-left-panel{max-height:50vh}.scraper-right-panel{min-height:50vh}}@media (max-width:768px){.url-input-group{flex-direction:column}.btn-load{justify-content:center;width:100%}.form-row{grid-template-columns:1fr}.extraction-field{align-items:stretch;flex-direction:column}.btn-extract{justify-content:center}}.admin-panel{background:#f5f7fa;min-height:100vh}.admin-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 6px #0000001a;color:#fff;padding:2rem 0}.admin-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.admin-header h1{font-size:2rem;font-weight:700;margin:0}.admin-subtitle{margin:.5rem 0 0;opacity:.9}.admin-subtitle,.user-role-badge{align-items:center;display:flex;gap:.5rem}.user-role-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;font-weight:500;padding:.5rem 1rem}.admin-container{margin:0 auto;max-width:1200px;padding:2rem}.admin-tabs{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;gap:1rem;margin-bottom:2rem;padding:1rem}.tab-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .2s}.tab-button:hover{background:#f5f7fa;color:#333}.tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.admin-content{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;min-height:500px;padding:2rem}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-card{align-items:center;background:linear-gradient(135deg,#f5f7fa,#fff);border:1px solid #e1e8ed;border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s}.stat-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-4px)}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;font-size:1.5rem;height:60px;justify-content:center;width:60px}.stat-icon.courses{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.institutions{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.users{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.analytics{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-info h3{color:#666;font-size:.9rem;font-weight:500;margin:0}.stat-number{color:#2c3e50;font-size:2rem;font-weight:700;margin:.5rem 0 0}.info-panel{background:linear-gradient(135deg,#f5f7fa,#fff);border:1px solid #e1e8ed;border-radius:12px;grid-column:span 2;padding:1.5rem}.info-panel h3{align-items:center;color:#2c3e50;display:flex;gap:.5rem;margin:0 0 1rem}.system-status{display:flex;flex-direction:column;gap:.75rem}.status-item{align-items:center;color:#555;display:flex;font-size:.95rem;gap:.75rem}.quick-actions{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.action-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s}.action-button:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.content-section{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.section-header{align-items:center;border-bottom:2px solid #e1e8ed;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.section-header h2{align-items:center;color:#2c3e50;display:flex;gap:.75rem;margin:0}.btn-primary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-primary:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.coming-soon-admin{color:#7f8c8d;padding:4rem 2rem;text-align:center}.coming-soon-admin i{color:#bdc3c7;font-size:4rem;margin-bottom:1rem}.coming-soon-admin h3{color:#2c3e50;margin:1rem 0}.coming-soon-admin p{color:#95a5a6}.loading-state{color:#666;font-size:1.1rem;padding:3rem;text-align:center}.loading-state i{color:#667eea;display:block;font-size:2rem;margin-bottom:1rem}.data-table-container{margin-top:1rem;overflow-x:auto}.data-table{border-collapse:collapse;font-size:.9rem;width:100%}.data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.data-table th{font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.data-table td{border-bottom:1px solid #e1e8ed;padding:.875rem 1rem;vertical-align:middle}.data-table tbody tr{transition:background-color .2s}.data-table tbody tr:hover{background-color:#f5f7fa}.course-title{color:#2c3e50;font-weight:500;max-width:300px}.institution-name{max-width:250px}.institution-name strong{color:#2c3e50}.acronym{color:#7f8c8d;font-size:.85rem}.badge{background:#e3f2fd;color:#1976d2}.badge,.badge-level{border-radius:12px;font-size:.8rem;font-weight:500;padding:.25rem .75rem;white-space:nowrap}.badge-level{background:#f3e5f5;color:#7b1fa2}.badge-admin{background:#ffe5e5;color:#c62828}.badge-admin,.badge-editor{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.badge-editor{background:#fff3e0;color:#e65100}.badge-viewer{background:#e8f5e9;color:#2e7d32;padding:.25rem .75rem}.badge-viewer,.status-badge{border-radius:12px;font-size:.8rem;font-weight:600;white-space:nowrap}.status-badge{padding:.35rem .75rem}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.website-link{align-items:center;color:#667eea;display:inline-flex;font-size:.85rem;gap:.25rem;text-decoration:none}.website-link:hover{text-decoration:underline}.action-buttons{display:flex;gap:.5rem}.btn-action{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;height:32px;justify-content:center;padding:.5rem;transition:all .2s;width:32px}.btn-action.edit{background:#e3f2fd;color:#1976d2}.btn-action.edit:hover{background:#1976d2;color:#fff}.btn-action.password{background:#fff3e0;color:#f57c00}.btn-action.password:hover{background:#f57c00;color:#fff}.btn-action.delete{background:#ffebee;color:#c62828}.btn-action.delete:hover{background:#c62828;color:#fff}.btn-action.activate{background:#e8f5e9;color:#2e7d32}.btn-action.activate:hover{background:#2e7d32;color:#fff}@media (max-width:768px){.admin-header-content{flex-direction:column;gap:1rem;text-align:center}.admin-tabs{flex-direction:column}.tab-button{justify-content:flex-start}.info-panel{grid-column:span 1}.dashboard-grid{grid-template-columns:1fr}.section-header{align-items:flex-start;flex-direction:column;gap:1rem}.data-table{font-size:.8rem}.data-table td,.data-table th{padding:.5rem}}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;margin:0 auto;width:100%}.coming-soon,.main-content{max-width:1200px;padding:2rem}.coming-soon{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#2c5282;font-size:1.5rem;font-weight:500;margin:4rem auto;text-align:center}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}h1{color:#333;margin-bottom:1rem}h1,p{text-align:center}p{color:#666;margin-bottom:2rem}
/*# sourceMappingURL=main.4b0de363.css.map*/