*{margin:0;padding:0;box-sizing:border-box}body{padding-top:3rem;font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.layout{min-height:100vh}.main-content{padding-top:80px}.body-home{background-color:#fff;color:#000;line-height:1.6}.body-course-detail{background-color:#e8dff5;color:#000;line-height:1.3}.body-favorites{background-color:#e8dff5;color:#000;line-height:1.6}.body-agenda,.body-auth,.body-account{background-color:#fff;color:#000;line-height:1.6}.header{padding:1rem 2rem;border-bottom:1px solid #e0e0e0;background-color:#fff;position:fixed;top:0;left:0;right:0;z-index:1000}.header-container{margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;position:relative}.search-section{order:1;display:flex;align-items:center;flex:0 0 auto;position:relative;z-index:100}.logo{order:2;flex:1;text-align:center;position:absolute;left:50%;transform:translate(-50%);pointer-events:auto}.header-icons{order:3;margin-left:auto}.hamburger-menu{order:4}.search-input-container{display:flex;align-items:flex-start;position:relative;max-width:40px;width:40px;min-height:40px;opacity:1;overflow:visible;background-color:transparent;border-radius:12px;border:1px solid transparent;transition:max-width .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,width .3s cubic-bezier(.4,0,.2,1),background-color .3s ease,border-color .3s ease,box-shadow .3s ease;white-space:nowrap;z-index:1000;cursor:pointer}.search-input-container.active{max-width:450px;width:450px;opacity:1;pointer-events:all;border-color:#9b7ed8;background-color:#fff;box-shadow:0 4px 12px #00000026;cursor:default;overflow:visible}.search-icon{position:absolute;left:12px;color:#333;pointer-events:auto;z-index:1;width:20px;height:20px;transition:color .2s ease,transform .2s ease;flex-shrink:0}.search-icon:hover{color:#9b7ed8}.search-input-container.active .search-icon{color:#9b7ed8;pointer-events:none}.search-input{width:100%;padding:12px 16px 12px 44px;border:none;border-radius:12px;font-size:15px;outline:none;transition:all .2s;background:transparent;color:#333;font-family:Montserrat,sans-serif;opacity:0;pointer-events:none}.search-input-container.active .search-input{opacity:1;pointer-events:all}.search-input::placeholder{color:#999}.search-input:focus{outline:none}.search-input-container:focus-within{box-shadow:0 4px 16px #9b7ed833;border-color:#9b7ed8}.search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background-color:#fff;border-radius:12px;box-shadow:0 4px 16px #00000026;border:1px solid #e0e0e0;max-height:400px;overflow-y:auto;z-index:1001;margin-top:4px}.search-dropdown-item{padding:12px 16px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f0f0f0}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item:hover{background-color:#f5f5f5}.search-result-title{font-size:15px;font-weight:600;color:#000;margin-bottom:4px}.search-result-subtitle{font-size:13px;color:#666}.search-dropdown-more{padding:12px 16px;cursor:pointer;text-align:center;font-weight:600;color:#9b7ed8;transition:background-color .2s ease;border-top:1px solid #e0e0e0}.search-dropdown-more:hover{background-color:#f0e8ff}.logo{font-size:24px;font-weight:700;color:#000;cursor:pointer;transition:color .2s}.logo:hover{color:#9b7ed8}.header-icons{display:flex;align-items:center;gap:1.5rem}.account-icon-wrapper{position:relative;display:inline-block}.account-icon-link{display:flex;align-items:center;text-decoration:none;color:inherit}.account-icon-link:hover{opacity:.8}.account-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 6px #0000001a;padding:.5rem 0;min-width:150px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .2s ease,visibility .2s ease,transform .2s ease;z-index:1000}.account-icon-wrapper:hover .account-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.logout-btn{width:100%;padding:.75rem 1rem;background-color:transparent;border:none;text-align:left;cursor:pointer;font-size:.95rem;color:#333;transition:background-color .2s ease}.logout-btn:hover{background-color:#f5f5f5}.icon{color:#333;cursor:pointer;transition:color .2s}.icon:hover{color:#9b7ed8}.hamburger-menu{display:none;flex-direction:column;justify-content:space-around;width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.hamburger-menu span{width:100%;height:3px;background-color:#333;border-radius:3px;transition:all .3s ease;transform-origin:center}.hamburger-menu:hover span{background-color:#9b7ed8}.hamburger-menu.active span:nth-child(1){transform:rotate(45deg) translate(8px,8px)}.hamburger-menu.active span:nth-child(2){opacity:0}.hamburger-menu.active span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:999}.sidebar-overlay.active{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;right:-320px;width:320px;height:100vh;background-color:#fff;box-shadow:-2px 0 10px #0000001a;transition:right .3s ease;z-index:1000;overflow-y:auto}.sidebar.active{right:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.sidebar-header h2{font-size:1.5rem;font-weight:600;color:#000;margin:0}.sidebar-close{background:none;border:none;cursor:pointer;padding:.5rem;color:#333;transition:color .2s;display:flex;align-items:center;justify-content:center}.sidebar-close:hover{color:#9b7ed8}.sidebar-menu{display:flex;flex-direction:column;padding:1rem 0}.sidebar-menu-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;color:#333;text-decoration:none;transition:background-color .2s,color .2s;border-left:3px solid transparent;cursor:pointer}.sidebar-menu-item:hover{background-color:#f5f5f5;color:#9b7ed8;border-left-color:#9b7ed8}.sidebar-icon{flex-shrink:0;color:currentColor;width:24px;height:24px}.sidebar-menu-item span{font-size:1rem;font-weight:500}.sidebar-search{padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0}.sidebar-search-container{display:flex;align-items:center;gap:.75rem;background-color:#f5f5f5;border-radius:12px;padding:.75rem 1rem}.sidebar-search-icon{flex-shrink:0;color:#666;width:20px;height:20px}.sidebar-search-input{flex:1;border:none;background:transparent;outline:none;font-size:1rem;color:#333;font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.sidebar-search-input::placeholder{color:#999}@media (max-width: 768px){.header-icons{display:none}.hamburger-menu{display:flex}.header-container{gap:1rem}.search-section{order:1}.logo{font-size:20px;order:2;position:absolute;left:50%;transform:translate(-50%)}.hamburger-menu{order:3;margin-left:auto}.search-input-container{max-width:36px;width:36px;height:36px;border-radius:10px}.search-input-container.active{max-width:calc(100vw - 120px);width:calc(100vw - 120px)}.search-input{padding:10px 14px 10px 40px;font-size:14px}.search-icon{left:10px;width:18px;height:18px}.search-dropdown{max-height:300px;border-radius:10px}.search-dropdown-item{padding:10px 14px}.search-result-title{font-size:14px}.search-result-subtitle{font-size:12px}}.hero{background-color:#c486fb;padding:6rem 2rem;margin:2rem;border-radius:16px}.hero-content{max-width:800px;margin:0 auto;text-align:center}.hero-title{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:2rem}.hero-search{display:flex;align-items:center;background:#fff;border-radius:30px;padding:4px;box-shadow:0 2px 8px #0000001a;max-width:600px;margin:0 auto}.hero-search-icon{margin-left:16px;color:#666}.hero-search-input{flex:1;padding:16px;border:none;outline:none;font-size:16px;background:transparent}.features{max-width:1200px;margin:3rem auto;padding:0 2rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.feature-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 2px 12px #00000014;border:1px solid #f0f0f0;text-align:center;transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.feature-icon{display:flex;justify-content:center;margin-bottom:1.5rem;color:#333}.feature-icon svg{stroke-width:2}.feature-title{font-size:2rem;font-weight:700;color:#000;margin-bottom:1rem}.feature-description{font-size:1rem;color:#333;line-height:1.6}.promo-banner{background-color:#e2c2ff;padding:3rem 2rem;margin:2rem;border-radius:16px}.promo-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:3rem}.promo-text{flex:1}.promo-title{font-size:2rem;font-weight:700;color:#000;margin-bottom:1rem}.promo-description{font-size:1.1rem;color:#333}.promo-image-placeholder{width:300px;height:200px;background-color:#d0d0d0;border-radius:12px;flex-shrink:0}@media (max-width: 768px){.header-container{flex-wrap:nowrap}}.hero-title{font-size:1.8rem}.features{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem}.feature-card{padding:2rem 1.5rem}.feature-title{font-size:1.5rem}.promo-content{flex-direction:column;text-align:center}.promo-image-placeholder{width:100%;max-width:400px}} @media (min-width: 601px) and (max-width: 1024px){.features{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media (min-width: 1025px){.features{grid-template-columns:repeat(3,1fr);gap:2rem}}.course-detail-container{max-width:1200px;margin:0 auto;padding:2rem}.course-overview{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem;padding:2rem 0rem;border-radius:16px}.course-info{display:flex;flex-direction:column}.course-header{display:flex;justify-content:space-between;margin-bottom:1.5rem}.course-title-section{flex:1}.course-category{font-size:.9rem;font-weight:700;color:#333;margin-bottom:.5rem}.course-main-title{font-size:2rem;font-weight:700;color:#000;margin-bottom:.5rem}.course-title-wrapper{display:flex;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.course-title{font-size:2rem;font-weight:700;color:#000;margin:0;flex:1}.course-subtitle{font-size:1rem;font-weight:700;color:#333}.favorite-btn{background:none;border:none;cursor:pointer;padding:.5rem;color:#333;transition:color .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.25rem}.favorite-btn:hover{color:#9b7ed8}.course-description{font-size:1rem;color:#333;line-height:1.6}.course-image{display:flex;align-items:center;justify-content:center}.course-image-placeholder{width:100%;height:300px;background:linear-gradient(135deg,#fff,#f0f0f0);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#666;font-size:.9rem}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.info-card{background-color:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.info-label{font-size:.9rem;color:#333;margin-bottom:.5rem}.info-value{font-size:1.5rem;font-weight:700;color:#000}.professions-section{background-color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.section-title{font-size:1.3rem;font-weight:700;color:#000;margin-bottom:1.5rem}.professions-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.professions-column{list-style:none;padding:0}.professions-column li{padding:.5rem 0;color:#333;border-bottom:1px solid rgba(0,0,0,.1)}.professions-column li:last-child{border-bottom:none}.bottom-section{display:grid;grid-template-columns:1fr 2fr;gap:2rem}.institutions-section{background-color:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.institutions-list{list-style:none;padding:0}.institution-item{padding:.75rem 0;color:#333;border-bottom:1px solid rgba(0,0,0,.1);cursor:pointer;transition:all .2s}.institution-item:hover{color:#9b7ed8;padding-left:.5rem}.institution-item.active{color:#9b7ed8;font-weight:800;padding-left:.5rem}.institution-item:last-child{border-bottom:none}.hva-details{background-color:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.institution-header{display:flex;gap:2rem;margin-bottom:2rem}.institution-header-content{flex:1}.institution-satisfaction{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:150px;padding:1rem;border-radius:12px}.satisfaction-label{font-size:.875rem;color:#666;margin-bottom:.5rem;text-align:center}.satisfaction-value{font-size:2.5rem;font-weight:700;color:#000;margin-bottom:1rem}.institution-website-btn{display:inline-block;padding:.75rem 1.5rem;background-color:#9b7ed8;color:#fff;text-decoration:none;border-radius:8px;font-size:.9rem;font-weight:600;transition:background-color .2s,transform .2s;text-align:center;width:100%;box-sizing:border-box}.institution-website-btn:hover{background-color:#8b6dc8;transform:translateY(-2px)}.institution-website-btn:active{transform:translateY(0)}.hva-description{font-size:1rem;color:#333;line-height:1.6;margin-bottom:1.5rem}.hva-location{font-size:1rem;color:#000;margin-bottom:1rem}.event-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}.event-card{background-color:#e8dff5;padding:1.5rem;border-radius:12px;display:flex;flex-direction:column;min-height:275px}.event-title{font-size:1rem;font-weight:600;color:#000;margin-bottom:.75rem}.event-date{display:flex;flex-direction:row;align-items:baseline;gap:.5rem;margin-bottom:1rem}.event-day{font-size:2rem;font-weight:700;color:#000;line-height:1}.event-month{font-size:.9rem;color:#333}.event-time{font-size:.9rem;color:#666;margin:auto 0;font-weight:500;text-align:center}.event-btn{width:100%;padding:.75rem;background-color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;color:#000;cursor:pointer;transition:background-color .2s}.event-btn:hover{background-color:#f0f0f0}.event-btn-added{background-color:#9b7ed8;color:#fff}.event-btn-added:hover{background-color:#8a6dc7}.more-dates{text-align:right;margin-top:1rem}.more-dates-link{color:#000;text-decoration:none;font-size:.9rem;font-weight:500}.more-dates-link:hover{text-decoration:underline}@media (max-width: 968px){.course-overview,.bottom-section,.professions-list,.event-cards{grid-template-columns:1fr}.institution-header{flex-direction:column;gap:1.5rem}.institution-satisfaction{min-width:100%}}.favorites-container{max-width:1500px;margin:0 auto;padding:3rem 2rem}.favorites-title{font-size:2.5rem;font-weight:700;color:#000;text-align:center;margin-bottom:3rem}.favorites-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem;max-width:1400px;margin:0 auto}.favorites-grid .auth-required-message{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 300px);padding:4rem 2rem}.favorites-grid .favorite-card:nth-child(5){grid-column:2 / 4}.favorite-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #00000014;transition:transform .2s,box-shadow .2s;cursor:pointer;box-sizing:border-box;border:5px solid transparent}.favorite-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.favorite-card-image{position:relative;width:100%;height:200px}.favorite-card-image-placeholder{width:100%;height:100%;background-color:#d0d0d0}.favorite-heart-icon{position:absolute;top:12px;right:12px;color:#000;width:24px;height:24px;cursor:pointer;z-index:10}.favorite-card-content{padding:1.5rem}.favorite-card-title{font-size:1.1rem;font-weight:600;color:#000;line-height:1.4;text-align:center}@media (max-width: 1024px){.favorites-grid{grid-template-columns:repeat(3,1fr)}.favorites-grid .favorite-card:nth-child(5){grid-column:1 / 3}}@media (max-width: 768px){.favorites-title{font-size:2rem}.favorites-grid{grid-template-columns:1fr}.favorites-grid .favorite-card:nth-child(5){grid-column:1}}.courses-container{max-width:1200px;margin:0 auto;padding:3rem 2rem}.courses-title{font-size:2.5rem;font-weight:700;color:#000;text-align:center;margin-bottom:3rem}.courses-filters{margin-bottom:2rem}.courses-search{display:flex;align-items:center;max-width:600px;margin:0 auto 2rem;position:relative;background:#fff;border:1px solid #d0d0d0;border-radius:12px;padding:4px}.courses-search .search-icon{position:absolute;left:16px;color:#666;pointer-events:none}.courses-search-input{flex:1;padding:12px 16px 12px 48px;border:none;outline:none;font-size:16px;background:transparent;font-family:Montserrat,sans-serif}.courses-search-input:focus{border:none}.filters-row{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;max-width:1200px;margin:0 auto}.filter-group{display:flex;align-items:center;gap:1rem}.filter-label{font-size:.9rem;font-weight:600;color:#333;white-space:nowrap}.filter-buttons{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;border:1.5px solid #d0d0d0;background-color:#fff;border-radius:8px;font-size:.9rem;font-weight:500;color:#333;cursor:pointer;transition:all .2s;font-family:Montserrat,sans-serif}.filter-btn:hover{border-color:#9b7ed8;color:#9b7ed8}.filter-btn.active{background-color:#9b7ed8;border-color:#9b7ed8;color:#fff}.filter-select{padding:.5rem 1rem;border:1.5px solid #d0d0d0;background-color:#fff;border-radius:8px;font-size:.9rem;font-weight:500;color:#333;cursor:pointer;transition:all .2s;font-family:Montserrat,sans-serif;min-width:200px}.filter-select:focus{outline:none;border-color:#9b7ed8}.view-toggle{display:flex;gap:.5rem;margin-left:auto}.view-btn{padding:.5rem;border:1.5px solid #d0d0d0;background-color:#fff;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:#333}.view-btn:hover{border-color:#9b7ed8;color:#9b7ed8}.view-btn.active{background-color:#9b7ed8;border-color:#9b7ed8;color:#fff}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.courses-grid.courses-list{grid-template-columns:1fr}.courses-grid.courses-list .course-card{display:flex;flex-direction:row;max-width:100%}.courses-grid.courses-list .course-card-image{width:250px;min-width:250px;height:200px;flex-shrink:0}.courses-grid.courses-list .course-card-content{flex:1;padding:1.5rem 2rem;display:flex;flex-direction:column;justify-content:center}.courses-grid.courses-list .course-card-description{-webkit-line-clamp:2;line-clamp:2}.course-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #00000014;border:1px solid #f0f0f0;transition:transform .2s,box-shadow .2s;cursor:pointer}.course-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.course-card-image{width:100%;height:200px;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center;overflow:hidden}.course-card-image img{width:100%;height:100%;object-fit:cover}.course-card-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8dff5,#f0f0f0);color:#666}.course-card-content{padding:1.5rem}.course-card-category{font-size:.875rem;color:#666;margin-bottom:.5rem;font-weight:500}.course-card-title{font-size:1.25rem;font-weight:700;color:#000;margin-bottom:.5rem;line-height:1.3}.course-card-subtitle{font-size:.9rem;color:#666;margin-bottom:1rem}.course-card-description{font-size:.95rem;color:#333;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:1rem;min-height:4.5rem}.course-card-footer{display:flex;align-items:center;gap:1rem;margin-top:auto;padding-top:1rem;border-top:1px solid #f0f0f0}.course-card-institution,.course-card-satisfaction{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#666}.course-card-institution svg,.course-card-satisfaction svg{flex-shrink:0;color:#9b7ed8}.course-card-satisfaction{margin-left:auto;font-weight:600;color:#333}.no-courses{grid-column:1 / -1;text-align:center;padding:3rem;color:#666}.pagination{display:flex;justify-content:center;align-items:center;gap:2rem;margin-top:3rem;padding:2rem 0}.pagination-btn{padding:.75rem 1.5rem;border:1.5px solid #d0d0d0;background-color:#fff;border-radius:8px;font-size:1rem;font-weight:600;color:#333;cursor:pointer;transition:all .2s;font-family:Montserrat,sans-serif;min-width:120px}.pagination-btn:hover:not(:disabled){border-color:#9b7ed8;color:#9b7ed8;background-color:#f5f5f5}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f5f5f5}.pagination-info{display:flex;flex-direction:column;align-items:center;gap:.25rem;font-size:.95rem;color:#333}.pagination-count{font-size:.85rem;color:#666}@media (max-width: 768px){.pagination{flex-direction:column;gap:1rem}.pagination-btn{width:100%;max-width:200px}}@media (max-width: 968px){.filters-row{flex-direction:column;align-items:stretch}.filter-group{width:100%;justify-content:space-between}.filter-select{flex:1;min-width:auto}.view-toggle{margin-left:0;justify-content:flex-end}.courses-grid.courses-list .course-card{flex-direction:column}.courses-grid.courses-list .course-card-image{width:100%;min-width:auto}}@media (max-width: 768px){.courses-title{font-size:2rem}.courses-grid{grid-template-columns:1fr}.filter-buttons{flex-wrap:wrap}}.agenda-container{max-width:1500px;margin:0 auto;padding:3rem 2rem}.agenda-title{font-size:2.5rem;font-weight:700;color:#000;text-align:center;margin-bottom:3rem}.agenda-content{display:grid;grid-template-columns:3fr 2fr;gap:2rem}.calendar-section{background:#e8dff5;border-radius:16px;padding:1rem;box-shadow:0 10px 25px #0003}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.calendar-nav-btn{background:none;border:none;cursor:pointer;padding:.5rem;color:#333;transition:color .2s;display:flex;align-items:center;justify-content:center;border-radius:8px}.calendar-nav-btn:hover{color:#9b7ed8;background-color:#f0f0f0}.calendar-month-year{font-size:1.5rem;font-weight:700;color:#000}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-day-header{text-align:center;font-weight:600;color:#666;padding:.75rem 0;font-size:.9rem}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:.5rem;border-radius:8px;cursor:pointer;transition:background-color .2s;position:relative;background-color:#f9f9f9}.calendar-day:hover{background-color:#f0f0f0}.calendar-day.empty{background-color:transparent;cursor:default}.calendar-day.today{background-color:#9b7ed8;font-weight:700}.calendar-day.has-events{border:2px solid #9b7ed8}.day-number{font-size:.9rem;color:#000}.event-indicator{width:6px;height:6px;background-color:#9b7ed8;border-radius:50%;margin-top:.25rem}.events-section{background:#e8dff5;border-radius:16px;padding:1rem;box-shadow:0 10px 25px #0003;height:fit-content}.events-title{font-size:1.5rem;font-weight:700;color:#000;margin-bottom:1.5rem}.events-list{display:flex;flex-direction:column;gap:1rem}.event-item{display:flex;gap:1rem;padding:1rem;border-radius:12px;background-color:#f9f9f9;transition:background-color .2s;cursor:pointer;position:relative}.event-item:hover{background-color:#f0f0f0}.event-item:active:not(:has(.event-delete-btn:active)){background-color:#e8e8e8}.event-item:has(.event-delete-btn:active){background-color:#f9f9f9!important}.event-delete-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;cursor:pointer;padding:.5rem;color:#999;transition:color .2s,background-color .2s,transform .2s;display:flex;align-items:center;justify-content:center;border-radius:4px;z-index:10}.event-delete-btn:hover{color:#c33;transform:scale(1.1)}.event-delete-btn:active{transform:scale(.95)}.event-delete-btn svg{width:18px;height:18px}.event-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:80px;min-width:80px;padding:.75rem;background-color:#e8dff5;border-radius:8px;flex-shrink:0}.event-day{font-size:1.5rem;font-weight:700;color:#000;line-height:1}.event-month{font-size:.75rem;color:#666;margin-top:.25rem}.event-details{flex:1}.event-title{font-size:1rem;font-weight:600;color:#000;margin-bottom:.25rem}.event-description{font-size:.875rem;color:#666}.no-events{text-align:center;padding:2rem;color:#666}@media (max-width: 968px){.agenda-content{grid-template-columns:1fr}.calendar-grid{gap:.25rem}.calendar-day{padding:.25rem}.day-number{font-size:.8rem}}.auth-container{max-width:500px;margin:6rem auto 2rem;padding:0 2rem}.auth-card{background-color:#fff;border-radius:16px;padding:3rem;box-shadow:0 2px 8px #0000001a}.auth-title{font-size:2rem;font-weight:700;color:#000;margin-bottom:.5rem}.auth-subtitle{font-size:1rem;color:#666;margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.9rem;font-weight:600;color:#333}.form-input{padding:12px 16px;border:1px solid #d0d0d0;border-radius:8px;font-size:1rem;font-family:Montserrat,sans-serif;outline:none;transition:border-color .2s}.form-input:focus{border-color:#9b7ed8}.form-textarea{padding:12px 16px;border:1px solid #d0d0d0;border-radius:8px;font-size:1rem;font-family:Montserrat,sans-serif;outline:none;resize:vertical;transition:border-color .2s}.form-textarea:focus{border-color:#9b7ed8}.form-error{display:none;padding:12px;background-color:#fee;color:#c33;border-radius:8px;font-size:.9rem}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;font-family:Montserrat,sans-serif;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;text-align:center}.btn-primary{background-color:#9b7ed8;color:#fff}.btn-primary:hover{background-color:#8a6dc7}.btn-secondary{background-color:#e0e0e0;color:#333}.btn-secondary:hover{background-color:#d0d0d0}.btn-full{width:100%}.btn-small{padding:8px 16px;font-size:.9rem}.btn-link{background:none;color:#9b7ed8;padding:0;text-decoration:underline}.btn-link:hover{color:#8a6dc7}.auth-footer{margin-top:2rem;text-align:center;font-size:.9rem;color:#666}.auth-link{color:#9b7ed8;text-decoration:none;font-weight:600}.auth-link:hover{text-decoration:underline}.role-selector{display:flex;gap:1rem;margin-bottom:2rem}.role-btn{flex:1;padding:1rem;border:2px solid #d0d0d0;border-radius:8px;background-color:#fff;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-family:Montserrat,sans-serif;font-size:.9rem;font-weight:600;color:#333}.role-btn:hover{border-color:#9b7ed8}.role-btn.active{border-color:#9b7ed8;background-color:#f0e8ff;color:#9b7ed8}.role-btn svg{width:32px;height:32px}.acc-container{max-width:1400px;margin:6rem auto 2rem}.account-content{background-color:#fff;border-radius:16px;padding:0;box-shadow:0 2px 8px #0000001a;overflow:hidden}.acc-layout{display:flex;gap:0;min-height:calc(100vh - 8rem)}.acc-sidebar{width:250px;flex-shrink:0;padding:2rem 1.5rem;background-color:#fff}.acc-header-info{padding:0rem 2rem 1.5rem;background-color:#fff;border-bottom:1px solid #e0e0e0}.acc-header-name{font-size:1.75rem;font-weight:700;color:#000;margin-bottom:.5rem}.acc-header-role{font-size:.9rem;color:#666;margin-bottom:.25rem}.acc-sidebar-nav{position:relative}.acc-nav-separator{position:absolute;left:0;top:0;bottom:0;width:3px;background-color:#e8dff5}.acc-nav-item{display:block;width:100%;padding:.75rem 1rem .75rem 1.5rem;border:none;background:none;text-align:left;font-family:Montserrat,sans-serif;font-size:1rem;font-weight:500;color:#333;cursor:pointer;transition:all .2s;margin-bottom:.25rem}.acc-nav-item:hover{color:#9b7ed8}.acc-nav-item.active{color:#9b7ed8;font-weight:600}.acc-main-content{flex:1;padding:2rem;background-color:#fff}.acc-tab-content{display:none}.acc-tab-content.active{display:block}.account-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e0e0e0}.account-info{flex:1}.account-name{font-size:2rem;font-weight:700;color:#000;margin-bottom:.5rem}.account-role{font-size:1rem;color:#666;margin-bottom:.25rem}.account-detail{font-size:.9rem;color:#999}.header-actions{display:flex;gap:1rem}.account-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0}.tab-btn{padding:1rem 1.5rem;border:none;background:none;font-family:Montserrat,sans-serif;font-size:1rem;font-weight:600;color:#666;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s}.tab-btn:hover{color:#9b7ed8}.tab-btn.active{color:#9b7ed8;border-bottom-color:#9b7ed8}.tab-content{display:none}.tab-content.active{display:block}.account-section{margin-bottom:2rem}.section-title{font-size:1.5rem;font-weight:700;color:#000;margin-bottom:1.5rem}.empty-state{padding:3rem;text-align:center;color:#999;font-style:italic}.favorites-list{display:flex;flex-direction:column;gap:1rem}.favorite-item{padding:1.5rem;border:1px solid #e0e0e0;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.acc-favorites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.acc-favorite-card{background-color:#e8dff5;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer;box-sizing:border-box;border:5px solid transparent}.acc-favorite-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.acc-favorite-card-content{background-color:#e8dff5;padding:1rem 1.5rem}.acc-favorite-card-title{font-size:1.1rem;font-weight:600;color:#000;margin:0;text-align:center}.acc-favorite-card-footer{background-color:#d0d0d0;padding:5rem 1.5rem}.acc-favorite-card-label{font-size:.9rem;font-weight:500;color:#333}.favorite-item-title{font-size:1.1rem;font-weight:600;color:#000;margin-bottom:.25rem}.favorite-item-category{font-size:.9rem;color:#666;margin-bottom:.5rem}.agenda-item-time{font-size:.9rem;color:#999;margin-top:.25rem}.agenda-list{display:flex;flex-direction:column;gap:1.5rem}.agenda-item{padding:1.5rem;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:1.5rem}.acc-agenda-event-card{background-color:#fff;border-radius:12px;padding:1.5rem;display:flex;gap:1.5rem;box-shadow:0 2px 4px #0000000d}.acc-agenda-event-date{flex-shrink:0}.acc-date-box{background-color:#9b7ed8;color:#fff;border-radius:8px;padding:1rem;min-width:70px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:110px}.acc-date-day{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:.25rem}.acc-date-month{font-size:.85rem;text-transform:capitalize;opacity:.9}.acc-agenda-event-content{flex:1;max-width:40%}.acc-agenda-event-title{font-size:1.1rem;font-weight:700;color:#000;margin-bottom:.5rem}.acc-agenda-event-program{font-size:.95rem;color:#333;margin-bottom:.25rem}.acc-agenda-event-institution{font-size:.9rem;color:#666;margin-bottom:1rem}.acc-agenda-event-note{margin-left:1rem;padding-left:1rem;border-left:1px solid #e0e0e0}.acc-note-label{font-weight:700;font-size:.9rem;color:#000;margin-bottom:.5rem}.acc-note-content{font-size:.9rem;color:#333;line-height:1.5;margin-bottom:.5rem}.acc-note-link{color:#9b7ed8;text-decoration:none;font-weight:500;font-size:.9rem;transition:color .2s}.acc-note-link:hover{color:#7b5eb8;text-decoration:underline}.agenda-item-date{display:flex;flex-direction:column;align-items:center;min-width:80px}.agenda-day{font-size:1.5rem;font-weight:700;color:#9b7ed8}.agenda-month{font-size:.9rem;color:#666;text-transform:capitalize}.agenda-item-content{flex:1}.agenda-item-title{font-size:1.1rem;font-weight:600;color:#000;margin-bottom:.5rem}.agenda-item-details{font-size:.9rem;color:#666;margin-bottom:.25rem}.agenda-item-location{font-size:.9rem;color:#999}.acc-notes-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.acc-agenda-list{display:flex;flex-direction:column;gap:1.5rem}.note-item{padding:1.5rem;border:1px solid #e0e0e0;border-radius:8px;background-color:#fafafa}.acc-note-card{background-color:#e8dff5;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.acc-note-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.acc-note-card-author{font-weight:700;font-size:1rem;color:#000}.acc-note-card-date{font-size:.9rem;color:#666}.acc-note-card-content{color:#333;line-height:1.6}.acc-note-card-content p{margin-bottom:.75rem}.acc-note-card-link{color:#9b7ed8;text-decoration:none;font-weight:500;font-size:.9rem;transition:color .2s}.acc-note-card-link:hover{color:#7b5eb8;text-decoration:underline}.note-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem}.note-author{font-weight:600;color:#333}.note-date{color:#999}.note-visibility{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600}.note-visibility.visible{background-color:#e8f5e9;color:#2e7d32}.note-visibility.hidden{background-color:#fff3e0;color:#e65100}.note-content{color:#333;line-height:1.6;margin-bottom:.75rem}.note-actions{display:flex;gap:1rem}.students-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.search-box{max-width:300px}.search-input-small{width:100%;padding:10px 16px;border:1px solid #d0d0d0;border-radius:8px;font-size:.9rem;font-family:Montserrat,sans-serif;outline:none}.search-input-small:focus{border-color:#9b7ed8}.students-list{display:flex;flex-direction:column;gap:1rem}.student-card{padding:1.5rem;border:1px solid #e0e0e0;border-radius:8px;display:flex;justify-content:space-between;align-items:center;background-color:#fff;transition:box-shadow .2s}.student-card:hover{box-shadow:0 2px 8px #0000001a}.student-info{flex:1}.student-name{font-size:1.1rem;font-weight:600;color:#000;margin-bottom:.5rem}.student-details{font-size:.9rem;color:#666;margin-bottom:.25rem}.student-email{font-size:.9rem;color:#999}.student-actions{display:flex;gap:1rem}.overview-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{padding:2rem;border:1px solid #e0e0e0;border-radius:8px;text-align:center;background-color:#fff}.stat-value{font-size:2.5rem;font-weight:700;color:#9b7ed8;margin-bottom:.5rem}.stat-label{font-size:1rem;color:#666}.acc-profile-panel{background-color:#e8dff5;border-radius:12px;padding:2rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem}.acc-profile-column{display:flex;flex-direction:column;gap:1rem}.acc-profile-field{display:flex;flex-direction:column;gap:.25rem}.acc-profile-label{font-weight:600;font-size:1.1rem;color:#333}.acc-profile-value{font-size:1rem;color:#000}.acc-profile-subjects{display:flex;flex-direction:column;gap:.25rem}.acc-profile-subject{font-size:1rem;color:#000}.student-detail-tabs{margin-bottom:1rem}@media (max-width: 968px){.account-layout{flex-direction:column}.account-sidebar{width:100%;border-bottom:1px solid #e0e0e0}.account-nav-separator{display:none}.account-sidebar-nav{display:flex;gap:1rem;overflow-x:auto;padding-bottom:1rem}.account-nav-item{white-space:nowrap;padding:.5rem 1rem;margin-bottom:0}.profile-panel{grid-template-columns:1fr}.favorites-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:2000;align-items:center;justify-content:center;padding:2rem}.modal-content{background-color:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 16px #0003}.modal-large{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1rem;border-bottom:1px solid #e0e0e0}.modal-header h2{font-size:1.5rem;font-weight:700;color:#000}.modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#000}.modal-body{padding:2rem}.acc-note-event-info{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e0e0e0}.acc-note-event-details h3{font-size:1.2rem;font-weight:700;color:#000;margin-bottom:.5rem}.acc-note-event-details p{font-size:.95rem;color:#666;margin-bottom:.25rem}.acc-note-event-date{font-size:.9rem;color:#999;margin-top:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-container{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e5e5}.modal-title{font-size:1.5rem;font-weight:600;color:#333;margin:0}.modal-close{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:#666;transition:color .2s;border-radius:4px}.modal-close:hover{color:#333;background-color:#f5f5f5}.modal-body{padding:1.5rem}.modal-message{font-size:1rem;color:#666;line-height:1.6;margin:0}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e5e5e5}.modal-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:Montserrat,sans-serif}.modal-btn-cancel{background-color:#f5f5f5;color:#333}.modal-btn-cancel:hover{background-color:#e5e5e5}.modal-btn-confirm{background-color:#8b5cf6;color:#fff}.modal-btn-confirm:hover{background-color:#7c3aed}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.profile-info{display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;padding:1rem 0;border-bottom:1px solid #e0e0e0}.info-label{font-weight:600;color:#666;min-width:120px}.info-value{color:#000}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.notes-section{display:flex;flex-direction:column;gap:2rem}.add-note-section{padding:1.5rem;border:1px solid #e0e0e0;border-radius:8px;background-color:#fafafa}.add-note-section h3{font-size:1.1rem;font-weight:600;color:#000;margin-bottom:1rem}.auth-required-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:400px}.auth-required-message svg{color:#9b7ed8;margin-bottom:1.5rem}.auth-required-message h2{font-size:1.5rem;font-weight:700;color:#000;margin-bottom:1rem}.auth-required-message p{font-size:1rem;color:#666;margin-bottom:2rem;max-width:400px}@media (max-width: 768px){.agenda-title{font-size:2rem}.calendar-section,.events-section{padding:1.5rem}}
