:root{
    --jawda-primary:#355efc;
    --jawda-primary-2:#6c8dff;
    --jawda-primary-3:#8fb2ff;
    --jawda-primary-dark:#173d90;
    --jawda-navy:#07183f;
    --jawda-navy-2:#0d2c73;
    --jawda-navy-3:#1746b0;
    --jawda-cyan:#26c6ff;
    --jawda-purple:#7b61ff;
    --jawda-pink:#ff6fa8;
    --jawda-gold:#ffcf5a;
    --jawda-green:#1cc88a;
    --jawda-orange:#ff8a3d;
    --jawda-bg:#eef4ff;
    --jawda-bg-2:#f8fbff;
    --jawda-card:#ffffff;
    --jawda-border:rgba(53,94,252,.12);
    --jawda-border-strong:rgba(53,94,252,.22);
    --jawda-text:#1e293b;
    --jawda-muted:#64748b;
    --jawda-shadow:0 22px 60px rgba(15,23,42,.10);
    --jawda-shadow-lg:0 34px 90px rgba(8,27,71,.20);
    --jawda-shadow-sm:0 12px 28px rgba(15,23,42,.07);
    --jawda-glass:rgba(255,255,255,.76);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
    margin:0;
    font-family:'Cairo', sans-serif;
    color:var(--jawda-text);
    background:
        radial-gradient(circle at 0% 0%, rgba(108,141,255,.16), transparent 20%),
        radial-gradient(circle at 100% 0%, rgba(38,198,255,.14), transparent 18%),
        radial-gradient(circle at 100% 100%, rgba(123,97,255,.12), transparent 18%),
        linear-gradient(180deg,#f9fbff 0%, #eef4ff 44%, #f7faff 100%);
    overflow-x:hidden;
}

body::before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    background:
        radial-gradient(circle at 18% 18%, rgba(255,255,255,.20), transparent 12%),
        radial-gradient(circle at 82% 28%, rgba(255,255,255,.18), transparent 12%),
        radial-gradient(circle at 42% 82%, rgba(255,255,255,.12), transparent 10%);
    opacity:.9;
    z-index:-1;
}

body::after{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    background:linear-gradient(180deg, rgba(255,255,255,.05), transparent 18%, transparent 82%, rgba(255,255,255,.05));
    z-index:-1;
}

h1,h2,h3,h4,h5,h6,
.brand-title,
.profile-name,
.hero-title,
.section-title,
.major-hero-title{
    font-family:"Cairo", sans-serif;
}

a{text-decoration:none}

.container-soft{
    width:min(1400px, calc(100% - 24px));
    margin:auto;
}

/* =========================
   TOP BAR
========================= */
.topbar{
    position:sticky;
    top:0;
    z-index:1200;
    background:
        linear-gradient(135deg, rgba(7,24,63,.97) 0%, rgba(23,61,144,.95) 42%, rgba(53,94,252,.93) 100%);
    border-bottom:1px solid rgba(255,255,255,.08);
    box-shadow:0 12px 35px rgba(15,23,42,.18);
    backdrop-filter:blur(16px);
}

.topbar-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:12px 0;
}

.brand-link{
    display:flex;
    align-items:center;
    gap:14px;
    color:#fff;
}

.brand-logo{
    width:56px;
    height:56px;
    object-fit:cover;
    border-radius:18px;
    background:linear-gradient(135deg,#ffffff,#eef4ff);
    padding:5px;
    border:1px solid rgba(143,178,255,.45);
    box-shadow:
        0 10px 24px rgba(0,0,0,.16),
        0 0 0 4px rgba(143,178,255,.10),
        0 0 24px rgba(53,94,252,.18);
    transition:.35s ease;
}

.brand-link:hover .brand-logo{
    transform:rotate(-3deg) scale(1.06);
    box-shadow:
        0 14px 30px rgba(0,0,0,.18),
        0 0 0 5px rgba(143,178,255,.14),
        0 0 34px rgba(53,94,252,.24);
}

.brand-title{
    font-size:1.4rem;
    font-weight:800;
    line-height:1;
    margin:0;
    text-shadow:0 0 18px rgba(143,178,255,.18);
}

.brand-sub{
    font-size:.82rem;
    font-weight:700;
    color:rgba(255,255,255,.82);
    margin-top:4px;
}

.top-actions{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-end;
}

.ghost-link{
    color:#fff;
    font-weight:800;
    opacity:.94;
    padding:9px 14px;
    border-radius:14px;
    transition:.25s ease;
}

.ghost-link:hover{
    color:#fff;
    transform:translateY(-2px);
    background:linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.05));
}

/* =========================
   PROFILE
========================= */
.profile-wrap{position:relative}

.profile-trigger{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:260px;
    padding:9px 13px;
    border-radius:20px;
    background:linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.08));
    border:1px solid rgba(255,255,255,.14);
    color:#fff;
    cursor:pointer;
    box-shadow:0 10px 22px rgba(0,0,0,.12);
    transition:.28s ease;
    backdrop-filter:blur(12px);
}

.profile-trigger:hover{
    transform:translateY(-1px);
    box-shadow:0 14px 28px rgba(0,0,0,.14);
}

.profile-trigger.static{cursor:default}

