:root{--color-primary: #003876;--color-primary-dark: #002855;--color-primary-light: #e8f0f8;--color-primary-lighter: #f5f8fc;--color-accent: #0066b3;--color-accent-light: #4d9fd6;--color-success: #059669;--color-warning: #d97706;--color-error: #dc2626;--color-gray-50: #fafafa;--color-gray-100: #f5f5f5;--color-gray-200: #e5e5e5;--color-gray-300: #d4d4d4;--color-gray-400: #a3a3a3;--color-gray-500: #737373;--color-gray-600: #525252;--color-gray-700: #404040;--color-gray-800: #262626;--color-gray-900: #171717;--color-white: #ffffff;--color-black: #000000;--font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans KR", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .04);--shadow-md: 0 4px 12px rgb(0 0 0 / .08);--shadow-lg: 0 8px 24px rgb(0 0 0 / .12);--shadow-xl: 0 16px 48px rgb(0 0 0 / .16);--max-width: 1280px;--header-height: 60px;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-800);background-color:var(--color-white);min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}img{max-width:100%;height:auto}#app{min-height:100vh;display:flex;flex-direction:column}main{flex:1;padding:var(--spacing-6);max-width:var(--max-width);width:100%;margin:0 auto}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-4)}.header{background-color:var(--color-white);border-bottom:1px solid var(--color-gray-100);height:var(--header-height);position:sticky;top:0;z-index:100}.header__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-6);height:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-8)}.header__logo{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);display:flex;align-items:center;gap:var(--spacing-2);white-space:nowrap}.header__logo:hover{text-decoration:none;color:var(--color-primary-dark)}.header__logo-icon{width:28px;height:28px;background:var(--color-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm)}.header__search{flex:1;max-width:480px;position:relative}.header__search-input{width:100%;padding:var(--spacing-2) var(--spacing-4);padding-left:var(--spacing-10);font-size:var(--font-size-sm);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);background-color:var(--color-gray-50);transition:var(--transition-fast)}.header__search-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-white);box-shadow:0 0 0 3px var(--color-primary-light)}.header__search-input::placeholder{color:var(--color-gray-400)}.header__search-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);color:var(--color-gray-400);font-size:var(--font-size-sm);pointer-events:none}.header__nav{display:flex;align-items:center;gap:var(--spacing-2)}.header__nav-link{color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:500;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);transition:var(--transition-fast);white-space:nowrap}.header__nav-link:hover{background-color:var(--color-gray-100);color:var(--color-gray-900);text-decoration:none}.header__nav-link--active{color:var(--color-primary);background-color:var(--color-primary-light)}.header__user{display:flex;align-items:center;gap:var(--spacing-3)}.header__user-email{font-size:var(--font-size-sm);color:var(--color-gray-600);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__mobile-btn{display:none;background:none;border:none;padding:var(--spacing-2);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-xl)}.header__dropdown{position:relative}.header__dropdown-trigger{display:flex;align-items:center;gap:var(--spacing-1);background:none;border:none;cursor:pointer}.header__dropdown-arrow{font-size:10px;transition:transform var(--transition-fast)}.header__dropdown-menu{position:absolute;top:100%;left:0;min-width:280px;max-height:70vh;overflow-y:auto;background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast);z-index:200}.header__dropdown-menu--open{opacity:1;visibility:visible;transform:translateY(8px)}.header__dropdown-group{padding:var(--spacing-2) 0;border-bottom:1px solid var(--color-gray-100)}.header__dropdown-group:last-of-type{border-bottom:none}.header__dropdown-group-title{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-xs);font-weight:600;color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.05em}.header__dropdown-item{display:block;padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-gray-700);transition:background-color var(--transition-fast)}.header__dropdown-item:hover{background-color:var(--color-gray-50);text-decoration:none;color:var(--color-primary)}.header__dropdown-footer{padding:var(--spacing-2) 0;border-top:1px solid var(--color-gray-100);margin-top:var(--spacing-2)}.header__dropdown-item--all{font-weight:500;color:var(--color-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--transition-fast);white-space:nowrap;cursor:pointer}.btn:hover{text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background-color:var(--color-primary);color:var(--color-white)}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px)}.btn--secondary{background-color:var(--color-white);color:var(--color-gray-700);border-color:var(--color-gray-200)}.btn--secondary:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-300)}.btn--ghost{background-color:transparent;color:var(--color-gray-600)}.btn--ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-gray-900)}.btn--sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.btn--lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base);border-radius:var(--radius-lg)}.form-group{margin-bottom:var(--spacing-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-700);margin-bottom:var(--spacing-1)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-base);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background-color:var(--color-white);transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::placeholder{color:var(--color-gray-400)}.form-textarea{min-height:120px;resize:vertical}.form-error{font-size:var(--font-size-sm);color:var(--color-error);margin-top:var(--spacing-1)}.form-help{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--spacing-1)}.card{background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-lg);padding:var(--spacing-4);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-200)}.card--clickable{cursor:pointer}.card--clickable:hover{transform:translateY(-2px)}.card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-3)}.card__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-900)}.card__subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--spacing-1)}.card__body{color:var(--color-gray-600)}.card__footer{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100)}.course-card{display:block;color:inherit;padding:var(--spacing-5)}.course-card:hover{text-decoration:none}.course-card__code{font-size:var(--font-size-xs);color:var(--color-gray-400);font-weight:500;letter-spacing:.02em}.course-card__name{font-size:var(--font-size-base);font-weight:600;color:var(--color-gray-900);margin-top:var(--spacing-1);line-height:1.4;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.course-card__major{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-2)}.course-card__stats{display:flex;gap:var(--spacing-3);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100)}.course-card__stat{display:flex;flex-direction:column;align-items:center;flex:1}.course-card__stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary)}.course-card__stat-label{font-size:var(--font-size-xs);color:var(--color-gray-400);margin-top:var(--spacing-1)}.course-card__reviews{font-size:var(--font-size-xs);color:var(--color-gray-400);margin-top:var(--spacing-3);display:flex;align-items:center;gap:var(--spacing-1)}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-4)}.course-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.course-card-h{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-5);background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all var(--transition-fast)}.course-card-h:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}.course-card-h__main{flex:1;min-width:0}.course-card-h__info{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-1)}.course-card-h__code{font-size:var(--font-size-xs);color:var(--color-gray-400);font-weight:500}.course-card-h__name{font-size:var(--font-size-base);font-weight:600;color:var(--color-gray-900);margin-bottom:var(--spacing-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-card-h__major{font-size:var(--font-size-sm);color:var(--color-gray-500)}.course-card-h__stats{display:flex;align-items:center;gap:var(--spacing-6);flex-shrink:0;margin-left:var(--spacing-4)}.course-card-h__stat{display:flex;flex-direction:column;align-items:center;min-width:48px}.course-card-h__stat-value{font-size:var(--font-size-base);font-weight:600;color:var(--color-gray-700)}.course-card-h__stat--rating .course-card-h__stat-value{font-size:var(--font-size-lg);color:var(--color-primary)}.course-card-h__stat-label{font-size:var(--font-size-xs);color:var(--color-gray-400);margin-top:2px}@media(max-width:768px){.course-card-h{flex-direction:column;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4)}.course-card-h__stats{margin-left:0;width:100%;justify-content:space-between;padding-top:var(--spacing-3);border-top:1px solid var(--color-gray-100)}.course-card-h__stat{min-width:unset;flex:1}}.courses-page{max-width:var(--max-width);margin:0 auto}.courses-page__header{background:linear-gradient(180deg,var(--color-primary-lighter) 0%,var(--color-white) 100%);padding:var(--spacing-8) var(--spacing-6);margin:calc(-1 * var(--spacing-6));margin-bottom:var(--spacing-6);border-bottom:1px solid var(--color-gray-100)}.courses-page__header .page-header__breadcrumb{margin-bottom:var(--spacing-3)}.courses-page__title{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-2)}.courses-page__subtitle{font-size:var(--font-size-base);color:var(--color-gray-500)}.courses-page__filters{margin-bottom:var(--spacing-6)}.courses-page__filters .filter-bar{background-color:var(--color-white);border:1px solid var(--color-gray-100);box-shadow:var(--shadow-sm)}.courses-page__content{min-height:400px}@media(max-width:768px){.courses-page__header{padding:var(--spacing-6) var(--spacing-4);margin:calc(-1 * var(--spacing-4));margin-bottom:var(--spacing-4)}.courses-page__title{font-size:var(--font-size-2xl)}}.course-table{background-color:var(--color-white);border-radius:var(--radius-lg);overflow:hidden}.course-table__header{display:grid;grid-template-columns:1fr 140px 70px 60px;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-gray-50);font-size:var(--font-size-xs);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.03em}.course-table__row{display:grid;grid-template-columns:1fr 140px 70px 60px;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);color:var(--color-gray-700);text-decoration:none;border-bottom:1px solid var(--color-gray-100);transition:background-color var(--transition-fast);align-items:center}.course-table__row:last-child{border-bottom:none}.course-table__row:hover{background-color:var(--color-gray-50);text-decoration:none}.course-table__col{font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-table__col--name{display:flex;align-items:center;gap:var(--spacing-3);font-weight:500;color:var(--color-gray-900)}.course-table__rank{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:var(--color-primary-light);color:var(--color-primary);font-size:var(--font-size-xs);font-weight:700;border-radius:var(--radius-md);flex-shrink:0}.course-table__row:nth-child(2) .course-table__rank{background-color:var(--color-primary);color:var(--color-white)}.course-table__row:nth-child(3) .course-table__rank,.course-table__row:nth-child(4) .course-table__rank{background-color:var(--color-primary-light);color:var(--color-primary)}.course-table__name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-table__col--major{color:var(--color-gray-500)}.course-table__col--rating{display:flex;align-items:center;gap:var(--spacing-1);font-weight:600;color:var(--color-gray-900)}.course-table__rating-star{color:#fbbf24}.course-table__col--reviews{color:var(--color-gray-400);text-align:right}@media(max-width:768px){.course-table__header{display:none}.course-table__row{grid-template-columns:1fr auto auto;gap:var(--spacing-2)}.course-table__col--major{display:none}.course-table__col--reviews:after{content:"개";margin-left:2px}}.rating{display:inline-flex;align-items:center;gap:var(--spacing-1)}.rating__star{color:var(--color-gray-300);font-size:var(--font-size-lg)}.rating__star--filled{color:#fbbf24}.rating__value{font-weight:600;color:var(--color-gray-900);margin-left:var(--spacing-1)}.tag{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full);background-color:var(--color-gray-100);color:var(--color-gray-700)}.tag--eval{background-color:var(--color-primary-light);color:var(--color-primary-dark)}.tag--freeform{background-color:#fef3c7;color:#92400e}.tags{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.filter-bar{background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-xl);padding:var(--spacing-5);margin-bottom:var(--spacing-6)}.filter-bar__row{display:flex;flex-wrap:wrap;gap:var(--spacing-4);align-items:flex-end}.filter-bar__group{flex:1;min-width:150px}.filter-bar__label{display:block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.03em;margin-bottom:var(--spacing-2)}.filter-bar__actions{display:flex;gap:var(--spacing-2)}.search-box{position:relative}.search-box__input{width:100%;padding:var(--spacing-2) var(--spacing-3);padding-left:var(--spacing-10);font-size:var(--font-size-base);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background-color:var(--color-white)}.search-box__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.search-box__icon{position:absolute;left:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--color-gray-400)}.major-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-3)}.major-item{display:flex;align-items:center;justify-content:center;padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-lg);color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);text-align:center}.major-item:hover{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary);text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.major-item--active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.review{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.review__meta{font-size:var(--font-size-sm);color:var(--color-gray-500)}.review__ratings{display:flex;gap:var(--spacing-4);margin-bottom:var(--spacing-3)}.review__rating-item{display:flex;flex-direction:column;align-items:center}.review__rating-value{font-size:var(--font-size-xl);font-weight:600;color:var(--color-gray-900)}.review__rating-label{font-size:var(--font-size-xs);color:var(--color-gray-500)}.review__text{color:var(--color-gray-700);line-height:1.7;margin-bottom:var(--spacing-3)}.review__tags{margin-top:var(--spacing-3)}.review-form{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-5)}.review-form__title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-gray-100)}.review-form__row{display:flex;flex-direction:column;gap:var(--spacing-3)}.review-form .form-group{margin-bottom:var(--spacing-4)}.review-form .form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.rating-input{display:flex;gap:var(--spacing-1);flex-wrap:wrap}.rating-input__btn{width:36px;height:36px;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background-color:var(--color-gray-50);font-weight:600;font-size:var(--font-size-sm);color:var(--color-gray-500);cursor:pointer;transition:all .15s ease}.rating-input__btn:hover{border-color:var(--color-primary);background-color:var(--color-primary-light);color:var(--color-primary)}.rating-input__btn--selected{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white);transform:scale(1.05)}.rating-input--text{gap:var(--spacing-2);flex-wrap:wrap}.rating-input--text .rating-input__btn{width:auto;min-width:0;padding:var(--spacing-2) var(--spacing-3);flex:1 1 auto;font-size:var(--font-size-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rating-input--text .rating-input__btn{min-width:52px}.tag-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.tag-selector__item{padding:var(--spacing-1) var(--spacing-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-gray-600);cursor:pointer;transition:all .15s ease;background-color:var(--color-white)}.tag-selector__item:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-lighter)}.tag-selector__item--selected{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.review-form .form-textarea{min-height:100px;font-size:var(--font-size-sm);resize:vertical}.review-form .form-help{font-size:var(--font-size-xs);color:var(--color-gray-400);margin-top:var(--spacing-1)}.review-form #review-submit{width:100%;margin-top:var(--spacing-2)}.review-form .form-error{margin-top:var(--spacing-3);padding:var(--spacing-3);background-color:#fef2f2;border-radius:var(--radius-md);text-align:center}.rating-bar{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) 0}.rating-bar__label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-600);min-width:50px}.rating-bar__track{display:flex;gap:3px;flex:1;max-width:200px}.rating-bar__segment{flex:1;height:8px;background-color:var(--color-gray-200);border-radius:2px;transition:background-color var(--transition-fast)}.rating-bar__segment--filled{background-color:var(--color-primary)}.rating-bar__value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-700);min-width:70px;text-align:right}.review__bars{display:flex;flex-direction:column;gap:var(--spacing-1);margin-bottom:var(--spacing-4);padding:var(--spacing-3);background-color:var(--color-gray-50);border-radius:var(--radius-md)}.review__bars .rating-bar{padding:var(--spacing-1) 0}.review__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-3)}.review__rating-overall{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-primary-lighter);border-radius:var(--radius-md)}.review__rating-overall-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);line-height:1}.review__rating-overall-label{font-size:var(--font-size-xs);color:var(--color-primary);margin-top:var(--spacing-1)}.review__meta{font-size:var(--font-size-sm);color:var(--color-gray-400)}.page-header{margin-bottom:var(--spacing-6)}.page-header__title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-900)}.page-header__subtitle{font-size:var(--font-size-base);color:var(--color-gray-500);margin-top:var(--spacing-1)}.page-header__breadcrumb{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-2)}.page-header__breadcrumb a{color:var(--color-gray-500)}.page-header__breadcrumb a:hover{color:var(--color-primary)}.course-detail{display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-6);align-items:start}@media(max-width:900px){.course-detail{grid-template-columns:1fr}.course-detail__sidebar{order:2}}.course-detail__main{min-width:0}.course-detail__sidebar{position:sticky;top:calc(var(--header-height) + var(--spacing-6));height:fit-content}.course-info{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-5)}.course-info__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4)}.course-info__title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.course-info__code{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--spacing-2)}.course-info__rating-big{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-4);background:linear-gradient(135deg,var(--color-primary-lighter) 0%,var(--color-white) 100%);border:1px solid var(--color-primary-light);border-radius:var(--radius-lg);min-width:100px}.course-info__rating-big-value{font-size:var(--font-size-4xl);font-weight:700;color:var(--color-primary);line-height:1}.course-info__rating-big-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);margin-top:var(--spacing-1)}.course-info__rating-big-count{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}.course-info__bars{margin-top:var(--spacing-5);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100)}.course-info__bars .rating-bar__track{max-width:300px}.course-info__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100)}.course-info__stat{text-align:center}.course-info__stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-900)}.course-info__stat-label{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}@media(max-width:600px){.course-info__header{flex-direction:column}.course-info__rating-big{flex-direction:row;width:100%;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-3)}.course-info__rating-big-value{font-size:var(--font-size-3xl)}.course-info__rating-big-label,.course-info__rating-big-count{margin-top:0}}.auth-container{max-width:400px;margin:var(--spacing-12) auto}.auth-card{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-8)}.auth-card__title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-6)}.auth-card__footer{text-align:center;margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-100);font-size:var(--font-size-sm);color:var(--color-gray-500)}#toast-container{position:fixed;bottom:var(--spacing-6);right:var(--spacing-6);z-index:1000;display:flex;flex-direction:column;gap:var(--spacing-2)}.toast{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);background-color:var(--color-gray-800);color:var(--color-white);font-size:var(--font-size-sm);box-shadow:var(--shadow-lg);animation:slideIn .3s ease}.toast--success{background-color:var(--color-success)}.toast--error{background-color:var(--color-error)}.toast--warning{background-color:var(--color-warning)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.loading{display:flex;justify-content:center;align-items:center;padding:var(--spacing-12)}.loading__spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--spacing-12)}.empty-state__icon{font-size:3rem;color:var(--color-gray-300);margin-bottom:var(--spacing-4)}.empty-state__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.empty-state__description{font-size:var(--font-size-sm);color:var(--color-gray-500)}.pagination{display:flex;justify-content:center;gap:var(--spacing-2);margin-top:var(--spacing-6)}.pagination__btn{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background-color:var(--color-white);color:var(--color-gray-700);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s}.pagination__btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.pagination__btn--active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.pagination__btn:disabled{opacity:.5;cursor:not-allowed}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.hidden{display:none}.home-page{max-width:var(--max-width);margin:0 auto}.hero-section{text-align:center;padding:var(--spacing-16) var(--spacing-4);margin-bottom:var(--spacing-8);background:linear-gradient(180deg,var(--color-primary-lighter) 0%,var(--color-white) 100%);position:relative}.hero-section__title{font-size:var(--font-size-4xl);font-weight:800;color:var(--color-primary);margin-bottom:var(--spacing-3);letter-spacing:-.02em}.hero-section__subtitle{font-size:var(--font-size-lg);color:var(--color-gray-500);margin-bottom:var(--spacing-8)}.hero-section__search{max-width:600px;margin:0 auto}.search-box--large .search-box__input{padding:var(--spacing-4) var(--spacing-6);padding-left:56px;font-size:var(--font-size-base);border-radius:var(--radius-full);border:2px solid var(--color-gray-200);box-shadow:var(--shadow-md);transition:var(--transition-normal)}.search-box--large .search-box__input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-lg),0 0 0 4px var(--color-primary-light)}.search-box--large .search-box__icon{left:var(--spacing-5);font-size:var(--font-size-lg)}.home-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.home-main{min-width:0}.home-sidebar{display:flex;flex-direction:column;gap:var(--spacing-6)}.home-sections{display:grid;gap:var(--spacing-6)}.home-section{background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-xl);padding:var(--spacing-6)}.home-section--majors{background-color:var(--color-gray-50);border:none}.home-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-5)}.home-section__title{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-lg);font-weight:700;color:var(--color-gray-900)}.home-section__icon{font-size:var(--font-size-lg)}.review-prompt{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-12) var(--spacing-6);background:linear-gradient(135deg,var(--color-primary-lighter) 0%,var(--color-white) 100%);border:2px dashed var(--color-primary-light);border-radius:var(--radius-xl);gap:var(--spacing-4)}.review-prompt__icon{font-size:3rem}.review-prompt__content{max-width:400px}.review-prompt__title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-2)}.review-prompt__description{font-size:var(--font-size-sm);color:var(--color-gray-600);line-height:1.6}.trending-box{background-color:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-xl);overflow:hidden}.trending-box__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--color-gray-100)}.trending-box__title{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-900)}.trending-box__title-icon{color:var(--color-error);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.trending-box__time{font-size:var(--font-size-xs);color:var(--color-gray-400)}.trending-list{padding:var(--spacing-2) 0}.trending-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-5);color:var(--color-gray-700);font-size:var(--font-size-sm);transition:background-color var(--transition-fast);cursor:pointer}.trending-item:hover{background-color:var(--color-gray-50);text-decoration:none;color:var(--color-primary)}.trending-item__rank{width:24px;font-weight:700;color:var(--color-gray-400);font-size:var(--font-size-sm)}.trending-item__rank--top{color:var(--color-primary)}.trending-item__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trending-item__change{font-size:var(--font-size-xs);display:flex;align-items:center;gap:2px}.trending-item__change--up{color:var(--color-error)}.trending-item__change--down{color:var(--color-accent)}.trending-item__change--new{color:var(--color-warning);font-weight:500}.stats-widget{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);border-radius:var(--radius-xl);padding:var(--spacing-5);color:var(--color-white)}.stats-widget__title{font-size:var(--font-size-sm);opacity:.9;margin-bottom:var(--spacing-4)}.stats-widget__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.stats-widget__item{text-align:center}.stats-widget__value{font-size:var(--font-size-2xl);font-weight:700}.stats-widget__label{font-size:var(--font-size-xs);opacity:.8;margin-top:var(--spacing-1)}@media(max-width:1024px){.home-layout{grid-template-columns:1fr}.home-sidebar{display:grid;grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){:root{--header-height: 56px}main{padding:var(--spacing-4)}.header__inner{padding:0 var(--spacing-4);gap:var(--spacing-3)}.header__search,.header__nav{display:none}.header__mobile-btn{display:block}.header__user-email{display:none}.hero-section{padding:var(--spacing-10) var(--spacing-4);margin-bottom:var(--spacing-6)}.hero-section__title{font-size:var(--font-size-2xl)}.hero-section__subtitle{font-size:var(--font-size-base);margin-bottom:var(--spacing-6)}.search-box--large .search-box__input{padding:var(--spacing-3) var(--spacing-4);padding-left:44px;font-size:var(--font-size-sm)}.search-box--large .search-box__icon{left:var(--spacing-4)}.home-layout{gap:var(--spacing-4)}.home-sidebar{grid-template-columns:1fr}.home-sections{gap:var(--spacing-4)}.home-section{padding:var(--spacing-4);border-radius:var(--radius-lg)}.home-section__title{font-size:var(--font-size-base)}.course-grid{grid-template-columns:1fr;gap:var(--spacing-3)}.course-card,.filter-bar{padding:var(--spacing-4)}.filter-bar__row{flex-direction:column;gap:var(--spacing-3)}.filter-bar__group{width:100%;min-width:unset}.major-list{grid-template-columns:repeat(2,1fr);gap:var(--spacing-2)}.major-item{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm)}.course-info__stats{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.review-form{padding:var(--spacing-4)}.rating-input__btn{width:40px;height:40px}.trending-box__header,.trending-item{padding:var(--spacing-3) var(--spacing-4)}.pagination{flex-wrap:wrap}#toast-container{left:var(--spacing-4);right:var(--spacing-4);bottom:var(--spacing-4)}.toast{width:100%}}@media(max-width:480px){.major-list{grid-template-columns:1fr}.course-card__stats{gap:var(--spacing-2)}.course-card__stat-value{font-size:var(--font-size-lg)}.stats-widget__grid{gap:var(--spacing-3)}.stats-widget__value{font-size:var(--font-size-xl)}}.mobile-nav{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background-color:var(--color-white);z-index:99;transform:translate(100%);transition:transform var(--transition-normal);overflow-y:auto}.mobile-nav--open{transform:translate(0)}.mobile-nav__search{padding:var(--spacing-4);border-bottom:1px solid var(--color-gray-100)}.mobile-nav__search-input{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background-color:var(--color-gray-50)}.mobile-nav__links{padding:var(--spacing-2) 0}.mobile-nav__link{display:block;padding:var(--spacing-4);color:var(--color-gray-700);font-size:var(--font-size-base);font-weight:500;border-bottom:1px solid var(--color-gray-100)}.mobile-nav__link:hover{background-color:var(--color-gray-50);text-decoration:none}.mobile-nav__section-title{padding:var(--spacing-4);font-size:var(--font-size-xs);font-weight:600;color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.05em}
