/* ============================================
   JMS RESEARCH CENTER - UI COMPONENTS
   Buttons, Cards, Badges, Forms, Navigation
   ============================================ */

/* === HEADER === */
.jms-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--jms-header-height);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--jms-gray-200);
    z-index: var(--jms-z-fixed);
    transition: all var(--jms-transition-base);
}

.jms-header--scrolled {
    height: 60px;
    box-shadow: var(--jms-shadow-md);
}

.jms-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    gap: var(--jms-space-8);
}

.jms-header__logo {
    flex-shrink: 0;
}

.jms-header__logo-text {
    display: flex;
    align-items: center;
    gap: var(--jms-space-3);
    color: var(--jms-gray-900);
    font-weight: 700;
    font-size: var(--jms-text-lg);
    font-family: var(--jms-font-heading);
}

.jms-header__logo-text:hover {
    color: var(--jms-gray-900);
}

.jms-header__brand-name {
    background: var(--jms-gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* === Navigation === */
.jms-nav {
    flex: 1;
    display: flex;
    justify-content: center;
}

.jms-nav__list {
    display: flex;
    align-items: center;
    gap: var(--jms-space-1);
    list-style: none;
    margin: 0;
    padding: 0;
}

.jms-nav__link {
    display: flex;
    align-items: center;
    gap: var(--jms-space-1);
    padding: var(--jms-space-2) var(--jms-space-4);
    color: var(--jms-gray-700);
    font-size: var(--jms-text-sm);
    font-weight: 500;
    border-radius: var(--jms-radius-sm);
    transition: all var(--jms-transition-fast);
    white-space: nowrap;
}

.jms-nav__link:hover {
    color: var(--jms-primary);
    background: var(--jms-primary-bg);
}

.jms-nav__item--active > .jms-nav__link {
    color: var(--jms-primary);
    background: var(--jms-primary-bg);
}

.jms-nav__chevron {
    transition: transform var(--jms-transition-fast);
}

.jms-nav__item--has-children:hover .jms-nav__chevron {
    transform: rotate(180deg);
}

/* Submenu */
.jms-nav__submenu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: #fff;
    border-radius: var(--jms-radius-md);
    box-shadow: var(--jms-shadow-xl);
    padding: var(--jms-space-2);
    list-style: none;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: all var(--jms-transition-base);
}

.jms-nav__item--has-children {
    position: relative;
}

.jms-nav__item--has-children:hover > .jms-nav__submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.jms-nav__submenu .jms-nav__link {
    border-radius: var(--jms-radius-sm);
    padding: var(--jms-space-3) var(--jms-space-4);
}

/* Header Actions */
.jms-header__actions {
    display: flex;
    align-items: center;
    gap: var(--jms-space-3);
    flex-shrink: 0;
}

/* Profile Dropdown */
.jms-header__profile-dropdown {
    position: relative;
}
.jms-header__profile-trigger {
    display: flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: 1px solid #e2e8f0;
    border-radius: 100px;
    padding: 4px 12px 4px 4px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: #374151;
    transition: all 0.2s;
}
.jms-header__profile-trigger:hover {
    border-color: var(--jms-primary);
    background: #f8fafc;
}
.jms-header__avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover;
}
.jms-header__profile-name {
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.jms-header__profile-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 180px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.12);
    border: 1px solid #e2e8f0;
    padding: 6px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: all 0.2s ease;
    z-index: 9999;
}
.jms-header__profile-dropdown:hover .jms-header__profile-menu,
.jms-header__profile-dropdown:focus-within .jms-header__profile-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.jms-header__profile-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    font-size: 13px;
    font-weight: 500;
    color: #374151;
    text-decoration: none;
    border-radius: 8px;
    transition: background 0.15s;
}
.jms-header__profile-item:hover {
    background: #f3f4f6;
    color: var(--jms-primary);
}
.jms-header__profile-item--logout {
    color: #ef4444;
    border-top: 1px solid #f1f5f9;
    margin-top: 4px;
    padding-top: 10px;
}
.jms-header__profile-item--logout:hover {
    background: #fef2f2;
    color: #dc2626;
}

/* Mobile Toggle */
.jms-header__toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--jms-space-2);
}

/* Mobile nav actions - hidden on desktop */
.jms-nav__mobile-actions {
    display: none;
}

.jms-nav__mobile-lang {
    margin-top: 4px;
}

