:root{--color-primary: #6BA3D6;--color-primary-light: #8EB8E8;--color-secondary: #D4AF37;--color-accent: #2D5016;--color-dark: #1A1A1A;--color-light: #F5F5F5;--color-white: #FFFFFF;--color-text: #333333;--color-text-light: #666666;--color-border: #E0E0E0;--font-display: "Pinyon Script", cursive;--font-body: "Source Sans 3", sans-serif;--font-family: var(--font-body);--font-size-base: 16px;--line-height: 1.6}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:var(--font-size-base)}body{font-family:var(--font-family);line-height:var(--line-height);color:var(--color-text);background-color:var(--color-light)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-dark);margin-bottom:.5em}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.1rem}h6{font-size:1rem}p{margin-bottom:1em}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-light)}ul,ol{padding-left:1.5rem}img{max-width:100%;height:auto}#app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.btn--primary{background-color:var(--color-primary);color:var(--color-white)}.btn--primary:hover{background-color:var(--color-primary-light)}.btn--secondary{background-color:var(--color-secondary);color:var(--color-dark)}.btn--secondary:hover{background-color:#c5a028}.btn--outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn--outline:hover{background-color:var(--color-primary);color:var(--color-white)}.btn--danger{background-color:#dc3545;color:var(--color-white)}.btn--danger:hover{background-color:#c82333}.btn--small{padding:.5rem 1rem;font-size:.875rem}.btn--large{padding:1rem 2rem;font-size:1.125rem}.btn:disabled{opacity:.6;cursor:not-allowed}.input,textarea.input{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:inherit;color:var(--color-text);background-color:var(--color-white);border:1px solid var(--color-border);border-radius:4px;transition:border-color .2s ease,box-shadow .2s ease}.input:focus,textarea.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6ba3d61a}.input::placeholder,textarea.input::placeholder{color:var(--color-text-light)}.input--error{border-color:#dc3545}.input--error:focus{box-shadow:0 0 0 3px #dc35451a}textarea.input{min-height:120px;resize:vertical}.form__group{margin-bottom:1.25rem}.form__label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.form__field{width:100%}.form__error{margin-top:.25rem;font-size:.875rem;color:#dc3545}.form__submit{margin-top:1rem}.modal-overlay{position:fixed;inset:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background-color:var(--color-white);border-radius:12px;max-width:500px;width:100%;max-height:95vh;overflow-y:auto;box-shadow:0 25px 80px #0006;animation:modalSlideIn .2s ease}.modal__header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal__header h3{margin:0;font-size:1.25rem;color:var(--color-dark);font-weight:600}.modal__close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-light);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal__close:hover{background:var(--color-light);color:var(--color-dark)}.modal__body{padding:1.5rem}.modal__body .form__group{margin-bottom:1rem}.modal__body .form__group:last-child{margin-bottom:0}.modal__body .form__group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-dark);font-size:.9rem}.modal__body .form__group input,.modal__body .form__group select,.modal__body .form__group textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}.modal__body .form__group input:focus,.modal__body .form__group select:focus,.modal__body .form__group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6ba3d633}.modal__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border);background:var(--color-light);border-radius:0 0 12px 12px}.modal--large{max-width:700px}.admin-layout{display:flex;flex-direction:column;min-height:100vh}.admin-layout__body{display:flex;flex:1}.admin-topbar{display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem;height:70px;background:linear-gradient(135deg,#6ba3d6,#5a93c6);color:var(--color-white);box-shadow:0 2px 10px #6ba3d64d}.admin-topbar__left{display:flex;align-items:center;gap:1rem}.admin-topbar__toggle{background:none;border:none;color:var(--color-white);font-size:1.25rem;cursor:pointer}.admin-topbar__title{font-size:1.5rem;font-weight:600;margin:0}.admin-topbar__right{display:flex;align-items:center;gap:1.5rem}.admin-topbar__user{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff26;border-radius:20px}.admin-topbar__user i{font-size:1.25rem}.admin-topbar__user-info{display:flex;flex-direction:column;line-height:1.2}.admin-topbar__username{font-weight:600;font-size:.875rem}.admin-topbar__userrole{font-size:.7rem;opacity:.8;font-weight:400}.admin-topbar__logout{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:var(--color-white);cursor:pointer;font-size:.9rem;padding:.5rem .75rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.admin-topbar__logout i{font-size:1rem}.admin-topbar__logout:hover{background:#dc3545;border-color:#dc3545;transform:scale(1.05)}.admin-topbar__link,.admin-topbar__logout{display:flex;align-items:center;gap:.5rem;color:var(--color-white);text-decoration:none;font-size:.875rem}.admin-sidebar{width:260px;background:linear-gradient(180deg,#fff,#f8f9fa);border-right:1px solid #e0e4e8;transition:width .3s ease;display:flex;flex-direction:column;box-shadow:2px 0 8px #0000000d}.admin-sidebar.collapsed{width:70px}.admin-sidebar.collapsed .admin-sidebar__label{display:none}.admin-sidebar.collapsed .admin-sidebar__link{justify-content:center;padding:1rem}.admin-sidebar__collapse{width:36px;height:36px;border-radius:8px;background:var(--color-primary);color:var(--color-white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;margin:1rem;align-self:flex-end;transition:all .2s ease;box-shadow:0 2px 6px #6ba3d666}.admin-sidebar__collapse:hover{background:#4a93c6;transform:scale(1.05)}.admin-sidebar.collapsed .admin-sidebar__collapse{align-self:center;margin:1rem 0}.admin-sidebar__nav{flex:1;overflow-y:auto;padding-bottom:1rem}.admin-sidebar__nav ul{list-style:none;padding:0;margin:0}.admin-sidebar__link{display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;color:#5a6c7d;text-decoration:none;transition:all .2s ease;border:none;background:transparent;width:100%;text-align:left;font-size:.9rem;cursor:pointer}.admin-sidebar__link i{width:20px;text-align:center;font-size:1rem}.admin-sidebar__link:hover{background:#6ba3d61a;color:var(--color-primary)}.admin-sidebar__link.active{background:linear-gradient(135deg,#6ba3d6,#5a93c6);color:var(--color-white);font-weight:500;box-shadow:0 2px 8px #6ba3d64d}.admin-dashboard{flex:1;background:var(--color-light);padding:1.5rem;overflow-y:auto}.admin-dashboard__content{background:var(--color-white);border-radius:8px;padding:1.5rem;min-height:calc(100vh - 120px)}.admin-dashboard__content{position:relative}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.view-header h2{font-size:1.5rem;color:var(--color-dark);margin:0}.view-subtitle{color:var(--color-text-light);font-size:.875rem;margin-left:1rem}.view-content{margin-top:1rem}.dashboard-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--color-primary)}.dashboard-header__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6ba3d6,#5a93c6);color:var(--color-white);border-radius:10px;font-size:1.25rem;box-shadow:0 2px 8px #6ba3d64d}.dashboard-header__title{font-size:1.5rem;color:var(--color-dark);margin:0;font-weight:600}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--color-white);border-radius:8px;box-shadow:0 2px 8px #0000000d}.stat-card--loading{opacity:.5}.stat-card__icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:var(--color-white);border-radius:8px;font-size:1.5rem}.stat-card__content{display:flex;flex-direction:column}.stat-card__value{font-size:1.75rem;font-weight:700;color:var(--color-dark)}.stat-card__label{color:var(--color-text-light);font-size:.875rem}.dashboard-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.dashboard-section{background:var(--color-white);border-radius:8px;padding:1.25rem;box-shadow:0 2px 8px #0000000d}.dashboard-section h3{font-size:1rem;color:var(--color-dark);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.dashboard-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.dashboard-item:last-child{border-bottom:none}.dashboard-item__date{color:var(--color-text-light);font-size:.875rem}.dashboard-item__title{color:var(--color-text);font-weight:500}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.data-table th{background:var(--color-light);font-weight:600;color:var(--color-dark);position:relative;-webkit-user-select:none;user-select:none}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{background:#e8eef4}.data-table th span:first-child{margin-right:.5rem}.sort-icon{font-size:.75rem;color:var(--color-text-light)}.data-table th.sortable:hover .sort-icon{color:var(--color-primary)}.data-table tr:hover{background:var(--color-light)}.data-table td.actions-cell{white-space:nowrap}.btn-view:hover{color:var(--color-primary)}.btn-edit:hover{color:#28a745}.empty-state{text-align:center;padding:3rem 2rem;color:var(--color-text-light)}.empty-state i{font-size:3rem;margin-bottom:1rem;opacity:.3}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading,.error,.empty-state{text-align:center;padding:2rem;color:var(--color-text-light)}.btn-icon{background:none;border:none;cursor:pointer;padding:.5rem;color:var(--color-text-light);transition:color .2s}.btn-icon:hover{color:var(--color-primary)}.btn-icon.btn-delete:hover{color:#dc3545}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.badge--success{background:#d4edda;color:#155724}.badge--warning{background:#fff3cd;color:#856404}.badge--secondary{background:var(--color-light);color:var(--color-text-light)}.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ticket-detail__row{display:flex;gap:.5rem;margin-bottom:.75rem}.ticket-detail__label{font-weight:600;color:var(--color-dark);min-width:80px}.ticket-detail__row--full{flex-direction:column}.ticket-detail__row--full .ticket-detail__label{margin-bottom:.25rem}.ticket-detail__row--full p{margin:0;line-height:1.5}.view-alert{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff3cd;border-radius:8px;margin-top:1rem;color:#856404;font-size:.875rem}.toast{position:fixed;bottom:1rem;right:1rem;padding:1rem 1.5rem;border-radius:8px;color:#fff;z-index:2000;animation:slideIn .3s ease}.toast--success{background:#28a745}.toast--error{background:#dc3545}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.admin-logout-modal{position:fixed;inset:0;background:#0009;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.admin-logout-modal.active{opacity:1;visibility:visible}.admin-logout-modal__content{background:var(--color-white);border-radius:12px;padding:2rem;text-align:center;max-width:360px;width:90%;box-shadow:0 10px 40px #0003}.admin-logout-modal__icon{width:60px;height:60px;border-radius:50%;background:var(--color-primary);color:var(--color-white);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.5rem}.admin-logout-modal__content h3{margin:0 0 .5rem;color:var(--color-dark);font-size:1.25rem}.admin-logout-modal__content p{margin:0 0 1.5rem;color:var(--color-text-light)}.admin-logout-modal__actions{display:flex;gap:1rem;justify-content:center}.admin-logout-modal__cancel,.admin-logout-modal__confirm{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.admin-logout-modal__cancel{background:var(--color-light);border:1px solid var(--color-border);color:var(--color-text)}.admin-logout-modal__cancel:hover{background:var(--color-border)}.admin-logout-modal__confirm{background:#dc3545;border:none;color:var(--color-white)}.admin-logout-modal__confirm:hover{background:#c82333}.confirm-modal-overlay{position:fixed;inset:0;background:#0009;z-index:10001;display:flex;align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal{background:var(--color-white);border-radius:12px;width:100%;max-width:400px;padding:2rem;text-align:center;box-shadow:0 25px 80px #0006;animation:modalSlideIn .2s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confirm-modal__icon{width:64px;height:64px;border-radius:50%;background:var(--color-light);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:1.75rem}.confirm-modal__title{margin:0 0 .75rem;font-size:1.25rem;color:var(--color-dark);font-weight:600}.confirm-modal__message{margin:0 0 1.5rem;color:var(--color-text-light);font-size:.95rem;line-height:1.5}.confirm-modal__actions{display:flex;gap:1rem;justify-content:center}.confirm-modal__actions .btn{flex:1;max-width:150px}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.section-title{text-align:center;color:var(--color-primary);margin-bottom:.5rem}.section-subtitle{text-align:center;color:var(--color-text-light);margin-bottom:2rem;font-size:1.1rem}.top-bar{background-color:var(--color-white);box-shadow:0 2px 8px #0000001a;position:fixed;top:0;left:0;right:0;z-index:1000}.top-bar__container{max-width:1200px;margin:0 auto;padding:1rem;display:flex;align-items:center;justify-content:space-between}.top-bar__logo{display:flex;align-items:baseline;gap:.3rem;font-family:var(--font-display)}.logo__portia{font-size:2rem;font-weight:700;color:#ff8c00}.logo__formacion{font-size:1.4rem;font-weight:400;color:#1a3a5c}.top-bar__toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.top-bar__toggle span{display:block;width:25px;height:3px;background-color:var(--color-text);margin:5px 0}.top-bar__nav{display:flex;gap:1.5rem;list-style:none;padding:0;margin:0}.top-bar__nav a{color:var(--color-text);font-weight:500;transition:color .2s ease}.top-bar__nav a:hover{color:var(--color-primary)}.top-bar__admin{padding:.5rem 1rem;border:2px solid var(--color-primary);border-radius:4px;color:var(--color-primary);font-weight:500;transition:all .2s ease}.top-bar__admin:hover{background-color:var(--color-primary);color:var(--color-white)}.home-page{padding-top:60px}.hero{min-height:65vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden}.hero__carousel{position:absolute;inset:0}.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}.hero__slide-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}.hero__slide-overlay{position:absolute;inset:0}.hero__slide.active{opacity:1}.hero__slide-label{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);font-family:var(--font-display);font-size:1.5rem;color:var(--color-white);opacity:.7}.hero__dots{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);z-index:2;display:flex;gap:.5rem}.hero__dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--color-white);background:transparent;cursor:pointer;transition:background .3s ease}.hero__dot.active,.hero__dot:hover{background:var(--color-white)}.hero__overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.3) 100%)}.hero__content{position:relative;z-index:1;padding:2rem;color:var(--color-white)}.hero__content h1{font-family:var(--font-display);font-size:4rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.hero__content h1 .logo__portia{font-size:5rem;color:#ff8c00}.hero__content h1 .logo__formacion{color:#fff;font-weight:400;font-size:2.5rem}.hero__subtitle{font-size:1.75rem;margin-bottom:.5rem;color:var(--color-secondary)}.hero__tagline{font-size:1.25rem;margin-bottom:2rem;opacity:.9}.hero__cta{margin-top:1rem}.parallax-section{padding:5rem 0;background-color:var(--color-light)}.courses__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.course-card{background-color:var(--color-white);padding:0;border-radius:8px;box-shadow:0 4px 12px #00000014;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;overflow:hidden}.course-card__image{height:160px;width:100%;position:relative}.course-card__image:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#6ba3d659,#8eb8e833);pointer-events:none}.course-card:hover{transform:translateY(-8px);box-shadow:0 8px 24px #0000001f}.course-card h3{color:var(--color-primary);margin-bottom:.5rem;padding:1.5rem 1.5rem .5rem}.course-card__desc{flex:1;margin-bottom:1rem;padding:0 1.5rem}.course-card__meta{display:flex;gap:1rem;font-size:.875rem;color:var(--color-text-light);margin-bottom:1rem;padding:0 1.5rem}.course-card .btn{margin:0 1.5rem 1.5rem}.calendar{padding:5rem 0;background:linear-gradient(135deg,var(--color-dark) 0%,#2a2a2a 100%);color:var(--color-white)}.calendar .section-title,.calendar .section-subtitle{color:var(--color-white)}.calendar__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:2rem}.calendar__item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#ffffff1a;border-radius:8px;transition:background .2s ease}.calendar__item:hover{background:#ffffff26}.calendar__date{font-weight:600;color:var(--color-secondary);white-space:nowrap}.news__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.news-card{background-color:var(--color-white);padding:1.5rem;border-radius:8px;border-left:4px solid var(--color-primary);box-shadow:0 2px 8px #0000000f}.news-card__date{font-size:.875rem;color:var(--color-text-light);display:block;margin-bottom:.5rem}.news-card h3{color:var(--color-primary);margin-bottom:.5rem;font-size:1.25rem}.pricing{padding:5rem 0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-white)}.pricing .section-title,.pricing .section-subtitle{color:var(--color-white)}.pricing__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.pricing-card{background-color:var(--color-white);padding:2rem;border-radius:12px;text-align:center;color:var(--color-text);transition:transform .3s ease}.pricing-card:hover{transform:translateY(-8px)}.pricing-card h3{color:var(--color-primary);margin-bottom:1rem}.pricing-card__price{font-size:2.5rem;font-weight:700;color:var(--color-dark);margin-bottom:1.5rem}.pricing-card ul{list-style:none;padding:0;margin-bottom:1.5rem}.pricing-card li{padding:.5rem 0;border-bottom:1px solid var(--color-border)}.pricing-card li:last-child{border-bottom:none}.contact{padding:5rem 0;background-color:var(--color-white)}.contact__info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:3rem}.contact__item h4{color:var(--color-primary);margin-bottom:.5rem}.contact__form{max-width:600px;margin:0 auto}.contact__form .form__group{margin-bottom:1rem}.contact__form label{display:block;margin-bottom:.5rem;font-weight:500}.footer{background-color:var(--color-dark);color:var(--color-light);padding:3rem 1rem 1.5rem}.footer__container{max-width:1200px;margin:0 auto}.footer__main{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}.footer__brand h3{margin-bottom:.5rem;font-family:var(--font-display)}.footer__brand h3 .logo__portia{font-size:2rem;font-weight:700;color:#ff8c00}.footer__brand h3 .logo__formacion{font-size:1.4rem;font-weight:400;color:#8eb8e8}.footer__brand p{color:var(--color-text-light)}.footer__links h4{color:var(--color-white);margin-bottom:1rem}.footer__links ul{list-style:none;padding:0}.footer__links li{margin-bottom:.5rem}.footer__links a{color:var(--color-text-light);transition:color .2s ease}.footer__links a:hover{color:var(--color-secondary)}.footer__social{display:flex;gap:1rem}.footer__social a{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;color:var(--color-white);transition:background .2s ease}.footer__social a:hover{background:var(--color-primary)}.footer__bottom{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer__copyright{font-size:.875rem;color:var(--color-text-light)}.footer__legal{display:flex;gap:1.5rem}.footer__legal a{font-size:.875rem;color:var(--color-text-light)}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);padding:1rem;padding-top:80px}.admin-login{background-color:var(--color-white);padding:2.5rem;border-radius:12px;box-shadow:0 8px 32px #0003;width:100%;max-width:400px}.admin-login h2{text-align:center;margin-bottom:1.5rem;margin-top:.5rem;color:var(--color-primary);font-size:1.1rem;font-weight:500}.admin-login__logo{display:flex;align-items:baseline;justify-content:center;gap:.3rem;font-family:var(--font-display)}.admin-login__logo .logo__portia{font-size:2rem;font-weight:700;color:#ff8c00}.admin-login__logo .logo__formacion{font-size:1.4rem;font-weight:400;color:#1a3a5c}.admin-login__field{margin-bottom:1.25rem}.admin-login__field label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.admin-login__field input{width:100%;padding:.875rem 1rem;font-size:1rem;font-family:inherit;border:2px solid var(--color-border);border-radius:6px;transition:border-color .2s ease,box-shadow .2s ease}.admin-login__field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b00001a}.admin-login__password-wrapper{position:relative}.admin-login__password-wrapper input{padding-right:2.5rem}.admin-login__toggle-password{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-light);padding:.25rem;font-size:1rem}.admin-login__toggle-password:hover{color:var(--color-primary)}.admin-login button[type=submit]{width:100%;padding:1rem;background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.admin-login button[type=submit]:hover{background-color:var(--color-primary-light)}.admin-login__error{margin-top:1rem;color:#dc3545;text-align:center;font-size:.875rem;display:none}@media(max-width:768px){.top-bar__toggle{display:block}.top-bar__nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--color-white);flex-direction:column;padding:1rem;gap:0;box-shadow:0 4px 8px #0000001a}.top-bar__nav.active{display:flex}.top-bar__nav li{padding:.75rem 0;border-bottom:1px solid var(--color-border)}.top-bar__nav li:last-child{border-bottom:none}.hero__content h1{font-size:2.5rem}.hero__subtitle{font-size:1.25rem}.pricing__grid,.courses__grid,.news__grid{grid-template-columns:1fr}.footer__bottom{flex-direction:column;text-align:center}}.course-page{padding-top:60px}.course-page__header{min-height:40vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden}.course-page__header-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.course-page__header-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#6ba3d6bf,#8eb8e899)}.course-page__header-content{position:relative;z-index:1;padding:2rem;border-radius:8px;color:var(--color-white)}.course-page__header h1{font-family:var(--font-display);font-size:3rem;color:var(--color-white);margin-bottom:1rem}.course-page__meta{display:flex;gap:2rem;justify-content:center;font-size:1.1rem}.course-page__meta span{display:flex;align-items:center;gap:.5rem}.course-page__meta i{color:var(--color-secondary)}.course-page__content{padding:4rem 1rem;background:var(--color-light)}.course-page__container{max-width:1000px;margin:0 auto}.course-page__section{background:var(--color-white);padding:2rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 2px 8px #0000000f}.course-page__section h2{color:var(--color-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-primary)}.course-page__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.course-page__info-item h4{color:var(--color-primary);font-size:.875rem;text-transform:uppercase;margin-bottom:.5rem}.course-page__info-item p{font-size:1.1rem;font-weight:500}.course-page__section ul{list-style:none;padding:0}.course-page__section li{padding:.75rem 0;border-bottom:1px solid var(--color-border)}.course-page__section li:last-child{border-bottom:none}.course-page__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.program-module{margin-bottom:1rem;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.program-module__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--color-light);cursor:pointer;transition:background .2s ease}.program-module__header:hover{background:var(--color-border)}.program-module__header h3{color:var(--color-primary);font-size:1rem;margin:0}.program-module__header i{color:var(--color-primary);transition:transform .3s ease}.program-module.collapsed .program-module__header i{transform:rotate(-90deg)}.program-module__content{max-height:1000px;overflow:hidden;transition:max-height .3s ease}.program-module.collapsed .program-module__content{max-height:0}.program-item{display:flex;gap:1rem;padding:.75rem 1.25rem;border-top:1px solid var(--color-border)}.program-item__num{font-weight:600;color:var(--color-primary);min-width:40px}.program-item__text{color:var(--color-text)}.legal-page{padding-top:80px;min-height:100vh;background-color:var(--color-light)}.legal-page__container{max-width:800px;margin:0 auto;padding:3rem 1.5rem;background:var(--color-white);box-shadow:0 2px 8px #0000000d}.legal-page h1{font-family:var(--font-display);font-size:2.5rem;color:var(--color-primary);margin-bottom:.5rem;text-align:center}.legal-page__date{text-align:center;color:var(--color-text-light);font-size:.875rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.legal-page__section{margin-bottom:2rem}.legal-page__section h2{font-size:1.25rem;color:var(--color-dark);margin-bottom:1rem;padding-top:1rem}.legal-page__section p{line-height:1.7;color:var(--color-text);margin-bottom:1rem}.legal-page__section ul,.legal-page__section ol{margin-left:1.5rem;margin-bottom:1rem}.legal-page__section li{line-height:1.7;margin-bottom:.5rem}.legal-page__section a{color:var(--color-primary);text-decoration:none}.legal-page__section a:hover{text-decoration:underline}.cookies-table{overflow-x:auto;margin:1.5rem 0}.cookies-table table{width:100%;border-collapse:collapse;font-size:.875rem}.cookies-table th,.cookies-table td{padding:.75rem;text-align:left;border:1px solid var(--color-border)}.cookies-table th{background:var(--color-light);font-weight:600;color:var(--color-dark)}.cookies-table tr:hover{background:var(--color-light)}
