/* =========================================================
   Diyanet-Sen Akademi — Modern theme overrides (PORT)
   Bootstrap 5 üzerine zengin görsel katman:
   - Renk paleti, gradient'ler
   - Kart hover animasyonları, gölge sistemleri
   - Hero, badge, stat-card, course-card, menu-card
   - Quiz / sınav modernizasyonu
   - PDF / video sayfaları için sade düzen
   ========================================================= */

:root {
    --brand: #204295;
    --brand-600: #1b3a85;
    --brand-700: #16306f;
    --brand-50:  #eaf0ff;
    --brand-100: #d8e2ff;
    --brand-soft: #f4f7ff;
    --accent: #ffb400;
    --accent-soft: #fff7e0;
    --ink: #16213e;
    --ink-soft: #4e5772;
    --muted: #8893a6;
    --surface: #ffffff;
    --bg: #f5f7fb;
    --line: #e6ebf3;
    --shadow-xs: 0 1px 2px rgba(20,30,60,.04);
    --shadow-sm: 0 2px 6px rgba(20,30,60,.06), 0 1px 3px rgba(20,30,60,.04);
    --shadow-md: 0 6px 16px rgba(20,30,60,.08), 0 12px 32px rgba(20,30,60,.06);
    --shadow-lg: 0 14px 40px rgba(20,30,60,.12), 0 30px 60px rgba(20,30,60,.08);
    --radius-sm: 10px;
    --radius:    16px;
    --radius-lg: 22px;
    --grad-hero: linear-gradient(135deg, #1f3a8f 0%, #2952c8 60%, #3b6dff 100%);
    --grad-warm: linear-gradient(135deg, #ff9a3c 0%, #ffb74d 100%);
    --grad-green: linear-gradient(135deg, #16a34a 0%, #4ade80 100%);
    --grad-pink: linear-gradient(135deg, #d946a3 0%, #f472b6 100%);
    --grad-violet: linear-gradient(135deg, #6d28d9 0%, #a78bfa 100%);
    --grad-cyan: linear-gradient(135deg, #0284c7 0%, #38bdf8 100%);
    --grad-rose: linear-gradient(135deg, #e11d48 0%, #fb7185 100%);
}

html, body {
    background: var(--bg) !important;
    color: var(--ink) !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Heebo', 'Roboto', "Segoe UI", sans-serif !important;
    -webkit-font-smoothing: antialiased;
}

a { transition: color .15s ease; }

/* =========================================================
   NAVBAR
   ========================================================= */
.navbar {
    background: rgba(255,255,255,.95) !important;
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--line);
    padding-top: 14px !important;
    padding-bottom: 14px !important;
}
.navbar-brand img { max-height: 44px; }
.navbar-nav .nav-link {
    color: var(--ink-soft) !important;
    font-weight: 500 !important;
    padding: 8px 14px !important;
    border-radius: 8px;
    transition: background .15s ease, color .15s ease;
    margin: 0 2px;
}
.navbar-nav .nav-link:hover, .navbar-nav .nav-item.dropdown:hover .nav-link {
    color: var(--brand) !important;
    background: var(--brand-50);
}
.navbar-nav .dropdown-menu {
    border: 1px solid var(--line);
    border-radius: 14px !important;
    box-shadow: var(--shadow-md);
    padding: 8px !important;
    margin-top: 8px !important;
}
.navbar-nav .dropdown-menu .dropdown-item {
    border-radius: 10px;
    padding: 10px 14px !important;
    font-size: 14px;
    color: var(--ink) !important;
    transition: background .15s ease, color .15s ease;
}
.navbar-nav .dropdown-menu .dropdown-item:hover {
    background: var(--brand-50) !important;
    color: var(--brand) !important;
}
.navbar .avatar-img {
    border: 2px solid var(--line);
    width: 40px !important; height: 40px !important;
    transition: border-color .15s ease, transform .15s ease;
}
.navbar .avatar:hover .avatar-img { border-color: var(--brand); transform: scale(1.04); }

/* navbar-transparent (anasayfa) */
.navbar-transparent { background: rgba(255,255,255,0) !important; backdrop-filter: none; -webkit-backdrop-filter: none; border-bottom-color: rgba(255,255,255,.08); }
.navbar-transparent .nav-link, .navbar-transparent .nav-link:hover { color: var(--ink) !important; }

/* =========================================================
   HERO / SECTION BANNER
   ========================================================= */
section.bg-blue, section.bg-dark {
    background: var(--grad-hero) !important;
    padding-top: 44px !important; padding-bottom: 52px !important;
    position: relative; overflow: hidden;
    border-radius: 0 0 26px 26px;
    margin-bottom: 12px;
}
section.bg-blue h1, section.bg-dark h1 {
    font-size: clamp(1.4rem, 2.8vw, 1.9rem) !important;
    margin-bottom: 8px !important;
}
/* Osmanlı görsel pattern (banner arka planı) */
section.bg-blue::before, section.bg-dark::before {
    content:""; position:absolute; inset:0;
    background: url("/diyanet_akademi/public/port/images/osmanli4.png") center/cover no-repeat;
    opacity: 0.35;
    mix-blend-mode: soft-light;
    pointer-events:none;
}
/* Radyal vurgular ayrı katman */
section.bg-blue::after, section.bg-dark::after {
    content:""; position:absolute; inset:0;
    background:
        radial-gradient(circle at 80% 20%, rgba(255,255,255,.16) 0%, rgba(255,255,255,0) 40%),
        radial-gradient(circle at 10% 80%, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 35%);
    pointer-events:none;
}
section.bg-blue > *, section.bg-dark > * { position: relative; z-index: 1; }
section.bg-blue h1, section.bg-dark h1 {
    font-size: clamp(1.7rem, 4vw, 2.4rem) !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em;
    color:#fff !important;
    margin-bottom: 14px !important;
}
section.bg-blue .breadcrumb, section.bg-dark .breadcrumb {
    background: rgba(255,255,255,.12);
    padding: 8px 16px;
    border-radius: 999px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.breadcrumb-item, .breadcrumb-item a, .breadcrumb-item.active {
    color: rgba(255,255,255,.92) !important;
    font-size: 13px;
}
.breadcrumb-item a:hover { color:#fff !important; text-decoration: underline; }
.breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255,255,255,.5) !important;
    content: "›" !important;
    padding: 0 8px;
}
.breadcrumb-dots .breadcrumb-item + .breadcrumb-item::before { content: "›" !important; }

/* =========================================================
   ANASAYFA HERO (özel)
   ========================================================= */
.home-hero {
    background: var(--grad-hero);
    position: relative;
    overflow: hidden;
    border-radius: 0 0 36px 36px;
    margin-bottom: 32px;
    padding: 70px 0 80px;
    color:#fff;
}
.home-hero::before {
    content:""; position:absolute; inset:0;
    background: url("/diyanet_akademi/public/port/images/osmanli4.png") center/cover no-repeat;
    opacity: 0.40;
    mix-blend-mode: soft-light;
    pointer-events:none;
}
.home-hero::after {
    content:""; position:absolute; inset:0;
    background:
        radial-gradient(circle at 85% 30%, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 40%),
        radial-gradient(circle at 15% 70%, rgba(255,180,0,.18) 0%, rgba(255,255,255,0) 40%);
    pointer-events:none;
}
.home-hero .inner { position: relative; z-index: 1; }
.home-hero .eyebrow {
    display:inline-flex; align-items:center; gap:8px;
    background: rgba(255,255,255,.16);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 12.5px; font-weight: 600;
    letter-spacing: .04em; text-transform: uppercase;
    color:#fff;
    margin-bottom: 18px;
}
.home-hero h1 {
    font-size: clamp(1.9rem, 4.2vw, 2.8rem);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color:#fff;
    margin-bottom: 14px;
}
.home-hero p.lead {
    font-size: clamp(1rem, 1.5vw, 1.15rem);
    color: rgba(255,255,255,.92);
    max-width: 580px;
    margin-bottom: 22px;
    line-height: 1.55;
}
.home-hero .hero-cta {
    display:inline-flex; align-items:center; gap:10px;
    background:#fff; color: var(--brand) !important;
    padding: 12px 24px;
    border-radius: 999px;
    font-weight: 600; font-size: 15px;
    box-shadow: 0 10px 24px rgba(0,0,0,.18);
    transition: transform .15s ease, box-shadow .2s ease;
    text-decoration: none !important;
}
.home-hero .hero-cta:hover { transform: translateY(-2px); box-shadow: 0 16px 32px rgba(0,0,0,.22); color: var(--brand-700) !important; }
.home-hero .hero-cta.outline {
    background: transparent; color:#fff !important;
    border: 1.5px solid rgba(255,255,255,.5);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    box-shadow: none;
}
.home-hero .hero-cta.outline:hover { background: rgba(255,255,255,.12); border-color:#fff; color:#fff !important; }

/* hero stats */
.home-hero .stats {
    display:grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 14px; margin-top: 36px;
}
.home-hero .stat {
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.22);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    border-radius: 14px;
    padding: 16px 18px;
}
.home-hero .stat .v { font-size: 1.6rem; font-weight: 800; color:#fff; line-height: 1; }
.home-hero .stat .l { font-size: 12.5px; color: rgba(255,255,255,.88); margin-top: 6px; text-transform: uppercase; letter-spacing: .04em; }
.home-hero .stat ion-icon, .home-hero .stat .icon { font-size: 18px; color: var(--accent); }

.home-hero .illustration {
    position: relative;
    text-align: right;
}
.home-hero .illustration img { max-width: 100%; max-height: 360px; filter: drop-shadow(0 20px 30px rgba(0,0,0,.25)); }

/* =========================================================
   SECTION TITLES
   ========================================================= */
section h2 {
    font-size: clamp(1.4rem, 2.5vw, 1.9rem) !important;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -0.01em;
}
section h2 + p { color: var(--ink-soft); font-size: 15px; }
.section-eyebrow {
    display:inline-block;
    color: var(--brand);
    font-size: 12.5px; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    margin-bottom: 8px;
}

/* =========================================================
   COURSE CARD (anasayfa + courses/list ortak)
   ========================================================= */
.card {
    border: 1px solid var(--line) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease;
    overflow: hidden;
    background: var(--surface) !important;
}
.card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md) !important;
    border-color: #d3dcec;
}
.card .card-img-top {
    aspect-ratio: 16/10;
    object-fit: cover;
    transition: transform .4s ease;
}
.card:hover .card-img-top { transform: scale(1.05); }
.card-image-scale { overflow: hidden; border-radius: 12px; }

.card .card-title, .card .card-title a {
    font-size: 1.05rem !important;
    color: var(--ink) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.card .card-body p, .card .card-body .text-truncate-2 {
    color: var(--ink-soft) !important;
    font-size: 13.5px; line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.card .card-footer {
    background: transparent !important;
    border-top: 1px solid var(--line) !important;
    padding-top: 12px !important;
}
.card .card-footer hr { display: none !important; }
.card .card-footer .h6 {
    font-size: 12.5px !important;
    color: var(--ink-soft) !important;
    font-weight: 500 !important;
}
.card .card-footer i { font-size: 13px; }

/* Badge yarı saydam üstünde */
.card .thumb-wrap {
    position: relative;
    overflow: hidden;
}
.card .card-badge {
    position: absolute; top: 12px; left: 12px;
    background: rgba(255,255,255,.92);
    color: var(--brand);
    font-size: 11px; font-weight: 700;
    padding: 5px 11px; border-radius: 999px;
    backdrop-filter: blur(8px);
    letter-spacing: .04em;
    z-index: 2;
}
.card .card-badge.--watched { background: rgba(22,163,74,.92); color:#fff; }

/* =========================================================
   COURSE MENU CARDS (eğitim detayı 5 kart)
   ========================================================= */
.menu-card {
    position: relative;
    display:flex; flex-direction:column; gap: 14px;
    padding: 28px 24px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease;
    overflow: hidden;
    min-height: 200px;
    height: 100%;
}
.menu-card::before {
    content:""; position:absolute; top:0; left:0; right:0; height: 4px;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    background: var(--grad-warm);
    transition: height .2s ease;
}
.menu-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
    border-color: transparent;
}
.menu-card:hover::before { height: 6px; }
.menu-card .icon-box {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: var(--grad-warm);
    color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size: 26px;
    box-shadow: 0 8px 20px rgba(255,154,60,.30);
    transition: transform .2s ease;
}
.menu-card:hover .icon-box { transform: scale(1.08) rotate(-3deg); }
.menu-card .menu-title { font-size: 1.1rem; font-weight: 700; color: var(--ink); margin: 0; }
.menu-card .menu-desc { font-size: 13.5px; color: var(--ink-soft); margin: 0; line-height: 1.55; }
.menu-card .menu-meta {
    display:flex; align-items:center; justify-content:space-between;
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    font-size: 12.5px;
}
.menu-card .menu-count {
    display:inline-flex; align-items:center; gap:6px;
    color: var(--ink-soft); font-weight: 600;
}
.menu-card .menu-cta {
    color: var(--brand); font-weight: 700;
    display:inline-flex; align-items:center; gap: 4px;
    text-decoration: none !important;
}
.menu-card .menu-cta::after { content:"→"; transition: transform .15s ease; }
.menu-card:hover .menu-cta::after { transform: translateX(4px); }

/* varyant renkleri */
.menu-card.--book::before    { background: var(--grad-warm); }
.menu-card.--book .icon-box  { background: var(--grad-warm); box-shadow: 0 8px 20px rgba(255,154,60,.30); }
.menu-card.--video::before   { background: var(--grad-rose); }
.menu-card.--video .icon-box { background: var(--grad-rose); box-shadow: 0 8px 20px rgba(225,29,72,.28); }
.menu-card.--unite::before   { background: var(--grad-green); }
.menu-card.--unite .icon-box { background: var(--grad-green); box-shadow: 0 8px 20px rgba(22,163,74,.30); }
.menu-card.--exam::before    { background: var(--grad-cyan); }
.menu-card.--exam .icon-box  { background: var(--grad-cyan); box-shadow: 0 8px 20px rgba(2,132,199,.28); }
.menu-card.--old::before     { background: var(--grad-violet); }
.menu-card.--old .icon-box   { background: var(--grad-violet); box-shadow: 0 8px 20px rgba(109,40,217,.28); }

/* =========================================================
   STATS ROW (eğitim detayı / kategori sayfaları header altı)
   ========================================================= */
.stat-row {
    display:grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 14px; margin-bottom: 32px;
}
.stat-card {
    background:#fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 16px 18px;
    display:flex; align-items:center; gap: 14px;
    box-shadow: var(--shadow-xs);
    transition: transform .15s ease, box-shadow .2s ease;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.stat-card .ic {
    width: 44px; height: 44px;
    border-radius: 12px;
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size: 18px;
    background: var(--grad-cyan);
    flex-shrink: 0;
}
.stat-card .ic.--warm  { background: var(--grad-warm); }
.stat-card .ic.--rose  { background: var(--grad-rose); }
.stat-card .ic.--green { background: var(--grad-green); }
.stat-card .ic.--violet{ background: var(--grad-violet); }
.stat-card .v { font-size: 1.25rem; font-weight: 800; color: var(--ink); line-height: 1.1; }
.stat-card .l { font-size: 12.5px; color: var(--muted); margin-top: 2px; }

/* =========================================================
   VIDEO / EBOOK / TEST CARD (kategori grid'leri)
   ========================================================= */
.media-card .thumb-wrap { position: relative; }
.media-card .play-overlay {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.6) 100%);
    transition: background .2s ease;
}
.media-card:hover .play-overlay { background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.65) 100%); }
.media-card .play-overlay .play-icon {
    width: 60px; height: 60px;
    border-radius: 50%;
    background: rgba(255,255,255,.95);
    display:flex; align-items:center; justify-content:center;
    color: var(--brand); font-size: 22px;
    box-shadow: 0 10px 24px rgba(0,0,0,.30);
    transition: transform .2s ease, background .2s ease;
}
.media-card:hover .play-overlay .play-icon { transform: scale(1.10); background:#fff; }
.media-card .pdf-icon-cover {
    aspect-ratio: 4/3;
    background: linear-gradient(135deg,#fff7e6 0%, #ffe8b3 100%);
    display:flex; align-items:center; justify-content:center;
    position:relative;
    overflow: hidden;
}
.media-card .pdf-icon-cover::after {
    content:""; position:absolute; left:0; top:0; bottom:0; width: 4px;
    background: var(--grad-warm);
}
.media-card .pdf-icon-cover i {
    font-size: 64px;
    color: #e07a00;
    filter: drop-shadow(0 10px 18px rgba(0,0,0,.10));
}

/* =========================================================
   BUTTONS — Bootstrap override
   ========================================================= */
.btn {
    border-radius: 10px !important;
    font-weight: 600 !important;
    padding: 10px 18px !important;
    transition: all .15s ease !important;
    border: 1px solid transparent;
    font-size: 14px;
}
.btn-sm { padding: 7px 12px !important; font-size: 13px; border-radius: 8px !important; }
.btn-lg { padding: 14px 24px !important; font-size: 15px; border-radius: 12px !important; }
.btn-primary {
    background: var(--brand) !important; border-color: var(--brand) !important;
    color:#fff !important;
}
.btn-primary:hover {
    background: var(--brand-700) !important; border-color: var(--brand-700) !important;
    transform: translateY(-1px); box-shadow: var(--shadow-sm);
}
.btn-primary-soft {
    background: var(--brand-50) !important; color: var(--brand) !important; border-color: var(--brand-50);
}
.btn-primary-soft:hover { background: var(--brand-100) !important; color: var(--brand-700) !important; }
.btn-dark { background: var(--ink) !important; border-color: var(--ink) !important; color:#fff !important; }
.btn-dark:hover { background: #0f172a !important; transform: translateY(-1px); }
.btn-outline-primary { border-color: var(--brand) !important; color: var(--brand) !important; }
.btn-outline-primary:hover { background: var(--brand) !important; color:#fff !important; }
.btn-success { background:#16a34a !important; border-color:#16a34a !important; }
.btn-success:hover { background:#0f8038 !important; transform: translateY(-1px); }
.btn-danger { background:#e11d48 !important; border-color:#e11d48 !important; }
.btn-warning { background: var(--accent) !important; border-color: var(--accent) !important; color: var(--ink) !important; }

/* =========================================================
   ALERTS — daha yumuşak görünüm
   ========================================================= */
.alert {
    border: 0 !important;
    border-left: 4px solid;
    border-radius: 12px !important;
    padding: 16px 20px !important;
    font-size: 14px;
}
.alert-heading { font-size: 1rem !important; font-weight: 600 !important; margin-bottom: 4px !important; }
.alert-warning {
    background: linear-gradient(135deg, #fff8e6, #fff1c8) !important;
    color: #7a5a00 !important; border-left-color: #f5b400;
}
.alert-danger {
    background: linear-gradient(135deg, #ffeaea, #ffd9d6) !important;
    color: #8a1a16 !important; border-left-color: #e53935;
}
.alert-success {
    background: linear-gradient(135deg, #e6f6ec, #cdebd6) !important;
    color: #15602f !important; border-left-color: #16a34a;
}
.alert-info {
    background: linear-gradient(135deg, #e6f1ff, #d0e1ff) !important;
    color: #16306f !important; border-left-color: var(--brand);
}

/* =========================================================
   TABLES (deneme sınavları / quiz list)
   ========================================================= */
.table-responsive {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: var(--shadow-xs);
    overflow: hidden;
}
.table {
    margin: 0 !important;
}
.table thead th, .table.table-dark-gray thead th {
    background: var(--brand-soft) !important;
    color: var(--ink-soft) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--line) !important;
    border-top: 0 !important;
    border-right: 0 !important; border-left: 0 !important;
}
.table tbody tr {
    background: #fff !important;
    border-color: var(--line) !important;
    transition: background .15s ease;
}
.table.table-hover tbody tr:hover {
    background: var(--brand-50) !important; cursor: default;
}
.table tbody td {
    padding: 14px 16px !important;
    color: var(--ink) !important;
    border-color: var(--line) !important;
    vertical-align: middle;
    font-size: 14px;
}
.table tbody tr:last-child td { border-bottom: 0 !important; }

/* =========================================================
   EMPTY STATE
   ========================================================= */
.empty-state {
    background: #fff;
    border: 1px dashed var(--line);
    border-radius: 18px;
    padding: 56px 28px;
    text-align: center;
    color: var(--muted);
}
.empty-state .ic-circle {
    width: 84px; height: 84px;
    margin: 0 auto 16px;
    border-radius: 50%;
    background: var(--brand-50);
    color: var(--brand);
    display:flex; align-items:center; justify-content:center;
    font-size: 36px;
}
.empty-state h3 { color: var(--ink); font-size: 1.15rem; font-weight: 700; margin: 0 0 6px; }
.empty-state p { margin: 0; font-size: 14px; }

/* =========================================================
   QUIZ / SINAV (welcome, stage, result)
   ========================================================= */
.quiz-toolbar {
    background:#fff; border:1px solid var(--line); border-radius: 14px;
    padding: 16px 20px;
    display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap: 12px;
    box-shadow: var(--shadow-xs); margin-bottom: 20px;
}
.quiz-toolbar .timer-pill {
    display:inline-flex; align-items:center; gap:8px;
    background: var(--brand-50); color: var(--brand);
    padding: 7px 16px; border-radius: 999px;
    font-weight: 700; font-size: 14px;
}
.quiz-toolbar .timer-pill.--warn { background:#fee2e2; color:#8a1a16; }

.quiz-shell { display: grid; gap: 20px; grid-template-columns: 1fr 290px; align-items: start; }
@media (max-width: 900px) { .quiz-shell { grid-template-columns: 1fr; } }

.quiz-card {
    background:#fff; border:1px solid var(--line); border-radius: 18px;
    box-shadow: var(--shadow-sm); padding: 32px;
}
.quiz-card .q-num {
    color: var(--brand); font-size: 12px; font-weight: 800;
    text-transform: uppercase; letter-spacing: .06em;
    margin-bottom: 10px;
}
.quiz-card h3, .quiz-card .q-title { font-size: 1.15rem !important; color: var(--ink) !important; margin: 0 0 14px !important; line-height: 1.5; font-weight: 600 !important; }
.quiz-card .q-content { color: var(--ink-soft); font-size: 15px; line-height: 1.65; }

.quiz-options { display:flex; flex-direction:column; gap: 12px; margin-top: 22px; }
.quiz-options .radio { margin: 0 !important; padding: 0; }
.quiz-options .radio > input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.quiz-options .radio > label {
    display:flex; align-items:center; gap: 12px;
    padding: 14px 18px;
    background: #f8fafd;
    border: 2px solid var(--line);
    border-radius: 12px;
    color: var(--ink) !important;
    font-weight: 500 !important;
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
    margin: 0 !important;
    width: 100%;
}
.quiz-options .radio > label:hover { background: var(--brand-50); border-color: #c9d6ff; }
.quiz-options .radio > label .radio-label {
    width: 22px; height: 22px; border-radius: 50%;
    border: 2px solid #c9d2e2; background:#fff;
    display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
    transition: border-color .15s ease, background .15s ease;
}
.quiz-options .radio > input[type="radio"]:checked + label {
    background: var(--brand-50); border-color: var(--brand); color: var(--brand) !important;
}
.quiz-options .radio > input[type="radio"]:checked + label .radio-label {
    border-color: var(--brand); background: var(--brand);
}
.quiz-options .radio > input[type="radio"]:checked + label .radio-label::after {
    content:""; width:8px; height:8px; border-radius:50%; background:#fff;
}

/* tests/stage anlık doğru/yanlış işareti */
.quiz-options .text-green-500, .quiz-options label.text-green-500 { color:#16a34a !important; font-weight: 600 !important; }
.quiz-options .text-red-500, .quiz-options label.text-red-500   { color:#e11d48 !important; font-weight: 600 !important; }

.quiz-nav { margin-top: 28px; display:flex; justify-content: space-between; gap: 12px; flex-wrap:wrap; }
.quiz-nav a, .quiz-nav button {
    background: #eef2f8 !important; color: var(--ink) !important;
    border-radius: 10px !important; padding: 11px 20px !important;
    font-weight: 600 !important; font-size: 14px !important;
    transition: background .15s ease, color .15s ease, transform .1s ease !important;
    text-decoration: none !important; border: 0;
    display: inline-flex; align-items: center; gap: 6px;
}
.quiz-nav a:hover, .quiz-nav button:hover { background: var(--brand) !important; color:#fff !important; transform: translateY(-1px); }
.quiz-nav a.disabled { opacity:.4 !important; pointer-events:none; }

.quiz-navigator {
    background:#fff; border:1px solid var(--line); border-radius: 18px;
    box-shadow: var(--shadow-sm); padding: 22px;
}
.quiz-navigator-title { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin-bottom: 12px; }
.quiz-navigator-grid { display:grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.dbox {
    display:flex !important; align-items:center; justify-content:center;
    width: 100%; aspect-ratio: 1; min-width: 0;
    border-radius: 10px;
    font-weight: 700; font-size: 13px;
    background: #f1f4f9 !important; color: var(--ink-soft) !important;
    border: 1px solid var(--line); cursor:pointer; transition: all .15s ease;
    text-decoration: none !important; margin: 0 !important;
}
.dbox:hover { background: var(--brand-50) !important; color: var(--brand) !important; border-color: var(--brand); }
.dbox-g, .dbox-success, .dbox.btn-success { background:#16a34a !important; color:#fff !important; border-color: #16a34a !important; }
.dbox-w, .dbox-danger, .dbox.btn-warning  { background:#e11d48 !important; color:#fff !important; border-color: #e11d48 !important; }

.quiz-legend {
    background:#fff; border:1px solid var(--line); border-radius: 14px;
    padding: 14px 18px; margin-top: 14px;
    font-size: 12.5px; color: var(--ink-soft);
}
.quiz-legend .row-i { display:flex; align-items:center; gap: 8px; margin: 4px 0; }
.quiz-legend .dot { display:inline-block; width:10px; height:10px; border-radius:3px; }
.quiz-legend .dot-success { background:#16a34a; }
.quiz-legend .dot-danger  { background:#e11d48; }

/* welcome timer */
.coming-soon-timer {
    background: var(--grad-hero) !important;
    border-radius: 22px !important;
    padding: 4rem 1rem !important;
    overflow: hidden; position:relative;
}
.coming-soon-timer::before {
    content:""; position:absolute; inset:0;
    background: radial-gradient(circle at 80% 20%, rgba(255,255,255,.18), transparent 40%);
    pointer-events:none;
}
.coming-soon-timer > * { position: relative; z-index: 1; }
.coming-soon-timer h1 {
    color:#fff !important; text-shadow: none !important;
    font-size: 1.5rem !important; font-weight: 700 !important;
    letter-spacing: .02em;
    text-align: center; margin-bottom: 24px !important;
}
.coming-soon-timer .time-counter { gap: 8px !important; justify-content: center !important; }
.coming-soon-timer .time-counter .mn {
    background: rgba(255,255,255,.16) !important;
    border: 1px solid rgba(255,255,255,.28) !important; border-bottom: none !important;
    color:#fff !important; font-size: 38px !important;
    border-radius: 12px 12px 0 0 !important;
    backdrop-filter: blur(6px);
    width: 88px !important; height: 88px !important;
    margin-right: 0 !important;
}
.coming-soon-timer .time-titles { gap: 8px !important; justify-content: center !important; }
.coming-soon-timer .time-titles div {
    background: rgba(0,0,0,.22) !important;
    color:#fff !important; border: 1px solid rgba(255,255,255,.28) !important; border-top:none !important;
    border-radius: 0 0 12px 12px !important;
    text-transform: capitalize !important; letter-spacing: .03em;
    width: 88px !important; height: 28px !important;
    margin-right: 0 !important;
}
.timer-bg { display:none !important; }

.quiz-welcome-card {
    background:#fff; border:1px solid var(--line); border-radius: 18px;
    box-shadow: var(--shadow-sm); padding: 28px;
}
.checkbox { margin-top: 14px; }
.checkbox label { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; color: var(--ink); }
.checkbox input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--brand); }

/* result detail score card */
.score-card {
    background: var(--grad-hero);
    color:#fff; border-radius: 22px;
    padding: 32px; box-shadow: var(--shadow-md);
    position: relative; overflow: hidden;
}
.score-card::before {
    content:""; position:absolute; inset:0;
    background: radial-gradient(circle at 90% 20%, rgba(255,255,255,.16), transparent 35%);
}
.score-card > * { position: relative; z-index: 1; }
.score-card .score-eyebrow { font-size: 12.5px; opacity:.85; text-transform: uppercase; letter-spacing: .06em; }
.score-card .score-title { font-size: 1.5rem; font-weight: 800; margin-top: 4px; }
.score-card .score-meta { font-size: 13px; opacity:.85; margin-top: 6px; }
.score-card .score-row {
    display:grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 14px; margin-top: 22px;
}
.score-card .score-cell {
    background: rgba(255,255,255,.14); border-radius: 14px; padding: 16px; text-align: center;
    backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,.18);
}
.score-card .score-cell .label { font-size: 12px; opacity:.85; text-transform: uppercase; letter-spacing: .05em; }
.score-card .score-cell .value { font-size: 1.8rem; font-weight: 800; margin-top: 4px; line-height: 1; }

.answer-card {
    background:#fff; border:1px solid var(--line); border-radius: 16px;
    padding: 22px; margin-top: 16px; box-shadow: var(--shadow-xs);
}
.answer-card .q-num { font-size: 12px; font-weight: 800; color: var(--brand); text-transform: uppercase; letter-spacing: .05em; }
.answer-card .your-answer { background:#f6f8fb; border-radius:10px; padding: 12px 14px; margin-top: 12px; font-size: 14px; }
.answer-card .correct-answer { background:#e6f6ec; color:#15602f; border-radius:10px; padding: 12px 14px; margin-top: 8px; font-size: 14px; }

.pill {
    display:inline-flex; padding: 4px 11px; border-radius: 999px;
    font-size: 11.5px; font-weight: 700; letter-spacing: .03em;
}
.pill-success { background:#dcfce7; color:#15602f; }
.pill-danger  { background:#fee2e2; color:#8a1a16; }
.pill-warn    { background:#fef3c7; color:#7a5a00; }
.pill-info    { background: var(--brand-50); color: var(--brand); }

/* explain box (tests/stage cevap açıklaması) */
[id^="answer_"] {
    background: var(--brand-soft);
    border-left: 4px solid var(--brand);
    border-radius: 10px;
    padding: 14px 16px;
    font-size: 14px;
    color: var(--ink-soft);
    margin-top: 14px;
}

/* =========================================================
   FORM (input override — auth/forgot/plaint)
   ========================================================= */
.form-control, .form-select {
    border: 1.5px solid var(--line) !important;
    border-radius: 10px !important;
    padding: 11px 14px !important;
    font-size: 14.5px !important;
    background: #fff !important;
    transition: border-color .15s ease, box-shadow .15s ease;
    height: auto !important;
    box-shadow: none !important;
}
.form-control:focus, .form-select:focus {
    border-color: var(--brand) !important;
    box-shadow: 0 0 0 4px var(--brand-50) !important;
}
.form-label, label { font-weight: 600; color: var(--ink-soft); font-size: 13.5px; margin-bottom: 6px; }

/* =========================================================
   AUTH PAGES (login / forgot kendi sayfa iskeleti)
   ========================================================= */
.auth-bg {
    min-height: 100vh;
    background:
        radial-gradient(circle at 90% -10%, var(--brand-50) 0%, transparent 35%),
        radial-gradient(circle at 10% 110%, #fff7e0 0%, transparent 35%),
        var(--bg);
    display: flex; flex-direction: column;
}
.auth-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 20px;
    box-shadow: var(--shadow-lg);
    padding: 36px;
    width: 100%; max-width: 480px;
    margin: 0 auto;
}
.auth-card h1 { font-size: 1.5rem; font-weight: 700; color: var(--ink); margin: 0 0 6px; }
.auth-card .lead { color: var(--muted); font-size: 14px; margin: 0 0 22px; line-height: 1.55; }

/* =========================================================
   FOOTER override
   ========================================================= */
footer.bg-dark, .footer {
    background: linear-gradient(180deg, var(--brand) 0%, var(--brand-700) 100%) !important;
    color: rgba(255,255,255,.92) !important;
    padding-top: 48px !important;
}
footer.bg-dark h5 { color:#fff !important; font-weight: 700; }
footer.bg-dark a { color: rgba(255,255,255,.78) !important; text-decoration: none; transition: color .15s ease; }
footer.bg-dark a:hover { color: var(--accent) !important; }
footer.bg-dark .text-body-secondary { color: rgba(255,255,255,.6) !important; }
footer.bg-dark .h6.fw-light, footer.bg-dark span.h6 { color:#fff !important; font-weight: 500 !important; }
footer.bg-dark hr { border-color: rgba(255,255,255,.10) !important; opacity: 1; }
footer.bg-dark .text-primary-hover a:hover { color: var(--accent) !important; }
footer.bg-dark .btn-white {
    background: rgba(255,255,255,.10) !important; border-color: transparent !important;
    color:#fff !important;
}
footer.bg-dark .btn-white:hover { background: rgba(255,255,255,.18) !important; }

/* back-top button */
.back-top {
    background: var(--brand) !important;
    color:#fff !important;
    box-shadow: 0 8px 20px rgba(32,66,149,.30);
}
.back-top:hover { background: var(--brand-700) !important; }

/* =========================================================
   PDF READER
   ========================================================= */
.normPdf {
    background:#fff !important;
    border: 1px solid var(--line) !important;
    border-radius: 16px !important;
    box-shadow: var(--shadow-md) !important;
    overflow:hidden;
}
.normPdfToolbar {
    background: var(--grad-hero) !important;
    color:#fff !important;
    border-bottom: 0 !important;
    padding: 10px 16px !important;
}
.normPdfToolbar button {
    background: rgba(255,255,255,.14) !important;
    color:#fff !important;
    border-radius: 8px !important;
    width: 34px; height: 34px;
    display:inline-flex !important; align-items:center; justify-content:center;
    margin: 0 3px !important;
    transition: background .15s ease, transform .1s ease;
    border: 0 !important;
}
.normPdfToolbar button:hover { background: rgba(255,255,255,.28) !important; transform: translateY(-1px); }
.normPdfToolbar .normPdfPage,
.normPdfToolbar .normPdfFit { border: 0 !important; border-left: 1px solid rgba(255,255,255,.22) !important; padding-left: 10px !important; }
.normPdfToolbar .normPdfPage:first-child { border-left: 0 !important; padding-left: 0 !important; }
.normPdfToolbar .normPdfPageTxt { color: rgba(255,255,255,.92) !important; }
.normPdfZoom select {
    background: rgba(255,255,255,.20) !important;
    color:#fff !important; border:0 !important; border-radius: 6px !important;
    width: 60px !important; height: 28px !important;
    font-weight: 600 !important; padding: 0 6px !important;
}
.normPdfZoom select option { color: var(--ink); }
.normPdfViewer { background:#eef2f8 !important; }

/* =========================================================
   FULL-SCREEN VIDEO WATCH (videos/player.twig)
   ========================================================= */
.course-watch { background:#0a0d14; min-height: 100vh; color:#fff; }
.course-watch .sidebar { background:#11151f !important; color:#fff; }
.course-curriculum-list { list-style:none; padding: 0; margin: 0; }
.course-curriculum-list li {
    border-radius: 10px; margin-bottom: 4px; transition: background .15s ease;
}
.course-curriculum-list li a {
    display:flex; align-items:center; gap: 12px; padding: 12px 14px;
    color:#cfd8e8 !important; font-size: 14px; line-height: 1.4;
    text-decoration: none; border-radius: 10px;
}
.course-curriculum-list li a::before {
    content:"▶"; font-size: 9px; color:#7fb1ff; opacity: .65; flex-shrink:0;
}
.course-curriculum-list li:hover a { background: #1a2030; color:#fff !important; }
.course-curriculum-list li.active a { background: var(--brand); color:#fff !important; }
.course-curriculum-list li.active a::before { color:#fff; opacity:1; }

/* =========================================================
   UTILITIES
   ========================================================= */
.rounded-3 { border-radius: 14px !important; }
.shadow { box-shadow: var(--shadow-sm) !important; }
.bg-grad-pink   { background: var(--grad-pink) !important; border-radius: 22px !important; }
.bg-grad-blue   { background: var(--grad-hero) !important; border-radius: 22px !important; }
.bg-grad-warm   { background: var(--grad-warm) !important; }
.bg-grad-green  { background: var(--grad-green) !important; }

.icon-xl {
    width: 64px; height: 64px;
    border-radius: 16px;
    display:flex; align-items:center; justify-content:center;
    font-size: 28px;
}

.text-orange { color: #ff7a00 !important; }
.text-purple { color: #6d28d9 !important; }
.bg-purple   { background-color: #6d28d9; }

/* =========================================================
   iOS RESUME BUTTON — "Kaldığın yerden devam et"
   iOS Safari'de otomatik seek user-gesture engeli yüzünden
   çalışmaz; kullanıcı butona tıklayınca senkron olarak
   seek + play yapar.
   ========================================================= */
.ios-resume-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    padding: 16px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.ios-resume-card {
    background: #fff;
    border-radius: 18px;
    padding: 24px 22px;
    width: 100%;
    max-width: 360px;
    text-align: center;
    box-shadow: 0 16px 40px rgba(0,0,0,.30);
}
.ios-resume-card .icon-circle {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--brand) 0%, var(--brand-700) 100%);
    color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 28px;
    margin-bottom: 14px;
    box-shadow: 0 8px 18px rgba(32,66,149,.30);
}
.ios-resume-card h5 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 6px;
}
.ios-resume-card p {
    font-size: 13.5px;
    color: var(--ink-soft);
    margin: 0 0 18px;
    line-height: 1.5;
}
.ios-resume-card .time-pill {
    display: inline-block;
    background: var(--brand-50);
    color: var(--brand);
    font-weight: 700;
    font-size: 13px;
    padding: 4px 12px;
    border-radius: 999px;
    margin-bottom: 14px;
}
.ios-resume-card .btn-row {
    display: flex;
    gap: 8px;
    flex-direction: column;
}
.ios-resume-card .btn-resume {
    background: var(--brand);
    color: #fff;
    border: 0;
    border-radius: 12px;
    padding: 14px 18px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    transition: background .15s ease;
}
.ios-resume-card .btn-resume:hover,
.ios-resume-card .btn-resume:active { background: var(--brand-700); }
.ios-resume-card .btn-restart {
    background: #eef2f8;
    color: var(--ink);
    border: 0;
    border-radius: 12px;
    padding: 12px 18px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}

/* =========================================================
   PDF NOT ALMA — TEXT HIGHLIGHT
   ========================================================= */
.pdf-stage {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 16px;
    height: 90vh;
}
@media (max-width: 991px) {
    .pdf-stage { grid-template-columns: 1fr; height: auto; }
    .pdf-notes-panel { max-height: 50vh; }
}

/* Reader sol kolon */
.pdf-reader-shell {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 16px;
    box-shadow: var(--shadow-md);
    overflow: hidden;
    position: relative;
    display: flex;
    flex-direction: column;
}
.pdf-reader-toolbar {
    background: var(--grad-hero);
    color: #fff;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    flex-shrink: 0;
}
.pdf-reader-toolbar button {
    background: rgba(255,255,255,.14) !important;
    color: #fff !important;
    border: 0 !important;
    border-radius: 8px !important;
    width: 34px; height: 34px;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .15s ease;
    cursor: pointer; padding: 0;
}
.pdf-reader-toolbar button:hover { background: rgba(255,255,255,.28) !important; }
.pdf-reader-toolbar button:disabled { opacity: .35; cursor: not-allowed; }
.pdf-reader-toolbar .group {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 0 8px;
    border-right: 1px solid rgba(255,255,255,.18);
}
.pdf-reader-toolbar .group:last-child { border-right: 0; }
.pdf-reader-toolbar .page-label {
    color: rgba(255,255,255,.95);
    font-size: 13px; font-weight: 600;
    padding: 0 6px; min-width: 70px; text-align: center;
}

.pdf-reader-viewport {
    flex: 1;
    background: #eef2f8;
    overflow: auto;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 18px;
}

/* Sayfa wrapper (canvas + text-layer + highlight-layer aynı boyutlu) */
.pdf-page-wrap {
    position: relative;
    box-shadow: 0 6px 20px rgba(0,0,0,.18);
    background: #fff;
    line-height: 0;
}
.pdf-page-wrap canvas { display: block; }

/* Text layer — metin seçimi için (görünmez) */
.pdf-text-layer {
    position: absolute; left: 0; top: 0;
    width: 100%; height: 100%;
    overflow: hidden;
    opacity: 1;
    line-height: 1;
    pointer-events: auto;
    user-select: text;
    -webkit-user-select: text;
}
.pdf-text-layer > span {
    color: transparent;
    position: absolute;
    white-space: pre;
    cursor: text;
    transform-origin: 0% 0%;
}
.pdf-text-layer ::selection { background: rgba(32,66,149,.28); }
.pdf-text-layer ::-moz-selection { background: rgba(32,66,149,.28); }

/* Highlight layer — kaydedilmiş vurgular */
.pdf-highlight-layer {
    position: absolute; left: 0; top: 0;
    width: 100%; height: 100%;
    pointer-events: none;
}
.pdf-highlight-rect {
    position: absolute;
    opacity: 0.42;
    mix-blend-mode: multiply;
    border-radius: 2px;
    pointer-events: auto;
    cursor: pointer;
    transition: opacity .15s ease;
}
.pdf-highlight-rect:hover { opacity: 0.62; }
.pdf-highlight-rect.has-note::after {
    content: "📝";
    position: absolute; top: -6px; right: -10px;
    font-size: 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 50%;
    width: 18px; height: 18px;
    display: flex; align-items: center; justify-content: center;
    line-height: 1;
}

/* Seçim popup'ı (renk seçici + Not Ekle butonu) */
.pdf-selection-popup {
    position: absolute;
    z-index: 1000;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 12px;
    box-shadow: var(--shadow-lg);
    padding: 8px;
    display: none;
    align-items: center;
    gap: 6px;
}
.pdf-selection-popup.is-visible { display: inline-flex; }
.pdf-selection-popup .color-btn {
    width: 24px; height: 24px;
    border-radius: 50%;
    border: 2px solid transparent;
    cursor: pointer;
    padding: 0;
    transition: transform .12s ease, border-color .12s ease;
}
.pdf-selection-popup .color-btn:hover { transform: scale(1.15); border-color: rgba(0,0,0,.10); }
.pdf-selection-popup .color-btn.is-active { border-color: var(--ink); }
.pdf-selection-popup .sep { width: 1px; height: 22px; background: var(--line); margin: 0 4px; }
.pdf-selection-popup .btn-mini {
    background: var(--brand); color: #fff;
    border: 0; border-radius: 8px;
    padding: 6px 12px; font-size: 12.5px; font-weight: 600;
    cursor: pointer; display: inline-flex; align-items: center; gap: 4px;
    transition: background .15s ease;
}
.pdf-selection-popup .btn-mini:hover { background: var(--brand-700); }
.pdf-selection-popup .btn-mini.--ghost {
    background: #eef2f8; color: var(--ink);
}
.pdf-selection-popup .btn-mini.--ghost:hover { background: #e0e6f1; }

/* Sağ notlar paneli */
.pdf-notes-panel {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 16px;
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.pdf-notes-panel .panel-head {
    background: var(--brand-soft);
    padding: 14px 18px;
    border-bottom: 1px solid var(--line);
    display: flex; align-items: center; justify-content: space-between;
}
.pdf-notes-panel .panel-head h6 {
    margin: 0; font-size: 14.5px; font-weight: 700; color: var(--ink);
    display: inline-flex; align-items: center; gap: 8px;
}
.pdf-notes-panel .panel-head .count-pill {
    background: var(--brand); color: #fff;
    font-size: 11px; font-weight: 700; padding: 2px 9px; border-radius: 999px;
}
.pdf-notes-panel .panel-body {
    overflow-y: auto;
    flex: 1;
    padding: 8px 0;
}
.pdf-notes-panel .panel-empty {
    padding: 36px 24px; text-align: center; color: var(--muted); font-size: 13px;
}
.pdf-notes-panel .panel-empty ion-icon {
    font-size: 36px; opacity: .5; display: block; margin: 0 auto 8px;
}
.pdf-note-item {
    padding: 12px 16px;
    border-bottom: 1px solid var(--line);
    cursor: pointer;
    transition: background .15s ease;
    position: relative;
}
.pdf-note-item:hover { background: var(--brand-50); }
.pdf-note-item .item-head {
    display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
    font-size: 12px;
}
.pdf-note-item .item-head .color-dot {
    width: 10px; height: 10px; border-radius: 50%;
    flex-shrink: 0;
}
.pdf-note-item .item-head .page-tag {
    background: var(--brand-50); color: var(--brand);
    font-weight: 700; font-size: 11px;
    padding: 2px 8px; border-radius: 999px;
}
.pdf-note-item .item-head .delete-btn {
    margin-left: auto;
    background: transparent; border: 0;
    color: var(--muted); cursor: pointer;
    padding: 2px 6px; border-radius: 4px;
    opacity: 0; transition: opacity .15s ease, color .15s ease;
}
.pdf-note-item:hover .delete-btn { opacity: 1; }
.pdf-note-item .delete-btn:hover { color: #e11d48; background: rgba(225,29,72,.08); }
.pdf-note-item .excerpt {
    font-size: 13px; color: var(--ink-soft);
    line-height: 1.5;
    background: #f6f8fb;
    border-left: 3px solid currentColor;
    padding: 6px 10px;
    border-radius: 4px;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
    quotes: "“" "”";
}
.pdf-note-item .excerpt::before { content: open-quote; }
.pdf-note-item .excerpt::after { content: close-quote; }
.pdf-note-item .note-text {
    margin-top: 6px;
    font-size: 13px; color: var(--ink);
    line-height: 1.5;
    display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.pdf-note-item .note-text:empty { display: none; }

/* Not düzenleme modal */
.pdf-note-modal {
    position: fixed; inset: 0;
    background: rgba(20,30,60,.55);
    display: none;
    align-items: center; justify-content: center;
    z-index: 1050;
    padding: 16px;
}
.pdf-note-modal.is-visible { display: flex; }
.pdf-note-modal .modal-card {
    background: #fff;
    border-radius: 18px;
    box-shadow: var(--shadow-lg);
    width: 100%; max-width: 520px;
    padding: 24px;
}
.pdf-note-modal h5 {
    font-size: 1.05rem; font-weight: 700; margin: 0 0 6px;
    display: inline-flex; align-items: center; gap: 8px;
}
.pdf-note-modal .modal-excerpt {
    background: #f6f8fb;
    border-left: 4px solid currentColor;
    padding: 10px 14px; border-radius: 6px;
    font-size: 13.5px; color: var(--ink-soft);
    margin: 12px 0 16px; line-height: 1.55;
    max-height: 100px; overflow-y: auto;
}
.pdf-note-modal textarea {
    width: 100%; min-height: 110px;
    border: 1.5px solid var(--line);
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    resize: vertical;
}
.pdf-note-modal textarea:focus {
    outline: none; border-color: var(--brand);
    box-shadow: 0 0 0 4px var(--brand-50);
}
.pdf-note-modal .field-label {
    display: block;
    font-size: 12.5px;
    color: var(--ink-soft);
    font-weight: 600;
    margin: 12px 0 6px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.pdf-note-modal .excerpt-input {
    width: 100%; min-height: 60px;
    border: 1.5px solid var(--line);
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 13.5px;
    color: var(--ink-soft);
    resize: vertical;
    background: #f6f8fb;
}
.pdf-note-modal .excerpt-input:focus {
    outline: none; border-color: var(--brand);
    box-shadow: 0 0 0 4px var(--brand-50); background: #fff;
}

/* Mobil için modal padding ve buton boyutları */
@media (max-width: 640px) {
    .pdf-note-modal { padding: 8px; }
    .pdf-note-modal .modal-card { padding: 18px; max-height: 95vh; overflow-y: auto; }
    .pdf-note-modal .modal-actions { flex-wrap: wrap; gap: 6px; }
    .pdf-note-modal .modal-actions .btn { font-size: 13px; padding: 8px 14px; }
}

/* Toolbar'da "Sayfa Notu Ekle" butonu — text ile */
.pdf-reader-toolbar .btn-add-note {
    background: var(--accent) !important;
    color: var(--ink) !important;
    width: auto !important;
    padding: 0 12px !important;
    height: 34px;
    font-size: 12.5px;
    font-weight: 700;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    letter-spacing: .02em;
}
.pdf-reader-toolbar .btn-add-note:hover { background: #ffc107 !important; }
.pdf-reader-toolbar .btn-add-note i { font-size: 14px; }

/* Sağ panelde "Sayfa Notu" (rects boş) için ayrı rozet */
.pdf-note-item .page-note-tag {
    background: var(--accent);
    color: var(--ink);
    font-weight: 700; font-size: 10.5px;
    padding: 2px 7px; border-radius: 999px;
    margin-left: 4px;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.pdf-note-modal .modal-actions {
    margin-top: 16px;
    display: flex; gap: 8px; justify-content: flex-end;
}
.pdf-note-modal .color-row {
    display: flex; gap: 6px; margin-top: 12px;
    align-items: center;
}
.pdf-note-modal .color-row .label-txt {
    font-size: 12px; color: var(--muted); margin-right: 4px;
}

/* =========================================================
   VIDEO PROGRESS (YouTube/Netflix tarzı ilerleme çubuğu)
   Kullanım: video thumb wrapper'ına eklenir
   ========================================================= */
.video-progress {
    position: absolute; left: 0; right: 0; bottom: 0;
    height: 4px;
    background: rgba(0,0,0,.35);
    overflow: hidden;
    z-index: 3;
    pointer-events: none;
}
.video-progress .bar {
    height: 100%;
    background: #e11d48;
    box-shadow: 0 0 10px rgba(225,29,72,.55);
    transition: width .3s ease;
}
.video-progress.is-completed .bar { background: #16a34a; box-shadow: 0 0 10px rgba(22,163,74,.55); }

.video-status-badge {
    position: absolute; top: 12px; right: 12px;
    z-index: 4;
    background: rgba(255,255,255,.95);
    color: var(--brand);
    font-size: 10.5px; font-weight: 800;
    letter-spacing: .04em;
    padding: 4px 10px;
    border-radius: 999px;
    backdrop-filter: blur(6px);
    display: inline-flex; align-items: center; gap: 4px;
    box-shadow: 0 2px 8px rgba(0,0,0,.20);
}
.video-status-badge.--continue { background: rgba(225,29,72,.95); color:#fff; }
.video-status-badge.--completed { background: rgba(22,163,74,.95); color:#fff; }
.video-status-badge i { font-size: 12px; }

/* =========================================================
   COURSE DETAIL — SOL kapak kartı + SAĞ 2 sıralı menü
   ========================================================= */
.course-cover-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow .2s ease, transform .2s ease;
    position: sticky; top: 90px;
}
.course-cover-card:hover { box-shadow: var(--shadow-md); }
.course-cover-card .cover-thumb {
    position: relative; overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--brand-soft);
}
.course-cover-card .cover-thumb img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .4s ease;
}
.course-cover-card:hover .cover-thumb img { transform: scale(1.04); }
.course-cover-card .cover-thumb .cover-badge {
    position: absolute; top: 14px; left: 14px;
    background: var(--accent); color: var(--ink);
    font-size: 11px; font-weight: 800;
    padding: 5px 12px; border-radius: 999px;
    letter-spacing: .04em; text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(0,0,0,.18);
}
.course-cover-card .cover-thumb .cover-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.40) 100%);
}
.course-cover-card .cover-body {
    padding: 22px 22px 24px;
}
.course-cover-card .cover-eyebrow {
    color: var(--brand); font-size: 11.5px; font-weight: 800;
    letter-spacing: .06em; text-transform: uppercase;
    margin-bottom: 6px; display: inline-flex; align-items: center; gap: 6px;
}
.course-cover-card .cover-title {
    font-size: 1.2rem; font-weight: 700; color: var(--ink);
    line-height: 1.35; margin: 0 0 10px;
}
.course-cover-card .cover-desc {
    font-size: 13.5px; color: var(--ink-soft);
    line-height: 1.6;
    display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
    margin-bottom: 18px;
}
.course-cover-card .cover-meta {
    list-style: none; padding: 14px 0; margin: 0 0 18px;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.course-cover-card .cover-meta li {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 10px;
    font-size: 13.5px; color: var(--ink-soft);
    border-radius: 10px;
    transition: background .15s ease;
    margin: 0 -10px;
}
.course-cover-card .cover-meta li:hover { background: var(--brand-50); }
.course-cover-card .cover-meta li .label {
    display: inline-flex; align-items: center; gap: 9px;
    color: var(--ink-soft) !important;
    text-decoration: none !important;
    flex: 1;
}
.course-cover-card .cover-meta li:hover .label { color: var(--brand) !important; }
.course-cover-card .cover-meta li .label i {
    color: var(--brand); font-size: 16px; width: 22px; text-align: center;
}
.course-cover-card .cover-meta li .count {
    font-weight: 700; color: var(--ink);
    background: var(--brand-50); padding: 3px 10px; border-radius: 999px;
    font-size: 12.5px; min-width: 28px; text-align: center;
}
/* Aktif kategori vurgusu */
.course-cover-card .cover-meta li.is-active {
    background: var(--brand);
}
.course-cover-card .cover-meta li.is-active .label,
.course-cover-card .cover-meta li.is-active .label i {
    color: #fff !important;
}
.course-cover-card .cover-meta li.is-active .count {
    background: rgba(255,255,255,.22); color: #fff;
}
.course-cover-card .cover-cta {
    display: flex; gap: 8px;
}
.course-cover-card .cover-cta .btn {
    flex: 1; justify-content: center;
}

.course-menu-head {
    margin-bottom: 16px;
}
.course-menu-head .eb {
    color: var(--brand); font-size: 12px; font-weight: 800;
    letter-spacing: .08em; text-transform: uppercase;
    margin-bottom: 6px; display: inline-flex; align-items: center; gap: 6px;
}
.course-menu-head h2 {
    margin: 0 0 6px; font-size: 1.5rem; font-weight: 700;
}
.course-menu-head p { margin: 0; color: var(--ink-soft); font-size: 14px; }

@media (max-width: 991px) {
    .course-cover-card { position: static; margin-bottom: 24px; }
}

/* =========================================================
   FEATURED CLASSES (yatay büyük kart — Courseplus tarzı)
   ========================================================= */
.featured-class {
    background:#fff;
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease;
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 0;
    height: 100%;
}
.featured-class:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: #d3dcec;
    text-decoration: none;
}
.featured-class .fc-thumb {
    position: relative; overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--brand-soft);
}
.featured-class .fc-thumb img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .4s ease;
}
.featured-class:hover .fc-thumb img { transform: scale(1.06); }
.featured-class .fc-thumb .fc-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.55) 100%);
}
.featured-class .fc-thumb .fc-badge {
    position: absolute; top: 14px; left: 14px;
    background: var(--accent); color: var(--ink);
    font-size: 11px; font-weight: 800;
    padding: 5px 12px; border-radius: 999px;
    letter-spacing: .04em; text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(0,0,0,.18);
}
.featured-class .fc-thumb .fc-play {
    position: absolute; bottom: 14px; left: 14px;
    width: 44px; height: 44px; border-radius: 50%;
    background: rgba(255,255,255,.92);
    display:flex; align-items:center; justify-content:center;
    color: var(--brand); font-size: 18px;
    box-shadow: 0 6px 14px rgba(0,0,0,.20);
}
.featured-class .fc-body {
    padding: 24px 22px;
    display: flex; flex-direction: column;
    justify-content: space-between;
}
.featured-class .fc-eyebrow {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--brand); font-size: 11.5px; font-weight: 800;
    letter-spacing: .06em; text-transform: uppercase;
    margin-bottom: 8px;
}
.featured-class .fc-title {
    font-size: 1.15rem; font-weight: 700; color: var(--ink);
    line-height: 1.35; margin-bottom: 8px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.featured-class .fc-desc {
    font-size: 13.5px; color: var(--ink-soft); line-height: 1.55;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
    margin-bottom: 16px;
}
.featured-class .fc-meta {
    display: flex; flex-wrap: wrap; gap: 14px;
    font-size: 12.5px; color: var(--ink-soft);
    padding-top: 12px; border-top: 1px solid var(--line);
}
.featured-class .fc-meta span {
    display:inline-flex; align-items:center; gap: 5px;
    font-weight: 600;
}
.featured-class .fc-meta i { color: var(--brand); font-size: 14px; }
@media (max-width: 768px) {
    .featured-class { grid-template-columns: 1fr; }
    .featured-class .fc-thumb { aspect-ratio: 16/9; }
}

/* =========================================================
   EPISODE CARD (Latest Episodes — yatay video kartı)
   ========================================================= */
.episode-card {
    display: flex; gap: 14px;
    background:#fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    transition: transform .15s ease, box-shadow .2s ease, border-color .15s ease;
    height: 100%;
    align-items: stretch;
}
.episode-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
    border-color: #d3dcec;
    text-decoration: none;
}
.episode-card .ep-thumb {
    position: relative; flex: 0 0 132px;
    aspect-ratio: 16/10;
    border-radius: 10px; overflow: hidden;
    background: var(--brand-soft);
}
.episode-card .ep-thumb img { width:100%; height:100%; object-fit:cover; }
.episode-card .ep-thumb .ep-play {
    position:absolute; inset:0; display:flex;
    align-items:center; justify-content:center;
    background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.55) 100%);
}
.episode-card .ep-thumb .ep-play i {
    color:#fff; font-size: 28px;
    filter: drop-shadow(0 3px 6px rgba(0,0,0,.5));
}
.episode-card .ep-thumb .ep-time {
    position:absolute; bottom:6px; right:6px;
    background: rgba(0,0,0,.72); color:#fff;
    font-size: 10.5px; font-weight: 600;
    padding: 2px 7px; border-radius: 4px;
}
.episode-card .ep-body {
    flex: 1; display:flex; flex-direction:column;
    justify-content: center; min-width: 0;
}
.episode-card .ep-eyebrow {
    color: var(--brand); font-size: 10.5px; font-weight: 800;
    text-transform: uppercase; letter-spacing: .05em; margin-bottom: 4px;
}
.episode-card .ep-title {
    font-size: 14px; font-weight: 600; color: var(--ink); line-height: 1.4;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.episode-card .ep-meta {
    margin-top: 6px; font-size: 12px; color: var(--muted);
    display:flex; align-items:center; gap: 10px;
}
.episode-card .ep-meta i { color: var(--brand); }

/* =========================================================
   BOOK CARD MINI (Latest Books / Çıkmış sorular tarzı)
   ========================================================= */
.book-mini {
    background:#fff;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 14px;
    display:flex; align-items:center; gap: 12px;
    transition: transform .15s ease, box-shadow .2s ease, border-color .15s ease;
    height: 100%;
}
.book-mini:hover {
    transform: translateY(-2px); box-shadow: var(--shadow-sm);
    border-color: #d3dcec; text-decoration: none;
}
.book-mini .bm-cover {
    flex: 0 0 56px; height: 72px;
    background: linear-gradient(135deg, #fff8e6 0%, #ffe8b3 100%);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: #e07a00; font-size: 24px;
    position: relative;
    box-shadow: 0 4px 8px rgba(0,0,0,.06);
}
.book-mini .bm-cover::after {
    content:""; position:absolute; left:0; top:0; bottom:0; width: 3px;
    background: var(--grad-warm);
    border-radius: 8px 0 0 8px;
}
.book-mini .bm-body { flex:1; min-width: 0; }
.book-mini .bm-title {
    font-size: 14px; font-weight: 600; color: var(--ink); line-height: 1.4;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.book-mini .bm-meta {
    margin-top: 4px; font-size: 12px; color: var(--muted);
    display:flex; align-items:center; gap: 6px;
}
.book-mini .bm-meta i { color: var(--brand); }
.book-mini .bm-cta {
    flex: 0 0 auto; color: var(--brand); font-size: 18px;
    transition: transform .15s ease;
}
.book-mini:hover .bm-cta { transform: translateX(3px); }

/* =========================================================
   HEADER NOTIFICATION + MESSAGE WIDGETS
   ========================================================= */
.nav-widget-btn {
    display:inline-flex; align-items:center; justify-content:center;
    width: 40px; height: 40px;
    border-radius: 50%;
    color: var(--ink-soft) !important;
    background: var(--brand-50);
    position: relative;
    transition: background .15s ease, color .15s ease, transform .15s ease;
    margin-right: 6px;
    border: 0;
}
.nav-widget-btn:hover { background: var(--brand); color:#fff !important; transform: translateY(-1px); }
.nav-widget-btn .nav-widget-dot {
    position:absolute; top: 6px; right: 6px;
    width: 9px; height: 9px;
    background: #e11d48; border-radius: 50%;
    border: 2px solid #fff;
}
.nav-widget-btn i { font-size: 18px; }

.widget-dropdown {
    width: 340px !important;
    max-width: 360px;
    padding: 0 !important;
    border-radius: 16px !important;
    overflow: hidden;
}
.widget-dropdown .widget-head {
    padding: 14px 16px;
    border-bottom: 1px solid var(--line);
    display:flex; align-items:center; justify-content:space-between;
}
.widget-dropdown .widget-head h6 { margin: 0; font-size: 15px; font-weight: 700; color: var(--ink); }
.widget-dropdown .widget-head .clear-all {
    font-size: 12px; color: var(--brand); font-weight: 600; text-decoration: none;
}
.widget-list { max-height: 360px; overflow-y: auto; }
.widget-item {
    display:flex; align-items:flex-start; gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--line);
    transition: background .15s ease;
    text-decoration: none !important;
    color: var(--ink) !important;
}
.widget-item:last-child { border-bottom: 0; }
.widget-item:hover { background: var(--brand-50); }
.widget-item .wi-icon {
    flex: 0 0 36px; height: 36px;
    border-radius: 10px;
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size: 14px;
}
.widget-item .wi-icon.--play  { background: var(--grad-rose); }
.widget-item .wi-icon.--book  { background: var(--grad-warm); }
.widget-item .wi-icon.--quiz  { background: var(--grad-cyan); }
.widget-item .wi-icon.--check { background: var(--grad-green); }
.widget-item .wi-icon.--msg   { background: var(--grad-violet); }
.widget-item .wi-body { flex:1; min-width: 0; }
.widget-item .wi-title { font-size: 13.5px; font-weight: 600; line-height: 1.4; color: var(--ink); }
.widget-item .wi-meta  { font-size: 11.5px; color: var(--muted); margin-top: 3px; }
.widget-dropdown .widget-foot {
    padding: 12px 16px; text-align:center;
    border-top: 1px solid var(--line);
    background: #fafbfd;
}
.widget-dropdown .widget-foot a {
    color: var(--brand); font-weight: 600; font-size: 13px; text-decoration: none;
}
.widget-dropdown .widget-foot a:hover { color: var(--brand-700); }

/* =========================================================
   CTA BANNER (alt sayfa CTA)
   ========================================================= */
.cta-banner {
    position: relative; overflow: hidden;
    background: var(--grad-hero);
    border-radius: var(--radius-lg);
    padding: 36px 32px;
    color:#fff;
}
.cta-banner::before {
    content:""; position:absolute; right: -60px; top: -60px;
    width: 240px; height: 240px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 70%);
}
.cta-banner h3 { color:#fff; font-weight: 700; font-size: 1.4rem; margin: 0 0 6px; }
.cta-banner p { color: rgba(255,255,255,.88); margin: 0 0 16px; }

/* Mobil */
@media (max-width: 640px) {
    section.bg-blue, section.bg-dark { border-radius: 0 0 18px 18px; padding-top: 32px !important; padding-bottom: 40px !important; }
    .home-hero { padding: 48px 0 56px; border-radius: 0 0 22px 22px; }
    .menu-card { padding: 22px 18px; min-height: auto; }
    .quiz-navigator-grid { grid-template-columns: repeat(5, 1fr); }
    .home-hero .stats { gap: 10px; }
    .home-hero .stat { padding: 12px 14px; }
    .home-hero .stat .v { font-size: 1.3rem; }
}