/* Profile menu visibility states */
.jms-header__profile-menu--open {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

/* Profile info in dropdown */
.jms-header__profile-info {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
}

.jms-header__profile-info small {
    display: block;
    color: #64748b;
    font-size: 12px;
}

.jms-header__profile-divider {
    height: 1px;
    background: #f1f5f9;
    margin: 4px 6px;
}

/* Notice bar */
.jms-notice-bar {
    background: linear-gradient(135deg, #6C63FF 0%, #3B82F6 100%);
    color: #fff;
    padding: 8px 0;
    font-size: 13px;
    position: relative;
    z-index: 10000;
}
.jms-notice-bar .jms-container {
    display: flex;
    align-items: center;
    gap: 8px;
}
.jms-notice-bar__close {
    margin-left: auto;
    background: none;
    border: none;
    color: rgba(255,255,255,0.8);
    cursor: pointer;
    font-size: 18px;
    padding: 0 4px;
}
.jms-notice-bar__close:hover {
    color: #fff;
}

/* Notification bell */
.jms-header__notif {
    position: relative;
}
.jms-header__notif-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    color: #64748b;
    position: relative;
    border-radius: 8px;
    transition: all 0.2s;
}
.jms-header__notif-btn:hover {
    background: #f1f5f9;
    color: #374151;
}
.jms-header__notif-badge {
    position: absolute;
    top: 0;
    right: 0;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    min-width: 16px;
    height: 16px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
}
.jms-header__notif-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 320px;
    max-height: 400px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.15);
    border: 1px solid #e2e8f0;
    overflow: hidden;
    z-index: 9999;
}
.jms-notif-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid #f1f5f9;
}
.jms-notif-panel__body {
    max-height: 300px;
    overflow-y: auto;
}
.jms-notif-item {
    padding: 12px 16px;
    border-bottom: 1px solid #f8fafc;
    cursor: pointer;
    transition: background 0.15s;
}
.jms-notif-item:hover {
    background: #f8fafc;
}
.jms-notif-item--unread {
    background: #eff6ff;
    border-left: 3px solid #6C63FF;
}
.jms-notif-item__title {
    font-size: 13px;
    font-weight: 500;
    color: #1e293b;
}
.jms-notif-item__meta {
    font-size: 11px;
    color: #94a3b8;
    margin-top: 2px;
}

.jms-header__toggle-bar {
    width: 24px;
    height: 2px;
    background: var(--jms-gray-700);
    border-radius: 2px;
    transition: all var(--jms-transition-base);
}

.jms-header__toggle--active .jms-header__toggle-bar:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}
.jms-header__toggle--active .jms-header__toggle-bar:nth-child(2) {
    opacity: 0;
}
.jms-header__toggle--active .jms-header__toggle-bar:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* === BUTTONS === */
.jms-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--jms-space-2);
    padding: 0.625rem 1.5rem;
    font-family: var(--jms-font-body);
    font-size: var(--jms-text-sm);
    font-weight: 600;
    line-height: 1.5;
    border: 2px solid transparent;
    border-radius: var(--jms-radius-md);
    cursor: pointer;
    transition: all var(--jms-transition-base);
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

.jms-btn--primary {
    background: var(--jms-gradient-primary);
    color: #fff;
    box-shadow: 0 4px 14px rgba(108, 99, 255, 0.25);
}

.jms-btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(108, 99, 255, 0.35);
    color: #fff;
}

.jms-btn--glow {
    animation: jms-glow 2s ease-in-out infinite alternate;
}

.jms-btn--outline {
    background: transparent;
    color: var(--jms-primary);
    border-color: var(--jms-primary);
}

.jms-btn--outline:hover {
    background: var(--jms-primary);
    color: #fff;
    transform: translateY(-2px);
}

.jms-btn--ghost {
    background: transparent;
    color: var(--jms-gray-700);
}

.jms-btn--ghost:hover {
    background: var(--jms-gray-100);
    color: var(--jms-gray-900);
}

.jms-btn--white {
    background: #fff;
    color: var(--jms-primary);
    box-shadow: var(--jms-shadow-lg);
}

.jms-btn--white:hover {
    transform: translateY(-2px);
    box-shadow: var(--jms-shadow-xl);
    color: var(--jms-primary-dark);
}

.jms-btn--outline-white {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.5);
}

.jms-btn--outline-white:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: #fff;
    color: #fff;
}

/* Button Sizes */
.jms-btn--sm {
    padding: 0.375rem 1rem;
    font-size: var(--jms-text-xs);
    border-radius: var(--jms-radius-sm);
}

.jms-btn--lg {
    padding: 0.875rem 2rem;
    font-size: var(--jms-text-base);
    border-radius: var(--jms-radius-lg);
}

.jms-btn--full {
    width: 100%;
}

/* Button Ripple Effect */
.jms-btn::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: radial-gradient(circle, rgba(255,255,255,0.3) 0%, transparent 70%);
    transform: scale(0);
    opacity: 0;
    transition: transform 0.5s, opacity 0.3s;
}

.jms-btn:active::after {
    transform: scale(2.5);
    opacity: 1;
    transition: transform 0s, opacity 0s;
}