.profile-avatar,
.profile-avatar img{
    width:48px;
    height:48px;
    border-radius:50%;
    flex-shrink:0;
}

.profile-avatar{
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#fff,#dce7ff);
    color:#173d90;
    font-weight:800;
    font-size:1rem;
    overflow:hidden;
    border:2px solid rgba(255,255,255,.50);
    box-shadow:0 8px 20px rgba(0,0,0,.10);
}

.profile-avatar img{
    object-fit:cover;
    display:block;
}

.profile-meta{
    min-width:0;
    flex:1 1 auto;
}

.profile-name{
    font-size:1rem;
    font-weight:800;
    line-height:1.05;
    margin:0 0 4px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.profile-role{
    font-size:.78rem;
    font-weight:700;
    color:rgba(255,255,255,.84);
    line-height:1.1;
}

.profile-menu{
    position:absolute;
    left:0;
    top:calc(100% + 12px);
    width:290px;
    background:rgba(255,255,255,.96);
    border:1px solid rgba(53,94,252,.12);
    border-radius:24px;
    box-shadow:0 28px 64px rgba(8,27,71,.15);
    padding:10px;
    display:none;
    backdrop-filter:blur(16px);
}

.profile-menu.show{display:block}

.profile-item,
.profile-item-btn{
    display:flex;
    align-items:center;
    gap:10px;
    width:100%;
    padding:13px 15px;
    border-radius:16px;
    color:var(--jawda-primary-dark);
    font-weight:800;
    background:transparent;
    border:0;
    text-align:right;
    transition:.22s ease;
}

.profile-item:hover,
.profile-item-btn:hover{
    background:linear-gradient(135deg,#eff4ff,#f7faff);
    color:var(--jawda-primary-dark);
}

/* =========================
   HERO
========================= */
.hero{padding:24px 0 12px}

.hero-grid{
    display:grid;
    grid-template-columns:1.15fr .85fr;
    gap:18px;
}

.hero-main,
.hero-side{
    border-radius:34px;
    box-shadow:var(--jawda-shadow);
    border:1px solid rgba(255,255,255,.18);
}

.hero-main{
    position:relative;
    overflow:hidden;
    min-height:310px;
    padding:26px;
    background:
        radial-gradient(circle at 15% 18%, rgba(255,255,255,.18), transparent 16%),
        radial-gradient(circle at 84% 68%, rgba(255,255,255,.10), transparent 20%),
        radial-gradient(circle at 70% 20%, rgba(38,198,255,.18), transparent 24%),
        linear-gradient(135deg,#07183f 0%, #163980 30%, #355efc 70%, #8fb2ff 100%);
    color:#fff;
    isolation:isolate;
}

.hero-main::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(180deg, rgba(255,255,255,.05), transparent 32%),
        radial-gradient(circle at 82% 16%, rgba(255,255,255,.12), transparent 16%);
    z-index:0;
}

.hero-main > *{
    position:relative;
    z-index:1;
}

.hero-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 15px;
    border-radius:999px;
    background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.10));
    border:1px solid rgba(255,255,255,.18);
    font-size:.86rem;
    font-weight:800;
    backdrop-filter:blur(8px);
    box-shadow:0 10px 22px rgba(0,0,0,.08);
}

.hero-title{
    font-size:clamp(1.9rem, 5vw, 3.2rem);
    line-height:1.12;
    font-weight:800;
    margin:16px 0 10px;
    text-shadow:0 8px 24px rgba(0,0,0,.10);
}

.hero-text{
    font-size:.98rem;
    line-height:1.95;
    color:rgba(255,255,255,.92);
    max-width:760px;
}

.hero-pills{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:18px;
}

.hero-pill{
    min-width:175px;
    padding:13px 15px;
    border-radius:22px;
    background:linear-gradient(135deg, rgba(255,255,255,.13), rgba(255,255,255,.08));
    border:1px solid rgba(255,255,255,.16);
    backdrop-filter:blur(10px);
    box-shadow:0 12px 24px rgba(0,0,0,.08);
}

.hero-pill-label{
    display:block;
    font-size:.76rem;
    font-weight:800;
    color:rgba(255,255,255,.74);
    margin-bottom:6px;
}

.hero-pill-value{
    font-size:.96rem;
    font-weight:800;
    color:#fff;
}

.hero-side{
    padding:16px;
    background:rgba(255,255,255,.82);
    backdrop-filter:blur(14px);
    border:1px solid rgba(53,94,252,.10);
}