/* === CARDS === */
.jms-card {
    background: #fff;
    border-radius: var(--jms-radius-lg);
    box-shadow: var(--jms-shadow-card);
    overflow: hidden;
    transition: all var(--jms-transition-base);
    position: relative;
}

.jms-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--jms-shadow-card-hover);
}

.jms-card__image {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    background: var(--jms-gray-100);
}

.jms-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--jms-transition-slow);
}

.jms-card:hover .jms-card__image img {
    transform: scale(1.05);
}

.jms-card__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: var(--jms-primary-bg);
    color: var(--jms-primary);
}

.jms-card__placeholder--1 { background: linear-gradient(135deg, #EEF2FF, #E0E7FF); color: #6C63FF; }
.jms-card__placeholder--2 { background: linear-gradient(135deg, #ECFDF5, #D1FAE5); color: #10B981; }
.jms-card__placeholder--3 { background: linear-gradient(135deg, #EFF6FF, #DBEAFE); color: #3B82F6; }
.jms-card__placeholder--4 { background: linear-gradient(135deg, #FEF3C7, #FDE68A); color: #F59E0B; }

.jms-card__badge {
    position: absolute;
    top: var(--jms-space-3);
    right: var(--jms-space-3);
    background: var(--jms-gradient-primary);
    color: #fff;
    font-size: var(--jms-text-sm);
    font-weight: 700;
    padding: var(--jms-space-1) var(--jms-space-3);
    border-radius: var(--jms-radius-sm);
}

.jms-card__body {
    padding: var(--jms-space-5);
}

.jms-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--jms-space-3);
    margin-bottom: var(--jms-space-3);
}

.jms-card__title {
    font-size: var(--jms-text-lg);
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: var(--jms-space-2);
}

.jms-card__title a {
    color: var(--jms-gray-900);
}

.jms-card__title a:hover {
    color: var(--jms-primary);
}

.jms-card__excerpt {
    font-size: var(--jms-text-sm);
    color: var(--jms-gray-500);
    line-height: 1.6;
    margin-bottom: var(--jms-space-4);
}

.jms-card__meta {
    display: flex;
    align-items: center;
    gap: var(--jms-space-4);
    font-size: var(--jms-text-sm);
    color: var(--jms-gray-500);
}

.jms-card__meta--job {
    flex-wrap: wrap;
    margin-bottom: var(--jms-space-4);
}

.jms-card__rating,
.jms-card__students,
.jms-card__location,
.jms-card__salary,
.jms-card__qualification {
    display: flex;
    align-items: center;
    gap: var(--jms-space-1);
}

.jms-card__rating svg {
    flex-shrink: 0;
}

.jms-card__date {
    font-size: var(--jms-text-xs);
    color: var(--jms-primary);
    font-weight: 600;
    margin-bottom: var(--jms-space-2);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.jms-card__read-more {
    font-size: var(--jms-text-sm);
    font-weight: 600;
    color: var(--jms-primary);
    display: inline-flex;
    align-items: center;
    gap: var(--jms-space-1);
}

/* === BADGES === */
.jms-badge {
    display: inline-flex;
    align-items: center;
    padding: var(--jms-space-1) var(--jms-space-3);
    font-size: var(--jms-text-xs);
    font-weight: 600;
    border-radius: var(--jms-radius-full);
    white-space: nowrap;
    flex-shrink: 0;
}

.jms-badge--full-time { background: #ECFDF5; color: #059669; }
.jms-badge--part-time { background: #EFF6FF; color: #2563EB; }
.jms-badge--contract { background: #FEF3C7; color: #D97706; }
.jms-badge--internship { background: #F5F3FF; color: #7C3AED; }
.jms-badge--freelance { background: #FEF2F2; color: #DC2626; }
.jms-badge--easy { background: #ECFDF5; color: #059669; }
.jms-badge--medium { background: #FEF3C7; color: #D97706; }
.jms-badge--hard { background: #FEF2F2; color: #DC2626; }

/* === MODULE CARDS === */
.jms-modules__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--jms-space-6);
}

.jms-module-card {
    background: #fff;
    border-radius: var(--jms-radius-xl);
    padding: var(--jms-space-8);
    box-shadow: var(--jms-shadow-card);
    transition: all var(--jms-transition-base);
    position: relative;
    overflow: hidden;
}

.jms-module-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--jms-gradient-primary);
    transform: scaleX(0);
    transition: transform var(--jms-transition-base);
}

.jms-module-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--jms-shadow-card-hover);
}

.jms-module-card:hover::before {
    transform: scaleX(1);
}

.jms-module-card__icon {
    width: 64px;
    height: 64px;
    border-radius: var(--jms-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--jms-space-5);
}

.jms-module-card__icon--blue { background: #EFF6FF; color: #3B82F6; }
.jms-module-card__icon--green { background: #ECFDF5; color: #10B981; }
.jms-module-card__icon--purple { background: #F5F3FF; color: #7C3AED; }
.jms-module-card__icon--orange { background: #FFF7ED; color: #F97316; }

.jms-module-card__title {
    font-size: var(--jms-text-xl);
    font-weight: 700;
    margin-bottom: var(--jms-space-3);
}

.jms-module-card__desc {
    font-size: var(--jms-text-sm);
    color: var(--jms-gray-500);
    line-height: 1.6;
    margin-bottom: var(--jms-space-5);
}

.jms-module-card__link {
    display: inline-flex;
    align-items: center;
    gap: var(--jms-space-2);
    color: var(--jms-primary);
    font-weight: 600;
    font-size: var(--jms-text-sm);
    transition: gap var(--jms-transition-fast);
}

.jms-module-card__link:hover {
    gap: var(--jms-space-3);
}

/* === FORMS === */
.jms-form__group {
    margin-bottom: var(--jms-space-5);
}

.jms-form__group label {
    display: block;
    font-size: var(--jms-text-sm);
    font-weight: 600;
    color: var(--jms-gray-700);
    margin-bottom: var(--jms-space-2);
}

.jms-form__input,
.jms-form__select {
    width: 100%;
    padding: 0.75rem 1rem;
    font-family: var(--jms-font-body);
    font-size: var(--jms-text-sm);
    color: var(--jms-gray-800);
    background: #fff;
    border: 2px solid var(--jms-gray-200);
    border-radius: var(--jms-radius-md);
    transition: all var(--jms-transition-fast);
    outline: none;
}

.jms-form__input:focus,
.jms-form__select:focus {
    border-color: var(--jms-primary);
    box-shadow: 0 0 0 3px rgba(108, 99, 255, 0.1);
}

/* === PROGRESS BAR === */
.jms-progress {
    height: 8px;
    background: var(--jms-gray-200);
    border-radius: var(--jms-radius-full);
    overflow: hidden;
    margin-bottom: var(--jms-space-2);
}

.jms-progress__bar {
    height: 100%;
    background: var(--jms-gradient-primary);
    border-radius: var(--jms-radius-full);
    transition: width var(--jms-transition-slow);
}

.jms-progress__text {
    font-size: var(--jms-text-xs);
    color: var(--jms-gray-500);
    font-weight: 500;
}

/* === SKELETON LOADER === */
.jms-skeleton {
    background: #fff;
    border-radius: var(--jms-radius-lg);
    overflow: hidden;
}

.jms-skeleton__pulse {
    background: linear-gradient(90deg, var(--jms-gray-100) 25%, var(--jms-gray-200) 50%, var(--jms-gray-100) 75%);
    background-size: 200% 100%;
    animation: jms-skeleton-pulse 1.5s ease-in-out infinite;
}

.jms-skeleton__image {
    height: 180px;
}

.jms-skeleton__body {
    padding: var(--jms-space-5);
}

.jms-skeleton__title {
    height: 20px;
    border-radius: 4px;
    margin-bottom: var(--jms-space-3);
    width: 80%;
}

.jms-skeleton__text {
    height: 14px;
    border-radius: 4px;
    margin-bottom: var(--jms-space-2);
}

.jms-skeleton__text--short {
    width: 60%;
}

/* === PAGINATION === */
.jms-pagination {
    display: flex;
    justify-content: center;
    margin-top: var(--jms-space-10);
}

.jms-pagination .nav-links {
    display: flex;
    gap: var(--jms-space-2);
}

/* === INSTRUCTOR COMPONENTS === */
.jms-instructor-hero { position: relative; padding: 80px 0 60px; overflow: hidden; }
.jms-instructor-hero__bg { position: absolute; inset: 0; background: linear-gradient(135deg, #312E81 0%, #4338CA 50%, #6366F1 100%); }
.jms-instructor-hero__gradient { position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 20%, rgba(255,255,255,0.08) 0%, transparent 60%); }
.jms-instructor-hero__grid { display: grid; grid-template-columns: auto 1fr; gap: var(--jms-space-10); align-items: center; position: relative; z-index: 1; }
.jms-instructor-hero__avatar { width: 180px; height: 180px; border-radius: 50%; overflow: hidden; border: 4px solid rgba(255,255,255,0.3); flex-shrink: 0; }
.jms-instructor-hero__img { width: 100%; height: 100%; object-fit: cover; }
.jms-instructor-hero__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.5); }
.jms-instructor-hero__content { color: #fff; }
.jms-instructor-hero__name { font-size: 2.25rem; font-weight: 800; margin: 8px 0 12px; color: #fff; font-family: var(--jms-heading); }
.jms-instructor-hero__bio { font-size: 1.1rem; opacity: 0.9; max-width: 600px; line-height: 1.6; margin-bottom: 16px; }
.jms-instructor-hero__meta { display: flex; flex-wrap: wrap; gap: 20px; margin-bottom: 20px; }
.jms-instructor-hero__stat { display: flex; align-items: center; gap: 6px; font-size: 0.95rem; opacity: 0.9; }
.jms-instructor-hero__links { display: flex; gap: 12px; }

.jms-tags { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.jms-tag { display: inline-flex; align-items: center; padding: 6px 16px; background: var(--jms-primary-50, #EEF2FF); color: var(--jms-primary); border-radius: 20px; font-size: 0.875rem; font-weight: 500; }
.jms-tag--sm { padding: 4px 10px; font-size: 0.75rem; }

.jms-achievements { display: grid; gap: 12px; max-width: 700px; margin: 0 auto; }
.jms-achievement-item { display: flex; align-items: center; gap: 12px; padding: 14px 18px; background: #fff; border-radius: 10px; box-shadow: 0 1px 3px rgba(0,0,0,0.06); font-size: 0.95rem; }

.jms-prose { font-size: 1.05rem; line-height: 1.8; color: var(--jms-text-secondary, #6B7280); max-width: 800px; }
.jms-prose p { margin-bottom: 1em; }

.jms-card--instructor { text-decoration: none; color: inherit; }
.jms-card__avatar { position: relative; display: flex; justify-content: center; padding: 24px 0 8px; }
.jms-card__avatar-img { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; border: 3px solid var(--jms-primary-50, #EEF2FF); }
.jms-card__avatar-placeholder { width: 100px; height: 100px; border-radius: 50%; background: var(--jms-primary-50, #EEF2FF); display: flex; align-items: center; justify-content: center; color: var(--jms-primary); }
.jms-card__featured-badge { position: absolute; top: 12px; right: 12px; display: flex; align-items: center; gap: 4px; padding: 3px 8px; background: #FEF3C7; color: #92400E; border-radius: 12px; font-size: 0.7rem; font-weight: 600; }
.jms-card--featured { border: 2px solid #F59E0B; }
.jms-card__subtitle { font-size: 0.85rem; color: var(--jms-gray-500, #6B7280); margin-top: -4px; }
.jms-card__tags { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; margin: 8px 0; }
.jms-card__footer--center { justify-content: center; }

.jms-empty { text-align: center; padding: 60px 20px; color: var(--jms-gray-500, #6B7280); }
.jms-empty svg { margin-bottom: 16px; }
.jms-empty h3 { margin-bottom: 8px; color: var(--jms-text-primary, #111); }

@media (max-width: 768px) {
    .jms-instructor-hero__grid { grid-template-columns: 1fr; text-align: center; }
    .jms-instructor-hero__avatar { margin: 0 auto; width: 140px; height: 140px; }
    .jms-instructor-hero__meta { justify-content: center; }
    .jms-instructor-hero__links { justify-content: center; }
    .jms-instructor-hero__name { font-size: 1.75rem; }
}

.jms-pagination a,
.jms-pagination span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--jms-space-3);
    border-radius: var(--jms-radius-sm);
    font-size: var(--jms-text-sm);
    font-weight: 500;
    transition: all var(--jms-transition-fast);
}

.jms-pagination a {
    background: #fff;
    color: var(--jms-gray-700);
    box-shadow: var(--jms-shadow-sm);
}

.jms-pagination a:hover {
    background: var(--jms-primary);
    color: #fff;
}

.jms-pagination span.current {
    background: var(--jms-primary);
    color: #fff;
}

/* === SLIDER === */
.jms-courses__slider {
    position: relative;
}

.jms-courses__track {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--jms-space-6);
}

.jms-slider__controls {
    display: flex;
    justify-content: center;
    gap: var(--jms-space-3);
    margin-top: var(--jms-space-8);
}

.jms-slider__btn {
    width: 48px;
    height: 48px;
    border-radius: var(--jms-radius-full);
    border: 2px solid var(--jms-gray-200);
    background: #fff;
    color: var(--jms-gray-600);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--jms-transition-fast);
}

.jms-slider__btn:hover {
    border-color: var(--jms-primary);
    color: var(--jms-primary);
    background: var(--jms-primary-bg);
}

/* === JOBS GRID === */
.jms-jobs__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: var(--jms-space-5);
}

/* === BLOG GRID === */
.jms-blog__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--jms-space-6);
}

/* === JOB LISTING FILTERS === */
.jms-job-listing__filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--jms-space-4);
    align-items: flex-end;
    background: #fff;
    padding: var(--jms-space-6);
    border-radius: var(--jms-radius-lg);
    box-shadow: var(--jms-shadow-card);
    margin-bottom: var(--jms-space-8);
}

.jms-job-listing__filters .jms-form__group {
    flex: 1;
    min-width: 200px;
    margin-bottom: 0;
}

/* ===================================================
   HEADER: NOTICE BAR
   =================================================== */
.jms-notice-bar {
    background: linear-gradient(90deg, #6C63FF, #3B82F6);
    color: #fff;
    font-size: 0.85rem;
    padding: 8px 0;
    position: relative;
    z-index: 1001;
}
.jms-notice-bar .jms-container {
    display: flex;
    align-items: center;
    gap: 10px;
}
.jms-notice-bar__text { flex: 1; }
.jms-notice-bar__close {
    background: none;
    border: none;
    color: #fff;
    font-size: 1.2rem;
    cursor: pointer;
    line-height: 1;
    padding: 0 4px;
    opacity: 0.8;
}
.jms-notice-bar__close:hover { opacity: 1; }

/* ===================================================
   HEADER: LOGO
   =================================================== */
.jms-header__logo-img { max-height: 52px; width: auto; display: block; }
.jms-header__logo-svg { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.jms-header__logo-icon { display: flex; align-items: center; }
.jms-header__logo-text-wrap { display: flex; flex-direction: column; }
.jms-header__logo-text-wrap strong { font-size: 1rem; font-weight: 700; color: var(--jms-color-text-primary); line-height: 1.2; }
.jms-header__logo-text-wrap small { font-size: 0.72rem; color: var(--jms-color-text-muted); }

/* ===================================================
   HEADER: NOTIFICATION BELL
   =================================================== */
.jms-header__notif {
    position: relative;
}
.jms-header__notif-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--jms-color-text-secondary);
    transition: background 0.2s, color 0.2s;
    position: relative;
}
.jms-header__notif-btn:hover {
    background: var(--jms-color-bg-subtle, #f5f5f5);
    color: var(--jms-color-primary);
}
.jms-header__notif-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    background: #EF4444;
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    min-width: 16px;
    height: 16px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
    line-height: 1;
}
.jms-header__notif-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 340px;
    background: #fff;
    border-radius: var(--jms-radius-lg, 12px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.15);
    z-index: 1000;
    display: none;
    overflow: hidden;
}
.jms-header__notif-panel.open { display: block; }
.jms-header__notif-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px 10px;
    border-bottom: 1px solid #f0f0f0;
    font-weight: 600;
    font-size: 0.9rem;
}
.jms-header__notif-panel-header a {
    font-size: 0.8rem;
    font-weight: 400;
    color: var(--jms-color-primary, #6C63FF);
    text-decoration: none;
}
.jms-notif-list { max-height: 320px; overflow-y: auto; }
.jms-notif-item {
    display: flex;
    gap: 10px;
    padding: 12px 16px;
    border-bottom: 1px solid #f8f8f8;
    transition: background 0.15s;
    text-decoration: none;
    color: inherit;
}
.jms-notif-item:hover { background: #fafafa; }
.jms-notif-item--unread { background: #f0f4ff; }
.jms-notif-item--unread:hover { background: #e8efff; }
.jms-notif-item__icon { font-size: 1.3rem; flex-shrink: 0; line-height: 1; margin-top: 2px; }
.jms-notif-item__body { flex: 1; min-width: 0; }
.jms-notif-item__title { font-size: 0.85rem; font-weight: 600; margin-bottom: 2px; }
.jms-notif-item__msg { font-size: 0.78rem; color: var(--jms-color-text-muted, #666); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.jms-notif-item__time { font-size: 0.7rem; color: #aaa; margin-top: 2px; }
.jms-notif-empty { text-align: center; padding: 30px 16px; color: #aaa; font-size: 0.85rem; }
.jms-notif-loading { text-align: center; padding: 20px; color: #aaa; font-size: 0.85rem; }

/* ===================================================
   HEADER: PROFILE DROPDOWN
   =================================================== */
.jms-header__profile {
    position: relative;
}
.jms-header__profile-trigger {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 24px;
    transition: background 0.2s;
    user-select: none;
}
.jms-header__profile-trigger:hover,
.jms-header__profile.open .jms-header__profile-trigger {
    background: var(--jms-color-bg-subtle, #f5f5f5);
}
.jms-header__profile-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--jms-color-primary, #6C63FF);
}
.jms-header__profile-avatar-initials {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6C63FF, #3B82F6);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.jms-header__profile-name {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--jms-color-text-primary);
}
.jms-header__profile-chevron {
    color: var(--jms-color-text-muted, #666);
    transition: transform 0.2s;
}
.jms-header__profile.open .jms-header__profile-chevron { transform: rotate(180deg); }
.jms-header__profile-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    background: #fff;
    border-radius: var(--jms-radius-lg, 12px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.15);
    z-index: 1000;
    display: none;
    overflow: hidden;
    padding: 8px 0;
}
.jms-header__profile.open .jms-header__profile-dropdown { display: block; }
.jms-header__profile-info {
    padding: 14px 16px 10px;
    border-bottom: 1px solid #f0f0f0;
}
.jms-header__profile-info strong { display: block; font-size: 0.9rem; color: var(--jms-color-text-primary); }
.jms-header__profile-info span { font-size: 0.78rem; color: var(--jms-color-text-muted, #666); }
.jms-header__profile-divider {
    height: 1px;
    background: #f0f0f0;
    margin: 4px 0;
}
.jms-header__profile-dropdown a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    font-size: 0.875rem;
    color: var(--jms-color-text-primary);
    text-decoration: none;
    transition: background 0.15s;
}
.jms-header__profile-dropdown a:hover { background: #f5f5f5; }
.jms-header__profile-dropdown a.jms-signout {
    color: #EF4444;
}
.jms-header__profile-dropdown a.jms-signout:hover { background: #fff5f5; }
.jms-verified-dot {
    width: 8px;
    height: 8px;
    background: #22C55E;
    border-radius: 50%;
    display: inline-block;
    margin-left: 4px;
    vertical-align: middle;
}

/* ===================================================
   HEADER: LANGUAGE SWITCHER
   =================================================== */
.jms-lang-switcher {
    position: relative;
}
.jms-lang-switcher__btn {
    background: none;
    border: 1px solid var(--jms-color-border, #e5e7eb);
    border-radius: 20px;
    padding: 6px 12px;
    font-size: 0.8rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--jms-color-text-secondary);
    transition: all 0.2s;
}
.jms-lang-switcher__btn:hover {
    border-color: var(--jms-color-primary, #6C63FF);
    color: var(--jms-color-primary, #6C63FF);
}
.jms-lang-switcher__dropdown {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    background: #fff;
    border-radius: var(--jms-radius-md, 8px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    z-index: 1000;
    display: none;
    min-width: 130px;
    overflow: hidden;
}
.jms-lang-switcher__dropdown.open { display: block; }
.jms-lang-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 0.15s;
    color: var(--jms-color-text-primary);
}
.jms-lang-item:hover { background: #f5f5f5; }
.jms-lang-item.active { background: #f0f4ff; font-weight: 600; color: var(--jms-color-primary, #6C63FF); }

/* ===================================================
   HEADER: MOBILE TOGGLE
   =================================================== */
.jms-header__mobile-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    color: var(--jms-color-text-primary);
    flex-direction: column;
    gap: 5px;
    align-items: center;
    justify-content: center;
}
.jms-header__mobile-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
    transition: all 0.25s;
}
@media (max-width: 900px) {
    .jms-header__mobile-toggle { display: flex; }
    .jms-header__nav { display: none; }
    .jms-header__nav.open { display: block; }
    .jms-header__notif-panel,
    .jms-header__profile-dropdown { right: auto; left: 0; }
}

/* ===================================================
   FOOTER: 4-COLUMN GRID
   =================================================== */
.jms-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 40px;
}
.jms-footer__widgets {
    display: contents;
}
.jms-footer__contact li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 10px;
    font-size: 0.875rem;
    color: rgba(255,255,255,0.75);
}
.jms-footer__contact li svg { flex-shrink: 0; margin-top: 2px; }
.jms-footer__contact a { color: rgba(255,255,255,0.75); text-decoration: none; }
.jms-footer__contact a:hover { color: #fff; }
@media (max-width: 900px) {
    .jms-footer__grid {
        grid-template-columns: 1fr 1fr;
    }
}
@media (max-width: 600px) {
    .jms-footer__grid {
        grid-template-columns: 1fr;
    }
}

/* === HEADER: NOTICE BAR === */
.jms-notice-bar{background:linear-gradient(90deg,#6C63FF,#3B82F6);color:#fff;font-size:.85rem;padding:8px 0;position:relative;z-index:1001}.jms-notice-bar .jms-container{display:flex;align-items:center;gap:10px}.jms-notice-bar__text{flex:1}.jms-notice-bar__close{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;line-height:1;padding:0 4px;opacity:.8}.jms-notice-bar__close:hover{opacity:1}

/* === HEADER: NOTIFICATION BELL === */
.jms-header__notif{position:relative}.jms-header__notif-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--jms-color-text-secondary);transition:background .2s,color .2s;position:relative}.jms-header__notif-btn:hover{background:#f5f5f5;color:var(--jms-color-primary)}.jms-header__notif-badge{position:absolute;top:2px;right:2px;background:#EF4444;color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.jms-header__notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);z-index:1000;display:none;overflow:hidden}.jms-header__notif-panel.open{display:block}.jms-header__notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid #f0f0f0;font-weight:600;font-size:.9rem}.jms-header__notif-panel-header a{font-size:.8rem;font-weight:400;color:var(--jms-color-primary,#6C63FF);text-decoration:none}.jms-notif-list{max-height:320px;overflow-y:auto}.jms-notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid #f8f8f8;transition:background .15s;text-decoration:none;color:inherit}.jms-notif-item:hover{background:#fafafa}.jms-notif-item--unread{background:#f0f4ff}.jms-notif-item--unread:hover{background:#e8efff}.jms-notif-item__icon{font-size:1.3rem;flex-shrink:0;line-height:1;margin-top:2px}.jms-notif-item__body{flex:1;min-width:0}.jms-notif-item__title{font-size:.85rem;font-weight:600;margin-bottom:2px}.jms-notif-item__msg{font-size:.78rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jms-notif-item__time{font-size:.7rem;color:#aaa;margin-top:2px}.jms-notif-empty{text-align:center;padding:30px 16px;color:#aaa;font-size:.85rem}

/* === HEADER: PROFILE DROPDOWN === */
.jms-header__profile{position:relative}.jms-header__profile-trigger{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:24px;transition:background .2s;user-select:none}.jms-header__profile-trigger:hover,.jms-header__profile.open .jms-header__profile-trigger{background:#f5f5f5}.jms-header__profile-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--jms-color-primary,#6C63FF)}.jms-header__profile-avatar-initials{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6C63FF,#3B82F6);color:#fff;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.jms-header__profile-name{font-size:.875rem;font-weight:500;color:var(--jms-color-text-primary)}.jms-header__profile-chevron{color:#666;transition:transform .2s}.jms-header__profile.open .jms-header__profile-chevron{transform:rotate(180deg)}.jms-header__profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);z-index:1000;display:none;overflow:hidden;padding:8px 0}.jms-header__profile.open .jms-header__profile-dropdown{display:block}.jms-header__profile-info{padding:14px 16px 10px;border-bottom:1px solid #f0f0f0}.jms-header__profile-info strong{display:block;font-size:.9rem}.jms-header__profile-info span{font-size:.78rem;color:#666}.jms-header__profile-divider{height:1px;background:#f0f0f0;margin:4px 0}.jms-header__profile-dropdown a{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:.875rem;color:var(--jms-color-text-primary);text-decoration:none;transition:background .15s}.jms-header__profile-dropdown a:hover{background:#f5f5f5}.jms-header__profile-dropdown a.jms-signout{color:#EF4444}.jms-header__profile-dropdown a.jms-signout:hover{background:#fff5f5}.jms-verified-dot{width:8px;height:8px;background:#22C55E;border-radius:50%;display:inline-block;margin-left:4px}

/* === HEADER: LANGUAGE SWITCHER === */
.jms-lang-switcher{position:relative}.jms-lang-switcher__btn{background:none;border:1px solid #e5e7eb;border-radius:20px;padding:6px 12px;font-size:.8rem;cursor:pointer;display:flex;align-items:center;gap:4px;color:#666;transition:all .2s}.jms-lang-switcher__btn:hover{border-color:var(--jms-color-primary,#6C63FF);color:var(--jms-color-primary,#6C63FF)}.jms-lang-switcher__dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:1000;display:none;min-width:130px;overflow:hidden}.jms-lang-switcher__dropdown.open{display:block}.jms-lang-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:.85rem;cursor:pointer;transition:background .15s;color:var(--jms-color-text-primary)}.jms-lang-item:hover{background:#f5f5f5}.jms-lang-item.active{background:#f0f4ff;font-weight:600;color:var(--jms-color-primary,#6C63FF)}

/* === HEADER: MOBILE === */
.jms-header__mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--jms-color-text-primary);flex-direction:column;gap:5px;align-items:center;justify-content:center}.jms-header__mobile-toggle span{display:block;width:22px;height:2px;background:currentColor;border-radius:1px;transition:all .25s}
@media(max-width:900px){.jms-header__mobile-toggle{display:flex}.jms-header__nav{display:none}.jms-header__nav.open{display:block}.jms-header__notif-panel,.jms-header__profile-dropdown{right:auto;left:0}}

/* === FOOTER: 4-COL === */
.jms-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}.jms-footer__widgets{display:contents}.jms-footer__contact li{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:.875rem;color:rgba(255,255,255,.75)}.jms-footer__contact li svg{flex-shrink:0;margin-top:2px}.jms-footer__contact a{color:rgba(255,255,255,.75);text-decoration:none}.jms-footer__contact a:hover{color:#fff}
@media(max-width:900px){.jms-footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.jms-footer__grid{grid-template-columns:1fr}}