/* =========================
   AUTH
========================= */
.auth-tabs{
    display:flex;
    gap:10px;
    background:linear-gradient(135deg,#eaf1ff,#f3f7ff);
    padding:8px;
    border-radius:20px;
    margin-bottom:16px;
    border:1px solid rgba(53,94,252,.08);
}

.auth-tab{
    flex:1 1 0;
    border:0;
    border-radius:15px;
    padding:12px 14px;
    font-weight:800;
    color:#173d90;
    background:transparent;
    transition:.25s ease;
}

.auth-tab.active{
    background:linear-gradient(135deg,#ffffff,#f8fbff);
    box-shadow:0 12px 24px rgba(15,23,42,.08);
}

.auth-pane{display:none}
.auth-pane.active{display:block}

.panel-title{
    font-size:1.18rem;
    font-weight:800;
    color:var(--jawda-primary-dark);
    margin-bottom:6px;
}

.panel-subtitle{
    color:var(--jawda-muted);
    font-size:.91rem;
    line-height:1.8;
    margin-bottom:14px;
}

.form-group{margin-bottom:12px}

.form-label{
    display:block;
    margin-bottom:6px;
    font-size:.88rem;
    font-weight:700;
    color:var(--jawda-primary-dark);
}

.form-input,
.form-select{
    width:100%;
    border:1px solid rgba(53,94,252,.12);
    background:linear-gradient(180deg,#f9fbff,#f4f8ff);
    color:var(--jawda-text);
    border-radius:16px;
    padding:13px 14px;
    outline:none;
    transition:.22s ease;
}

.form-input:focus,
.form-select:focus{
    border-color:rgba(53,94,252,.34);
    box-shadow:0 0 0 4px rgba(53,94,252,.10);
    background:#fff;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
}

.form-grid .full{grid-column:1 / -1}

.btn-primary-soft{
    width:100%;
    border:0;
    border-radius:18px;
    padding:14px 16px;
    font-weight:800;
    color:#fff;
    background:linear-gradient(135deg,#173d90 0%, #355efc 55%, #6c8dff 100%);
    box-shadow:0 18px 34px rgba(53,94,252,.24);
    transition:.25s ease;
}

.btn-primary-soft:hover{
    color:#fff;
    transform:translateY(-2px);
    box-shadow:0 24px 40px rgba(53,94,252,.30);
}

.alert-soft{
    padding:13px 14px;
    border-radius:16px;
    font-weight:700;
    margin-bottom:14px;
}

.alert-danger-soft{
    background:linear-gradient(135deg,#fff1f2,#fff7f7);
    color:#b42318;
    border:1px solid #fecdd3;
}

.alert-success-soft{
    background:linear-gradient(135deg,#ecfdf3,#f4fff9);
    color:#027a48;
    border:1px solid #a7f3d0;
}

.alert-warning-soft{
    background:linear-gradient(135deg,#fff8eb,#fffdf5);
    color:#b45309;
    border:1px solid #fde68a;
}

/* =========================
   SECTIONS
========================= */
.section{padding:22px 0 34px}

.section-head{
    display:flex;
    align-items:end;
    justify-content:space-between;
    gap:16px;
    margin-bottom:18px;
}

.section-title,
.teachers-title,
.showcase-title,
.said-title,
.major-hero-title{
    letter-spacing:-.3px;
}

.section-title{
    margin:0;
    font-size:2rem;
    font-weight:800;
    color:var(--jawda-primary-dark);
}

.section-note{
    margin:6px 0 0;
    color:var(--jawda-muted);
    line-height:1.85;
    font-weight:600;
}

.major-filter-shell{
    background:rgba(255,255,255,.78);
    border:1px solid rgba(53,94,252,.12);
    border-radius:28px;
    box-shadow:0 22px 46px rgba(15,23,42,.08);
    padding:18px;
    backdrop-filter:blur(14px);
    margin-bottom:18px;
    position:relative;
    overflow:hidden;
}

.major-filter-shell::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 15% 20%, rgba(53,94,252,.06), transparent 18%),
        linear-gradient(180deg, rgba(255,255,255,.10), transparent 30%);
    pointer-events:none;
}

.major-filter-title{
    position:relative;
    z-index:1;
    font-weight:800;
    color:var(--jawda-primary-dark);
    margin-bottom:12px;
}

.major-btns{
    position:relative;
    z-index:1;
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.major-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 16px;
    border-radius:999px;
    background:linear-gradient(135deg,#eef4ff,#f6f9ff);
    color:#173d90;
    border:1px solid rgba(53,94,252,.14);
    font-weight:800;
    transition:.24s ease;
    box-shadow:0 8px 18px rgba(15,23,42,.04);
}

.major-btn:hover{
    transform:translateY(-2px);
    background:linear-gradient(135deg,#dfe8ff,#edf3ff);
    color:#173d90;
    box-shadow:0 14px 24px rgba(53,94,252,.10);
}

.major-hero{
    margin-bottom:18px;
    padding:24px 24px;
    border-radius:30px;
    background:
        radial-gradient(circle at 15% 20%, rgba(255,255,255,.18), transparent 20%),
        radial-gradient(circle at 85% 80%, rgba(255,255,255,.10), transparent 20%),
        linear-gradient(135deg, rgba(8,27,71,1) 0%, rgba(23,61,144,1) 48%, rgba(53,94,252,1) 100%);
    color:#fff;
    box-shadow:var(--jawda-shadow-lg);
}

.major-hero-title{
    margin:0;
    font-size:2rem;
    font-weight:800;
}

.major-hero-sub{
    margin-top:6px;
    color:rgba(255,255,255,.82);
    font-weight:700;
}

.major-block{margin-bottom:28px}

.major-title{
    font-size:1.35rem;
    font-weight:800;
    color:var(--jawda-primary-dark);
    margin:0 0 4px;
}

.major-code{
    color:var(--jawda-muted);
    font-weight:700;
    margin-bottom:12px;
}

/* =========================
   COMMON SLIDERS
========================= */
.slider-section{
    position:relative;
    background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(248,251,255,.90));
    border:1px solid rgba(53,94,252,.10);
    border-radius:30px;
    padding:20px 64px;
    box-shadow:0 18px 34px rgba(15,23,42,.06);
    overflow:hidden;
}

.course-slider-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    margin-bottom:14px;
    flex-wrap:wrap;
}

.course-slider-note{
    color:var(--jawda-muted);
    font-size:.86rem;
    font-weight:700;
}

.course-slider-shell,
.unified-slider-shell{
    position:relative;
    overflow-x:auto;
    overflow-y:hidden;
    width:100%;
    scroll-behavior:smooth;
    scrollbar-width:none;
    -ms-overflow-style:none;
    cursor:grab;
    touch-action:pan-x pan-y;
    padding-block:10px;
}

.course-slider-shell::-webkit-scrollbar,
.unified-slider-shell::-webkit-scrollbar{
    display:none;
}

.course-slider-shell.dragging,
.unified-slider-shell.dragging{
    cursor:grabbing;
}

.course-slider-track,
.unified-slider-track{
    display:flex;
    gap:18px;
    width:max-content;
    will-change:auto;
    transition:none;
}

.course-nav-btn,
.slider-btn{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:46px;
    height:46px;
    border:none;
    border-radius:50%;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    z-index:10;
    transition:.25s ease;
}

.course-nav-btn{
    background:linear-gradient(135deg,#173d90,#355efc);
    color:#fff;
    box-shadow:0 14px 24px rgba(53,94,252,.22);
}

.slider-btn{
    color:#fff;
    backdrop-filter:blur(10px);
    box-shadow:0 12px 24px rgba(0,0,0,.18);
}

.course-nav-btn:hover,
.slider-btn:hover{
    transform:translateY(-50%) scale(1.06);
}

.course-prev,
.slider-btn.prev{right:10px}

.course-next,
.slider-btn.next{left:10px}

/* =========================
   COURSES
========================= */
.course-slide{
    flex:0 0 248px;
    min-width:248px;
    max-width:248px;
}

.course-card{
    position:relative;
    display:block;
    background:linear-gradient(180deg, rgba(255,255,255,.99) 0%, rgba(247,250,255,.98) 100%);
    border:1px solid rgba(53,94,252,.10);
    border-radius:28px;
    overflow:hidden;
    color:inherit;
    box-shadow:0 14px 28px rgba(15,23,42,.06);
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.course-card::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(135deg, rgba(53,94,252,.07), rgba(23,61,144,.02), rgba(100,134,255,.08));
    opacity:0;
    transition:.35s ease;
    pointer-events:none;
}

.course-card::after{
    content:"";
    position:absolute;
    left:16px;
    right:16px;
    bottom:0;
    height:4px;
    border-radius:999px 999px 0 0;
    background:linear-gradient(90deg, #355efc, #26c6ff, #7b61ff);
    transform:scaleX(.18);
    transform-origin:right center;
    opacity:.9;
    transition:.35s ease;
}

.course-card:hover{
    transform:translateY(-10px) scale(1.02);
    box-shadow:0 30px 52px rgba(53,94,252,.15);
    color:inherit;
    border-color:rgba(53,94,252,.24);
}

.course-card:hover::before{opacity:1}
.course-card:hover::after{transform:scaleX(1)}

.course-card.active-style-1{background:linear-gradient(180deg,#ffffff 0%, #f5f8ff 100%)}
.course-card.active-style-2{background:linear-gradient(180deg,#ffffff 0%, #f4fffb 100%)}
.course-card.active-style-3{background:linear-gradient(180deg,#ffffff 0%, #faf7ff 100%)}
.course-card.active-style-4{background:linear-gradient(180deg,#ffffff 0%, #fff8f2 100%)}

.course-thumb{
    position:relative;
    aspect-ratio:16/6.9;
    overflow:hidden;
    background:
        radial-gradient(circle at 25% 22%, rgba(255,255,255,.40), transparent 18%),
        linear-gradient(135deg, #dfe9ff 0%, #eff5ff 48%, #f9fbff 100%);
}

.course-thumb::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, transparent 0%, rgba(7,24,63,.06) 100%);
    z-index:1;
    pointer-events:none;
}

.course-thumb::after{
    content:"";
    position:absolute;
    width:136px;
    height:136px;
    border-radius:50%;
    left:-28px;
    top:-46px;
    background:radial-gradient(circle, rgba(53,94,252,.14), transparent 66%);
    z-index:1;
    pointer-events:none;
}

.course-image-ring{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:2;
    padding-top:0;
}

.course-image-ring::before{
    content:"";
    position:absolute;
    width:88px;
    height:88px;
    border-radius:50%;
    background:linear-gradient(135deg, rgba(53,94,252,.16), rgba(38,198,255,.16), rgba(123,97,255,.14));
    box-shadow:0 10px 24px rgba(53,94,252,.10);
}

.course-image-ring img{
    position:relative;
    width:64px;
    height:64px;
    border-radius:50%;
    object-fit:cover;
    border:4px solid rgba(255,255,255,.95);
    box-shadow:0 10px 20px rgba(15,23,42,.11);
    display:block;
    transition:transform .55s ease, filter .55s ease;
    background:#fff;
}

.course-card:hover .course-image-ring img{
    transform:scale(1.08) rotate(-2deg);
    filter:saturate(1.06) contrast(1.03);
}

.course-orb{
    position:absolute;
    width:78px;
    height:78px;
    border-radius:50%;
    top:-12px;
    right:-12px;
    background:radial-gradient(circle, rgba(255,255,255,.74) 0%, rgba(255,255,255,.18) 42%, transparent 72%);
    pointer-events:none;
    z-index:2;
}

.course-body{
    padding:12px 13px 13px;
    position:relative;
    z-index:2;
    text-align:right;
}

.course-code{
    display:inline-flex;
    align-items:center;
    gap:7px;
    padding:6px 10px;
    border-radius:999px;
    font-size:.7rem;
    font-weight:800;
    margin-bottom:8px;
    box-shadow:0 8px 18px rgba(15,23,42,.05);
    direction:ltr;
}

.active-style-1 .course-code{background:linear-gradient(135deg,#e9f0ff,#f7faff);color:#173d90;}
.active-style-2 .course-code{background:linear-gradient(135deg,#e8fff7,#f6fffb);color:#0f766e;}
.active-style-3 .course-code{background:linear-gradient(135deg,#f1ebff,#faf7ff);color:#6d28d9;}
.active-style-4 .course-code{background:linear-gradient(135deg,#fff1e6,#fff8f2);color:#c2410c;}

.course-name{
    font-size:.92rem;
    font-weight:800;
    margin:0 0 7px;
    color:var(--jawda-text);
    min-height:38px;
    line-height:1.48;
}

.course-card:hover .course-name{
    color:#173d90;
}

.state-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin-top:9px;
    padding:8px 11px;
    border-radius:13px;
    font-size:.74rem;
    font-weight:800;
    box-shadow:0 8px 18px rgba(15,23,42,.05);
}

.badge-free{
    background:linear-gradient(135deg,#fff6df,#fffdf5);
    color:#b45309;
    border:1px solid #fde68a;
}

.badge-open{
    background:linear-gradient(135deg,#e8fff2,#f7fffb);
    color:#027a48;
    border:1px solid #a7f3d0;
}

.badge-locked{
    background:linear-gradient(135deg,#eef4ff,#f8fbff);
    color:#173d90;
    border:1px solid rgba(53,94,252,.16);
}

.course-actions{
    margin-top:8px;
    display:flex;
    align-items:center;
}

.course-btn{
    width:100%;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    border:0;
    border-radius:15px;
    padding:11px 12px;
    font-weight:800;
    font-size:.83rem;
    transition:.25s ease;
}

.whatsapp-btn{
    color:#fff;
    background:linear-gradient(135deg,#0f8f63,#25d366);
    box-shadow:0 16px 26px rgba(37,211,102,.22);
}

.whatsapp-btn:hover{
    color:#fff;
    transform:translateY(-2px);
    box-shadow:0 22px 34px rgba(37,211,102,.28);
}

.whatsapp-btn.disabled,
.whatsapp-btn:disabled{
    background:linear-gradient(135deg,#cbd5e1,#e2e8f0);
    color:#64748b;
    box-shadow:none;
    cursor:not-allowed;
}

/* =========================
   TEACHERS
========================= */
.teachers-slider-wrap{
    position:relative;
    overflow:hidden;
    border-radius:34px;
    padding:26px 56px;
    border:1px solid rgba(255,255,255,.08);
    background:
        radial-gradient(circle at 12% 18%, rgba(255,255,255,.14), transparent 16%),
        radial-gradient(circle at 82% 24%, rgba(38,198,255,.16), transparent 18%),
        radial-gradient(circle at 88% 78%, rgba(123,97,255,.16), transparent 20%),
        linear-gradient(135deg, var(--jawda-navy) 0%, var(--jawda-navy-2) 42%, var(--jawda-navy-3) 100%);
    box-shadow:
        0 30px 84px rgba(8,27,71,.22),
        inset 0 1px 0 rgba(255,255,255,.06);
}

.teachers-slider-wrap::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(180deg, rgba(255,255,255,.04), transparent 28%),
        radial-gradient(circle at 20% 30%, rgba(255,255,255,.08), transparent 18%);
    opacity:.95;
}

.teachers-slider-wrap::after{
    content:"";
    position:absolute;
    inset:auto 0 0 0;
    height:120px;
    pointer-events:none;
    background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.10) 100%);
}

.teachers-head{
    position:relative;
    z-index:1;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:12px;
    margin-bottom:16px;
}

.teachers-title{
    color:#fff;
    font-size:2rem;
    font-weight:800;
    margin:0;
    text-shadow:0 6px 18px rgba(0,0,0,.18);
}

.teachers-note{
    margin:6px 0 0;
    color:rgba(255,255,255,.78);
    font-weight:600;
}

#teachers .slider-btn{
    background:linear-gradient(135deg, rgba(255,255,255,.24), rgba(255,255,255,.10));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:
        0 14px 28px rgba(0,0,0,.22),
        inset 0 1px 0 rgba(255,255,255,.10);
}

#teachers .slider-btn:hover{
    background:linear-gradient(135deg, rgba(255,255,255,.30), rgba(255,255,255,.14));
}

.teacher-card{
    min-width:194px;
    max-width:194px;
    flex:0 0 auto;
    position:relative;
    overflow:hidden;
    border-radius:26px;
    padding:16px 14px;
    text-align:center;
    backdrop-filter:blur(14px);
    background:linear-gradient(180deg, rgba(255,255,255,.17), rgba(255,255,255,.08));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:
        0 16px 34px rgba(0,0,0,.16),
        inset 0 1px 0 rgba(255,255,255,.08);
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.teacher-card::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(135deg, rgba(255,255,255,.12), transparent 58%),
        radial-gradient(circle at 85% 18%, rgba(38,198,255,.14), transparent 22%);
    opacity:0;
    transition:.35s ease;
    pointer-events:none;
}

.teacher-card::after{
    content:"";
    position:absolute;
    left:16px;
    right:16px;
    bottom:0;
    height:4px;
    border-radius:999px 999px 0 0;
    background:linear-gradient(90deg, #26c6ff, #8fb2ff, #7b61ff);
    transform:scaleX(.18);
    transform-origin:right center;
    transition:.35s ease;
    opacity:.95;
}

.teacher-card:hover{
    transform:translateY(-8px) scale(1.02);
    border-color:rgba(255,255,255,.24);
    box-shadow:
        0 26px 46px rgba(0,0,0,.20),
        0 0 0 1px rgba(255,255,255,.04) inset;
}

.teacher-card:hover::before{opacity:1}
.teacher-card:hover::after{transform:scaleX(1)}

.teacher-avatar{
    width:66px;
    height:66px;
    margin:0 auto 10px;
    border-radius:50%;
    overflow:hidden;
    position:relative;
    background:#dbe8ff;
    border:3px solid rgba(255,255,255,.42);
    box-shadow:
        0 10px 20px rgba(0,0,0,.16),
        0 0 0 6px rgba(255,255,255,.03);
}

.teacher-avatar::before{
    content:"";
    position:absolute;
    inset:-12px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(38,198,255,.20), transparent 62%);
    pointer-events:none;
}

.teacher-avatar img{
    position:relative;
    z-index:1;
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .45s ease, filter .45s ease;
}

.teacher-card:hover .teacher-avatar img{
    transform:scale(1.08);
    filter:saturate(1.06) contrast(1.03);
}

.teacher-name{
    font-size:.92rem;
    font-weight:800;
    color:#fff;
    margin:0;
    line-height:1.45;
    text-shadow:0 4px 14px rgba(0,0,0,.16);
}

.teacher-tag{
    margin-top:6px;
    color:rgba(255,255,255,.74);
    font-size:.72rem;
    font-weight:700;
    letter-spacing:.2px;
}

/* =========================
   SAID ABOUT US
========================= */
.said-slider-wrap{
    position:relative;
    overflow:hidden;
    border-radius:34px;
    background:
        radial-gradient(circle at 15% 20%, rgba(255,255,255,.56), transparent 18%),
        radial-gradient(circle at 85% 70%, rgba(143,178,255,.18), transparent 20%),
        linear-gradient(135deg, #f9fbff 0%, #eef4ff 45%, #e8f1ff 100%);
    box-shadow:0 30px 84px rgba(23,61,144,.10);
    padding:26px 56px;
    border:1px solid rgba(53,94,252,.12);
}

.said-slider-wrap::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(180deg, rgba(255,255,255,.10), transparent 28%),
        radial-gradient(circle at 18% 26%, rgba(53,94,252,.06), transparent 18%);
}

.said-head{
    position:relative;
    z-index:1;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:12px;
    margin-bottom:16px;
}

.said-title{
    font-size:2rem;
    font-weight:800;
    margin:0;
    color:var(--jawda-primary-dark);
}

.said-note{
    margin:6px 0 0;
    color:var(--jawda-muted);
    font-weight:600;
}

#said-about-us .slider-btn{
    background:linear-gradient(135deg, rgba(53,94,252,.14), rgba(53,94,252,.08));
    color:var(--jawda-primary-dark);
    box-shadow:0 12px 24px rgba(53,94,252,.14);
}

.said-card{
    min-width:300px;
    max-width:300px;
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,255,.98));
    border:1px solid rgba(53,94,252,.12);
    border-radius:28px;
    padding:18px 16px;
    color:var(--jawda-text);
    box-shadow:0 16px 32px rgba(15,23,42,.08);
    flex:0 0 auto;
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
    position:relative;
    overflow:hidden;
}

.said-card::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(135deg, rgba(53,94,252,.06), rgba(38,198,255,.04), transparent 60%);
    opacity:0;
    transition:.35s ease;
    pointer-events:none;
}

.said-card::after{
    content:"";
    position:absolute;
    left:18px;
    right:18px;
    bottom:0;
    height:4px;
    border-radius:999px 999px 0 0;
    background:linear-gradient(90deg, #355efc, #26c6ff, #7b61ff);
    transform:scaleX(.20);
    transform-origin:right center;
    transition:.35s ease;
}

.said-card:hover{
    transform:translateY(-8px) scale(1.02);
    box-shadow:0 28px 46px rgba(53,94,252,.14);
    border-color:rgba(53,94,252,.22);
}

.said-card:hover::before{opacity:1}
.said-card:hover::after{transform:scaleX(1)}

.said-quote-icon{
    width:40px;
    height:40px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#eef4ff,#f8fbff);
    color:var(--jawda-primary-dark);
    font-size:.96rem;
    margin-bottom:12px;
    border:1px solid rgba(53,94,252,.12);
    box-shadow:0 10px 22px rgba(53,94,252,.08);
}

.said-stars{
    display:flex;
    gap:5px;
    margin-bottom:14px;
}

.said-stars i{
    color:#d6dbe7;
    font-size:.92rem;
}

.said-stars i.active{
    color:var(--jawda-gold);
}

.said-text{
    font-size:.86rem;
    line-height:1.9;
    color:var(--jawda-text);
    min-height:96px;
    font-weight:600;
}

.said-user{
    display:flex;
    align-items:center;
    gap:12px;
    margin-top:14px;
    padding-top:14px;
    border-top:1px solid rgba(53,94,252,.10);
}

.said-avatar{
    width:40px;
    height:40px;
    border-radius:50%;
    overflow:hidden;
    flex-shrink:0;
    border:2px solid rgba(53,94,252,.14);
    background:#dbe8ff;
    box-shadow:0 8px 16px rgba(53,94,252,.08);
}

.said-avatar img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .45s ease;
}

.said-card:hover .said-avatar img{
    transform:scale(1.08);
}

.said-meta{min-width:0}

.said-name{
    font-size:.9rem;
    font-weight:800;
    color:var(--jawda-primary-dark);
    line-height:1.3;
}

.said-major{
    margin-top:4px;
    color:var(--jawda-muted);
    font-size:.76rem;
    font-weight:700;
    direction:ltr;
}

/* =========================
   STUDENT HIGHLIGHTS
========================= */
.showcase-slider-wrap{
    position:relative;
    overflow:hidden;
    border-radius:34px;
    padding:26px 56px;
    border:1px solid rgba(53,94,252,.10);
    background:
        radial-gradient(circle at 12% 18%, rgba(255,255,255,.22), transparent 18%),
        radial-gradient(circle at 88% 74%, rgba(143,178,255,.18), transparent 20%),
        linear-gradient(135deg, #eef4ff 0%, #f8fbff 52%, #e8f1ff 100%);
    box-shadow:0 30px 84px rgba(23,61,144,.10);
}

.showcase-slider-wrap::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(180deg, rgba(255,255,255,.10), transparent 26%),
        radial-gradient(circle at 20% 28%, rgba(53,94,252,.06), transparent 20%);
}

.showcase-head{
    position:relative;
    z-index:1;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:12px;
    margin-bottom:16px;
}

.showcase-title{
    font-size:2rem;
    font-weight:800;
    margin:0;
    color:var(--jawda-primary-dark);
}

.showcase-note{
    margin:6px 0 0;
    color:var(--jawda-muted);
    font-weight:600;
}

#student-highlights .slider-btn{
    background:linear-gradient(135deg, rgba(53,94,252,.14), rgba(53,94,252,.08));
    color:var(--jawda-primary-dark);
    box-shadow:0 12px 24px rgba(53,94,252,.14);
}

.showcase-card{
    min-width:255px;
    max-width:255px;
    background:linear-gradient(180deg, rgba(255,255,255,.99), rgba(247,250,255,.98));
    border:1px solid rgba(53,94,252,.12);
    border-radius:28px;
    overflow:hidden;
    box-shadow:0 16px 32px rgba(15,23,42,.08);
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
    flex:0 0 auto;
    position:relative;
}

.showcase-card::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(135deg, rgba(53,94,252,.06), rgba(38,198,255,.04), transparent 60%);
    opacity:0;
    transition:.35s ease;
    pointer-events:none;
    z-index:1;
}

.showcase-card::after{
    content:"";
    position:absolute;
    left:18px;
    right:18px;
    bottom:0;
    height:4px;
    border-radius:999px 999px 0 0;
    background:linear-gradient(90deg, #355efc, #26c6ff, #7b61ff);
    transform:scaleX(.20);
    transform-origin:right center;
    transition:.35s ease;
    z-index:2;
}

.showcase-card:hover{
    transform:translateY(-8px) scale(1.02);
    box-shadow:0 28px 46px rgba(53,94,252,.14);
    border-color:rgba(53,94,252,.22);
}

.showcase-card:hover::before{opacity:1}
.showcase-card:hover::after{transform:scaleX(1)}

.showcase-image{
    height:142px;
    background:#dce7ff;
    overflow:hidden;
    position:relative;
}

.showcase-image::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, transparent 0%, rgba(23,61,144,.08) 100%);
    pointer-events:none;
}

.showcase-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .55s ease, filter .55s ease;
}

.showcase-card:hover .showcase-image img{
    transform:scale(1.08);
    filter:saturate(1.06);
}

.showcase-body{
    padding:14px;
    color:var(--jawda-text);
    text-align:right;
    position:relative;
    z-index:2;
}

.showcase-kind{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:6px 10px;
    border-radius:999px;
    background:linear-gradient(135deg,#eef4ff,#f8fbff);
    color:var(--jawda-primary-dark);
    font-size:.7rem;
    font-weight:800;
    margin-bottom:10px;
    border:1px solid rgba(53,94,252,.12);
}

.showcase-name{
    font-size:.92rem;
    font-weight:800;
    line-height:1.45;
    margin-bottom:4px;
    color:var(--jawda-primary-dark);
}

.showcase-sub{
    color:var(--jawda-muted);
    font-size:.8rem;
    font-weight:700;
    margin-bottom:8px;
}

.showcase-text{
    font-size:.8rem;
    line-height:1.75;
    color:var(--jawda-text);
    min-height:40px;
}

.showcase-badge{
    margin-top:10px;
    display:inline-flex;
    padding:6px 10px;
    border-radius:999px;
    background:rgba(53,94,252,.08);
    color:var(--jawda-primary-dark);
    font-size:.7rem;
    font-weight:800;
    direction:ltr;
}

/* =========================
   OTHERS
========================= */
.empty-box{
    padding:20px;
    border-radius:24px;
    background:linear-gradient(135deg,#ffffff,#f8fbff);
    border:1px dashed rgba(53,94,252,.24);
    color:var(--jawda-muted);
    font-weight:700;
    box-shadow:0 12px 24px rgba(15,23,42,.04);
}

.footer-space{height:28px}

.course-top-badge{
    position:absolute;
    top:12px;
    right:12px;
    z-index:3;
    padding:7px 12px;
    border-radius:999px;
    background:linear-gradient(135deg, rgba(7,24,63,.88), rgba(53,94,252,.88));
    color:#fff;
    font-size:.75rem;
    font-weight:800;
    box-shadow:0 10px 20px rgba(0,0,0,.16);
    direction:ltr;
}

.focus-login{
    animation:focusPulse .9s ease;
}

@keyframes focusPulse{
    0%{transform:translateY(0); box-shadow:0 0 0 0 rgba(53,94,252,.24)}
    50%{transform:translateY(-4px); box-shadow:0 0 0 12px rgba(53,94,252,.10)}
    100%{transform:translateY(0); box-shadow:0 0 0 0 rgba(53,94,252,0)}
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1199px){
    .hero-grid{grid-template-columns:1fr}

    .course-slide{
        flex:0 0 232px;
        min-width:232px;
        max-width:232px;
    }

    .teacher-card{
        min-width:184px;
        max-width:184px;
    }

    .said-card{
        min-width:285px;
        max-width:285px;
    }

    .showcase-card{
        min-width:240px;
        max-width:240px;
    }
}

@media (max-width: 991px){
    .topbar-inner{
        align-items:flex-start;
        flex-direction:column;
    }

    .top-actions{
        width:100%;
        justify-content:space-between;
    }

    .slider-section{
        padding:18px 56px;
    }

    .teachers-slider-wrap,
    .showcase-slider-wrap,
    .said-slider-wrap{
        padding:22px 46px;
    }
}

@media (max-width: 767px){
    .container-soft{width:min(100% - 16px, 100%)}

    .form-grid{grid-template-columns:1fr}

    .profile-trigger{min-width:100%}

    .section-head{
        flex-direction:column;
        align-items:flex-start;
    }

    .hero-main{
        min-height:auto;
        padding:22px 18px;
    }

    .hero-side{padding:14px}

    .course-slide{
        flex:0 0 204px;
        min-width:204px;
        max-width:204px;
    }

    .course-thumb{
        aspect-ratio:16/6.8;
    }

    .course-image-ring::before{
        width:76px;
        height:76px;
    }

    .course-image-ring img{
        width:54px;
        height:54px;
        border-width:3px;
    }

    .course-name{
        font-size:.85rem;
        min-height:34px;
    }

    .teacher-card{
        min-width:164px;
        max-width:164px;
        padding:14px 12px;
    }

    .teacher-avatar{
        width:54px;
        height:54px;
        margin-bottom:8px;
    }

    .teacher-name{
        font-size:.84rem;
    }

    .teacher-tag{
        font-size:.68rem;
    }

    .showcase-card{
        min-width:215px;
        max-width:215px;
    }

    .showcase-image{
        height:118px;
    }

    .showcase-name{
        font-size:.84rem;
    }

    .showcase-text{
        font-size:.76rem;
        min-height:34px;
    }

    .said-card{
        min-width:240px;
        max-width:240px;
        padding:16px 14px;
    }

    .said-avatar{
        width:34px;
        height:34px;
    }

    .said-text{
        min-height:84px;
        font-size:.8rem;
        line-height:1.8;
    }

    .said-name{
        font-size:.84rem;
    }

    .said-major{
        font-size:.72rem;
    }

    .teachers-slider-wrap,
    .showcase-slider-wrap,
    .said-slider-wrap{
        padding:20px 40px;
    }

    .major-btns{gap:8px}

    .major-btn{
        padding:9px 13px;
        font-size:.88rem;
    }

    .section-title,
    .teachers-title,
    .showcase-title,
    .said-title{
        font-size:1.65rem;
    }

    .slider-section{
        padding:18px 50px;
    }

    .course-nav-btn,
    .slider-btn{
        width:42px;
        height:42px;
    }

    .course-prev,
    .slider-btn.prev{right:8px}

    .course-next,
    .slider-btn.next{left:8px}
}