/* =====================================================================
   NextLearns — Master CSS  v5.0.0
   Navy + Blue rebrand — image logo — legal pages
   ===================================================================== */

/* ── VARIABLES ──────────────────────────────────────────────────────── */
:root {
    --bg:          #0c1220;
    --card-bg:     rgba(15,23,42,0.85);
    --accent:      #4f8fff;
    --accent-glow: rgba(79,143,255,0.12);
    --text-main:   #f1f5f9;
    --text-dim:    #94a3b8;
    --border:      rgba(148,163,184,0.08);
    --radius-lg:   32px;
    --radius-md:   16px;
    --max-w:       1200px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── BODY & GRAIN ───────────────────────────────────────────────────── */
body {
    background-color: var(--bg);
    color: var(--text-main);
    font-family: 'Inter', sans-serif;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}
body::before {
    content: "";
    position: fixed; inset: 0;
    background: url('https://grainy-gradients.vercel.app/noise.svg');
    opacity: 0.03;
    pointer-events: none;
    z-index: 9999;
}

h1, h2, h3, h4, h5 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1;
}
a { text-decoration: none; }
p { line-height: 1.6; }

/* ── NAV ────────────────────────────────────────────────────────────── */
.nl-nav {
    position: fixed;
    top: 24px; left: 50%;
    transform: translateX(-50%);
    width: 90%; max-width: 1100px;
    background: rgba(12,18,32,0.82);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 12px 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 1000;
    transition: padding 0.4s ease, background 0.4s ease;
}
.nl-nav__logo {
    display: flex;
    align-items: center;
    height: 36px;
}
.nl-nav__logo img {
    height: 36px;
    width: 36px;
    display: block;
    object-fit: contain;
}

.nl-nav__links {
    display: flex; gap: 28px;
}
.nl-nav__links a {
    color: var(--text-dim);
    font-size: 13px; font-weight: 500;
    transition: color 0.25s;
}
.nl-nav__links a:hover { color: var(--accent); }

.nl-nav__right { display: flex; align-items: center; gap: 14px; }
.nl-nav__badge { font-size: 12px; color: var(--text-dim); font-weight: 600; letter-spacing: 0.05em; }

/* ── BUTTONS ────────────────────────────────────────────────────────── */
.btn-mag {
    background: var(--accent);
    color: #fff;
    padding: 14px 32px;
    border-radius: 100px;
    font-weight: 700;
    font-size: 15px;
    font-family: 'Bricolage Grotesque', sans-serif;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: none; cursor: pointer;
    transition: transform .3s cubic-bezier(.23,1,.32,1),
                box-shadow .3s cubic-bezier(.23,1,.32,1);
    box-shadow: 0 10px 40px var(--accent-glow);
}
.btn-mag:hover { transform: translateY(-3px) scale(1.02); box-shadow: 0 20px 60px var(--accent-glow); color:#fff; }
.btn-mag--sm   { padding: 10px 22px; font-size: 13px; }
.btn-mag--dark { background: #111; color: #fff; box-shadow: none; border: 1px solid rgba(255,255,255,0.1); }
.btn-mag--dark:hover { color: #fff; box-shadow: 0 10px 30px rgba(0,0,0,.5); }

/* ── HERO ────────────────────────────────────────────────────────────── */
.nl-hero {
    padding: 200px 24px 120px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.nl-hero h1 {
    font-size: clamp(50px, 9vw, 110px);
    line-height: 0.87;
    margin-bottom: 28px;
}
.nl-hero h1 em {
    font-style: italic;
    color: transparent;
    -webkit-text-stroke: 1.5px rgba(255,255,255,0.4);
}
.nl-hero p { color: var(--text-dim); font-size: 20px; max-width: 680px; margin: 0 auto 36px; line-height: 1.7; }

/* ── SHARED HELPERS ──────────────────────────────────────────────────── */
.card-label {
    color: var(--accent);
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    display: block;
    margin-bottom: 14px;
}
.glow {
    position: absolute;
    width: 500px; height: 500px;
    background: var(--accent);
    filter: blur(180px);
    opacity: 0.07;
    pointer-events: none;
    border-radius: 50%;
    z-index: 0;
    will-change: transform;
}
.nl-section { max-width: var(--max-w); margin: 0 auto; padding: 100px 24px; }
.section-heading { font-size: clamp(36px, 5vw, 60px); margin-bottom: 16px; }
.section-heading em { font-style: normal; color: var(--accent); }
.section-sub { color: var(--text-dim); font-size: 18px; max-width: 600px; margin-bottom: 60px; }

/* ── TRUST BAR ───────────────────────────────────────────────────────── */
.trust-bar {
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 32px 0;
    overflow: hidden;
    display: flex;
}
.trust-track {
    display: flex;
    gap: 80px;
    white-space: nowrap;
    animation: trustScroll 30s linear infinite;
    flex-shrink: 0;
}
.trust-track span {
    color: var(--text-dim);
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.12em;
    opacity: 0.4;
}
@keyframes trustScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ── BENTO GRID ─────────────────────────────────────────────────────── */
.bento-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 280px;
    gap: 20px;
    margin-top: 60px;
}
.bento-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 40px;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    transition: border-color .3s ease;
    transform-style: preserve-3d;
}
.bento-card:hover { border-color: rgba(255,255,255,.16); }
.bento-card h3    { font-size: 32px; margin-bottom: 12px; }
.bento-card p     { color: var(--text-dim); font-size: 15px; line-height: 1.6; }

/* Grid spans — matching reference layout */
.c-1 { grid-column: span 7; grid-row: span 2; }
.c-2 { grid-column: span 5; grid-row: span 1; }
.c-3 { grid-column: span 5; grid-row: span 1; }
.c-4 { grid-column: span 5; grid-row: span 2; }
.c-5 { grid-column: span 7; grid-row: span 2; }

.bento-card--accent            { background: var(--accent) !important; border-color: transparent !important; }
.bento-card--accent .card-label { color: rgba(255,255,255,.6); }
.bento-card--accent h3          { color: #fff; }
.bento-card--accent p           { color: rgba(255,255,255,.75); }

/* ── CURRICULUM TABLE ────────────────────────────────────────────────── */
.curriculum {
    margin-top: 70px;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.mod-row {
    display: grid;
    grid-template-columns: 80px 1fr 180px;
    padding: 30px 40px;
    border-bottom: 1px solid var(--border);
    align-items: center;
    transition: background .3s;
    cursor: default;
}
.mod-row:last-child { border-bottom: none; }
.mod-row:hover      { background: rgba(255,255,255,0.025); }

.mod-num   { font-family: 'Bricolage Grotesque', sans-serif; color: var(--accent); font-size: 22px; font-weight: 800; }
.mod-title h4 { font-size: 20px; margin-bottom: 5px; }
.mod-title p  { color: var(--text-dim); font-size: 14px; }
.mod-tag   { font-size: 11px; color: var(--text-dim); text-align: right; text-transform: uppercase; font-weight: 700; letter-spacing: 0.1em; }

/* ── SPLIT / FOR WHOM ────────────────────────────────────────────────── */
.split-section {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-top: 60px;
}
.check-box {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 44px;
    backdrop-filter: blur(12px);
}
.check-box--dashed { background: transparent; border-style: dashed; }

.check-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 18px;
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.5;
}
.check-item svg { color: var(--accent); flex-shrink: 0; margin-top: 2px; }
.check-item--cross svg { color: #ef4444; }

/* ── TESTIMONIALS ────────────────────────────────────────────────────── */
.t-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 60px;
}
.t-card {
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 32px;
    transition: border-color .3s;
}
.t-card:hover { border-color: rgba(255,255,255,0.15); }
.t-stars { color: var(--accent); font-size: 16px; margin-bottom: 14px; letter-spacing: 2px; }
.t-card blockquote {
    font-size: 15px;
    color: var(--text-dim);
    font-style: italic;
    margin-bottom: 22px;
    border: none; padding: 0;
    line-height: 1.7;
}
.t-user { display: flex; align-items: center; gap: 12px; }
.t-avatar {
    width: 50px; height: 50px;
    border-radius: 50%;
    background: var(--accent-glow);
    border: 2px solid var(--accent);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; flex-shrink: 0;
    overflow: hidden;
    line-height: 1;
}
.t-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.t-user-info strong { display: block; font-size: 14px; font-weight: 700; }
.t-user-info span { color: var(--accent); font-size: 11px; text-transform: uppercase; font-weight: 600; letter-spacing: 0.08em; }

/* ── GUARANTEE BAND ──────────────────────────────────────────────────── */
.guarantee-band {
    background: var(--accent-glow);
    border: 1px solid rgba(79,143,255,.2);
    border-radius: 20px;
    padding: 44px;
    display: flex;
    align-items: center;
    gap: 32px;
    max-width: var(--max-w);
    margin: 0 auto;
}
.guarantee-icon { font-size: 56px; flex-shrink: 0; }
.guarantee-band h3 { font-size: 28px; margin-bottom: 10px; }
.guarantee-band p  { color: var(--text-dim); font-size: 15px; line-height: 1.7; }

/* ── PRICING TICKET ──────────────────────────────────────────────────── */
.nl-ticket-area {
    padding: 80px 24px 100px;
    display: flex;
    flex-direction: column;
    align-items: center;
    perspective: 2000px;
}
.nl-ticket-area .section-intro { text-align: center; margin-bottom: 60px; }
.nl-ticket-area .section-intro h2 { font-size: clamp(34px,5vw,60px); margin-bottom: 14px; }
.nl-ticket-area .section-intro p  { color: var(--text-dim); font-size: 18px; max-width: 520px; margin: 0 auto; }

.nl-ticket {
    background: #fff; color: #000;
    width: 100%; max-width: 500px;
    padding: 64px 56px;
    border-radius: 44px;
    text-align: center;
    clip-path: polygon(0% 0%, 100% 0%, 100% 72%, 96.5% 75%, 100% 78%, 100% 100%, 0% 100%, 0% 78%, 3.5% 75%, 0% 72%);
    box-shadow: 0 40px 100px rgba(0,0,0,.65);
    transform-style: preserve-3d;
    will-change: transform;
}
.nl-ticket__eyebrow  { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .15em; color: #999; margin-bottom: 6px; }
.nl-ticket__product-name { font-family: 'Inter', sans-serif; font-size: 17px; font-weight: 500; color: #444; margin-bottom: 6px; }
.nl-ticket__price    { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 86px; letter-spacing: -.04em; line-height: 1; color: #000; margin: 8px 0 4px; }
.nl-ticket__price sup { font-size: 30px; vertical-align: super; letter-spacing: 0; font-weight: 700; }
.nl-ticket__subline  { font-size: 11px; font-weight: 700; letter-spacing: .12em; color: #888; text-transform: uppercase; margin-bottom: 4px; }
.nl-ticket__dash     { border: none; border-top: 2px dashed #e0e0e0; margin: 28px 0; }
.nl-ticket__features { list-style: none; text-align: left; margin-bottom: 32px; }
.nl-ticket__features li { padding: 10px 0; font-size: 15px; font-weight: 600; color: #111; border-bottom: 1px solid #f0f0f0; display: flex; align-items: center; gap: 10px; }
.nl-ticket__features li:last-child { border-bottom: none; }
.nl-ticket__payment-note { font-size: 11px; color: #aaa; margin-top: 14px; }

/* ── FAQ ─────────────────────────────────────────────────────────────── */
.faq-list { max-width: 820px; margin: 60px auto 0; }
.faq-item {
    border-bottom: 1px solid var(--border);
    cursor: pointer;
    overflow: hidden;
}
.faq-item:first-child { border-top: 1px solid var(--border); }
.faq-q {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 26px 0;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 19px;
    font-weight: 800;
    gap: 20px;
    color: var(--text-main);
    user-select: none;
}
.faq-q .faq-icon { color: var(--accent); font-size: 24px; flex-shrink: 0; transition: transform .35s ease; line-height: 1; }
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-a {
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.7;
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease, padding .3s ease;
    padding-bottom: 0;
}
.faq-item.open .faq-a { max-height: 300px; padding-bottom: 26px; }

/* ── FOOTER ──────────────────────────────────────────────────────────── */
.nl-footer {
    border-top: 1px solid var(--border);
    padding: 80px 24px;
    text-align: center;
}
.footer-logo {
    display: inline-block;
    margin-bottom: 28px;
    height: 44px;
}
.footer-logo img {
    height: 44px;
    width: 44px;
    display: block;
    object-fit: contain;
}
.footer-links { display: flex; justify-content: center; gap: 30px; flex-wrap: wrap; margin-bottom: 40px; }
.footer-links a { color: var(--text-dim); font-size: 14px; transition: color .25s; }
.footer-links a:hover { color: var(--accent); }
.footer-copy { color: var(--text-dim); font-size: 12px; opacity: .5; }

/* ── WHATSAPP FLOAT ──────────────────────────────────────────────────── */
.wa-float {
    position: relative; display: inline-flex;
    width: 52px; height: 52px;
    background: #25D366; border-radius: 50%;
    align-items: center; justify-content: center;
    box-shadow: 0 8px 24px rgba(37,211,102,.3);
    transition: transform .3s ease, box-shadow .3s ease;
    margin: 0 auto;
}
.wa-float:hover { transform: scale(1.1); box-shadow: 0 12px 32px rgba(37,211,102,.45); }
.wa-float svg { width: 28px; height: 28px; }
.nl-wa-footer-wrap {
    text-align: center; padding: 24px 0 0;
}
.nl-wa-footer-wrap span {
    display: block; font-size: 12px; color: var(--text-dim);
    margin-top: 8px; opacity: .6;
}

/* ── REVEAL (GSAP base) ───────────────────────────────────────────────── */
.reveal { opacity: 1; }

/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media (max-width: 980px) {
    .nl-nav__links { display: none; }
    .bento-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: auto; }
    .c-1,.c-5 { grid-column: span 2; }
    .c-2,.c-3,.c-4 { grid-column: span 1; }
    .c-1,.c-2,.c-3,.c-4,.c-5 { grid-row: span 1; min-height: 240px; }
    .split-section { grid-template-columns: 1fr; }
    .t-grid { grid-template-columns: 1fr 1fr; }
    .mod-row { grid-template-columns: 60px 1fr; }
    .mod-tag { display: none; }
    .nl-hero h1 { font-size: 52px; }
    .nl-nav { width: 95%; padding: 10px 20px; }
    .guarantee-band { flex-direction: column; text-align: center; }
    .nl-ticket { padding: 48px 32px; }
    .nl-ticket__price { font-size: 72px; }
}
@media (max-width: 600px) {
    .bento-grid { grid-template-columns: 1fr; }
    .c-1,.c-2,.c-3,.c-4,.c-5 { grid-column: span 1; min-height: 220px; }
    .t-grid { grid-template-columns: 1fr; }
    .nl-hero { padding: 160px 20px 80px; }
    .nl-hero h1 { font-size: 42px; }
    .btn-mag { padding: 12px 24px; font-size: 14px; }
    .bento-card { padding: 28px; }
    .bento-card h3 { font-size: 26px; }
    .nl-section { padding: 60px 20px; }
    .nl-ticket { padding: 40px 24px; }
    .nl-ticket__price { font-size: 60px; }
    .mod-row { padding: 22px 24px; }
}


/* =====================================================================
   NextLearns v3.0 — Extended Components
   (Page: Programme, About, Contact, Merci + shared partials)
   ===================================================================== */

/* ── NAV ACTIVE LINK ─────────────────────────────────────────────── */
.nl-nav__links a.is-active { color: var(--accent); }

/* ── PAGE HERO VARIANTS ─────────────────────────────────────────── */
.nl-hero--page   { padding: 180px 24px 80px; }
.nl-hero--compact{ padding: 160px 24px 60px; }
.nl-hero--merci  { padding: 180px 24px 80px; }

/* ── STATS PILLS (programme hero) ──────────────────────────────── */
.stats-pills {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 32px;
}
.stat-pill {
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 10px 20px;
    font-size: 14px;
    color: var(--text-dim);
    display: flex;
    align-items: center;
    gap: 6px;
}
.stat-pill strong { color: var(--accent); font-size: 18px; font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; }

/* ── VERTICAL TIMELINE (programme phases) ────────────────────────── */
.nl-timeline {
    margin-top: 60px;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.nl-timeline::before {
    content: "";
    position: absolute;
    left: 31px;
    top: 0; bottom: 0;
    width: 1px;
    background: var(--border);
}
.nl-timeline__item {
    display: flex;
    gap: 32px;
    align-items: flex-start;
    padding: 36px 0;
    border-bottom: 1px solid var(--border);
    position: relative;
}
.nl-timeline__item:last-child { border-bottom: none; }

.nl-timeline__num {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 13px;
    font-weight: 800;
    color: var(--accent);
    background: var(--bg);
    border: 1px solid var(--accent);
    border-radius: 50%;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}
.nl-timeline__label { color: var(--accent); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; display: block; margin-bottom: 8px; }
.nl-timeline__title { font-size: 24px; margin-bottom: 10px; }
.nl-timeline__desc  { color: var(--text-dim); font-size: 15px; line-height: 1.7; }

/* Horizontal timeline variant (about page milestones) */
.nl-timeline--horizontal { flex-direction: row; overflow-x: auto; gap: 0; padding-bottom: 8px; }
.nl-timeline--horizontal::before { left: 0; right: 0; top: 22px; bottom: auto; height: 1px; width: 100%; }
.nl-timeline--horizontal .nl-timeline__item { flex-direction: column; min-width: 200px; padding: 0 32px 0 0; border-bottom: none; }
.nl-timeline--horizontal .nl-timeline__num  { display: none; }
.nl-timeline--horizontal .nl-timeline__dot  {
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 4px var(--accent-glow);
    margin-bottom: 20px;
    flex-shrink: 0;
}

/* ── EXPANDABLE MODULES ──────────────────────────────────────────── */
.curriculum--expandable { cursor: default; }

.mod-row--exp {
    cursor: pointer;
    display: block !important;         /* Override base .mod-row grid */
    grid-template-columns: none !important;
    padding: 0 !important;             /* Header handles its own padding */
}
.mod-row--exp.is-open { background: rgba(255,255,255,0.02); }

.mod-row__header { display: grid; grid-template-columns: 80px 1fr auto; align-items: center; gap: 20px; padding: 30px 40px; }

.mod-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.mod-duration { font-size: 12px; color: var(--text-dim); font-weight: 600; }
.mod-toggle { font-size: 24px; color: var(--accent); transition: transform .35s ease; line-height: 1; }
.mod-row--exp.is-open .mod-toggle { transform: rotate(45deg); }

.mod-lessons {
    max-height: 0;
    overflow: hidden;
    transition: max-height .45s cubic-bezier(.4,0,.2,1), padding .3s ease;
    padding: 0 40px;
    border-top: 0px solid var(--border);
    transition: max-height .45s ease, padding .3s ease, border-top-width .3s ease;
}
.mod-row--exp.is-open .mod-lessons {
    max-height: 800px;
    padding: 20px 40px 32px;
    border-top: 1px solid var(--border);
}

.mod-lesson {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    font-size: 14px;
    color: var(--text-dim);
    line-height: 1.5;
}
.mod-lesson:last-child { border-bottom: none; }
.mod-lesson svg { color: var(--accent); flex-shrink: 0; margin-top: 2px; }

/* ── TOOLS GRID ──────────────────────────────────────────────────── */
.tools-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-top: 48px;
}
.tool-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 28px 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: border-color .3s, transform .3s;
    backdrop-filter: blur(12px);
}
.tool-card:hover { border-color: rgba(255,255,255,.2); transform: translateY(-3px); }
.tool-icon  { font-size: 28px; }
.tool-name  { font-family: 'Bricolage Grotesque', sans-serif; font-size: 17px; font-weight: 800; }
.tool-desc  { font-size: 13px; color: var(--text-dim); }

/* ── ENROLL CTA BLOCK (programme page) ───────────────────────────── */
.nl-enroll-cta {
    text-align: center;
    position: relative;
    overflow: hidden;
}
.enroll-price { display: flex; align-items: baseline; justify-content: center; gap: 4px; margin: 24px 0 8px; }
.enroll-price__amount { font-family: 'Bricolage Grotesque', sans-serif; font-size: 80px; font-weight: 800; letter-spacing: -.04em; line-height: 1; }
.enroll-price__currency { font-family: 'Bricolage Grotesque', sans-serif; font-size: 28px; font-weight: 700; color: var(--text-dim); }

/* ── STATS GRID (about page) ─────────────────────────────────────── */
.nl-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.nl-stat-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 40px 32px;
    text-align: center;
    backdrop-filter: blur(12px);
    transition: border-color .3s;
}
.nl-stat-card:hover { border-color: rgba(79,143,255,.25); }
.nl-stat-card__number { font-family: 'Bricolage Grotesque', sans-serif; font-size: 52px; font-weight: 800; letter-spacing: -.04em; color: var(--accent); line-height: 1; margin-bottom: 8px; }
.nl-stat-card__label  { font-size: 15px; font-weight: 700; margin-bottom: 10px; }
.nl-stat-card__desc   { font-size: 13px; color: var(--text-dim); line-height: 1.6; }

/* ── FOUNDER SECTION ─────────────────────────────────────────────── */
.nl-founder {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 64px;
    align-items: center;
}
.nl-founder__avatar {
    aspect-ratio: 1;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(79,143,255,.15), rgba(79,143,255,.03));
    border: 1px solid rgba(79,143,255,.2);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
}
.nl-founder__avatar::before {
    content: "";
    position: absolute;
    inset: -8px;
    border-radius: 50%;
    border: 1px dashed rgba(79,143,255,.15);
    animation: spinSlow 20s linear infinite;
}
@keyframes spinSlow { to { transform: rotate(360deg); } }
.nl-founder__avatar-inner {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 60px;
    font-weight: 800;
    color: var(--accent);
    letter-spacing: -.04em;
}

.founder-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 6px 14px;
    font-size: 13px;
    color: var(--text-dim);
}

/* ── VALUES GRID ─────────────────────────────────────────────────── */
.values-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-top: 60px;
}
.value-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 40px;
    backdrop-filter: blur(12px);
    transition: border-color .3s;
}
.value-card:hover { border-color: rgba(79,143,255,.2); }
.value-icon  { font-size: 36px; margin-bottom: 16px; display: block; }
.value-title { font-size: 24px; margin-bottom: 12px; }
.value-card p { color: var(--text-dim); font-size: 15px; line-height: 1.7; }

/* ── CONTACT CHANNELS ────────────────────────────────────────────── */
.contact-channels {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 40px;
}
.channel-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 32px;
    display: flex;
    align-items: center;
    gap: 20px;
    backdrop-filter: blur(12px);
    transition: border-color .3s, transform .3s;
    text-decoration: none;
    color: var(--text-main);
}
.channel-card:hover { border-color: rgba(255,255,255,.2); transform: translateY(-3px); color: var(--text-main); }
.channel-card--wa   { border-color: rgba(37,211,102,.25); }
.channel-card--wa:hover { border-color: rgba(37,211,102,.5); }

.channel-icon { font-size: 32px; flex-shrink: 0; }
.channel-info { flex: 1; }
.channel-info strong { display: block; font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.channel-info span   { color: var(--text-dim); font-size: 13px; }
.channel-arrow { color: var(--accent); font-size: 20px; flex-shrink: 0; }

/* ── CONTACT FORM ────────────────────────────────────────────────── */
.contact-form-wrap {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 60px;
    align-items: start;
}

.nl-contact-form {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 48px;
    backdrop-filter: blur(12px);
}

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.form-group:last-of-type { margin-bottom: 24px; }
.form-label { font-size: 13px; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: .08em; }
.form-label span { color: var(--accent); }

.form-input {
    background: rgba(255,255,255,.04);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 14px 18px;
    color: var(--text-main);
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    outline: none;
    transition: border-color .25s, box-shadow .25s;
    width: 100%;
    -webkit-appearance: none;
}
.form-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.form-input::placeholder { color: rgba(156,163,175,.5); }

.form-select { cursor: pointer; }
.form-select option { background: #0f172a; color: var(--text-main); }

.form-textarea { resize: vertical; min-height: 140px; }

.form-success {
    text-align: center;
    padding: 48px 32px;
}
.form-success span { font-size: 48px; display: block; margin-bottom: 16px; }
.form-success strong { font-size: 22px; font-family: 'Bricolage Grotesque', sans-serif; display: block; margin-bottom: 12px; }
.form-success p { color: var(--text-dim); font-size: 15px; }

.form-error-msg {
    background: rgba(239,68,68,.1);
    border: 1px solid rgba(239,68,68,.3);
    border-radius: 12px;
    padding: 14px 18px;
    font-size: 14px;
    color: #fca5a5;
    margin-bottom: 20px;
}

/* ── NEXT STEPS GRID (merci page) ────────────────────────────────── */
.next-steps-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 60px;
}
.next-step-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 36px 28px;
    text-align: center;
    backdrop-filter: blur(12px);
    position: relative;
    transition: border-color .3s;
}
.next-step-card:hover { border-color: rgba(79,143,255,.2); }
.next-step-icon { font-size: 40px; display: block; margin-bottom: 16px; }
.next-step-num  {
    position: absolute;
    top: -14px; left: 28px;
    background: var(--accent);
    color: #fff;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 12px;
    font-weight: 800;
    padding: 4px 12px;
    border-radius: 100px;
}
.next-step-title { font-size: 18px; margin-bottom: 12px; }
.next-step-card p { color: var(--text-dim); font-size: 14px; line-height: 1.6; }

/* ── BONUS GRID (merci page) ────────────────────────────────────── */
.bonus-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 60px;
}
.bonus-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 36px;
    backdrop-filter: blur(12px);
}
.bonus-icon  { font-size: 36px; display: block; margin-bottom: 16px; }
.bonus-card h3 { font-size: 20px; margin-bottom: 10px; }
.bonus-card p  { color: var(--text-dim); font-size: 14px; line-height: 1.6; margin-bottom: 16px; }
.bonus-tag  {
    display: inline-flex;
    font-size: 11px;
    font-weight: 700;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: .1em;
    background: var(--accent-glow);
    padding: 4px 10px;
    border-radius: 100px;
}

/* Celebration badge on merci hero */
.merci-badge { font-size: 72px; display: block; margin-bottom: 16px; animation: bounceBadge .6s ease; }
@keyframes bounceBadge { 0%,100%{transform:scale(1)} 50%{transform:scale(1.2)} }

/* ── SUPPORT BAND (merci page) ───────────────────────────────────── */
.support-band {
    background: var(--accent-glow);
    border: 1px solid rgba(79,143,255,.2);
    border-radius: 20px;
    padding: 44px;
    display: flex;
    align-items: center;
    gap: 32px;
}
.support-band__icon { font-size: 48px; flex-shrink: 0; }
.support-band h3 { font-size: 26px; margin-bottom: 8px; }
.support-band p  { color: var(--text-dim); font-size: 15px; }

/* ── CTA BAND (shared footer partial) ───────────────────────────── */
.nl-cta-band {
    text-align: center;
    padding: 100px 24px;
    position: relative;
    overflow: hidden;
    border-top: 1px solid var(--border);
}
.nl-cta-band h2 { font-size: clamp(36px,5vw,60px); margin-bottom: 16px; }
.nl-cta-band h2 em { font-style: normal; color: var(--accent); }
.nl-cta-band p  { color: var(--text-dim); font-size: 18px; max-width: 500px; margin: 0 auto 36px; }

/* ── FOOTER NAV (multi-column) ───────────────────────────────────── */
.footer-nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    max-width: 600px;
    margin: 0 auto 48px;
    text-align: left;
}
.footer-nav__col { display: flex; flex-direction: column; gap: 10px; }
.footer-nav__col strong { color: var(--text-main); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 4px; }
.footer-nav__col a { color: var(--text-dim); font-size: 14px; transition: color .25s; }
.footer-nav__col a:hover { color: var(--accent); }

.footer-bottom { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.footer-socials { display: flex; gap: 14px; }
.footer-socials a { color: var(--text-dim); display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: 1px solid var(--border); border-radius: 50%; transition: color .25s, border-color .25s; }
.footer-socials a:hover { color: var(--accent); border-color: var(--accent); }

/* ── EXTRA RESPONSIVE RULES ──────────────────────────────────────── */
@media (max-width: 1100px) {
    .tools-grid { grid-template-columns: repeat(4, 1fr); }
    .nl-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 980px) {
    .tools-grid { grid-template-columns: repeat(2, 1fr); }
    .contact-channels { grid-template-columns: 1fr; }
    .contact-form-wrap { grid-template-columns: 1fr; gap: 40px; }
    .form-row { grid-template-columns: 1fr; }
    .next-steps-grid { grid-template-columns: repeat(2, 1fr); }
    .bonus-grid { grid-template-columns: 1fr; }
    .nl-founder { grid-template-columns: 1fr; text-align: center; }
    .nl-founder__avatar { width: 160px; height: 160px; margin: 0 auto; }
    .values-grid { grid-template-columns: 1fr; }
    .footer-nav { grid-template-columns: 1fr; text-align: center; }
    .support-band { flex-direction: column; text-align: center; }
    .mod-row__header { grid-template-columns: 60px 1fr auto; padding: 24px; }
}
@media (max-width: 600px) {
    .nl-stats-grid { grid-template-columns: 1fr; }
    .next-steps-grid { grid-template-columns: 1fr; }
    .tools-grid { grid-template-columns: repeat(2, 1fr); }
    .nl-contact-form { padding: 28px 20px; }
    .mod-row__header { grid-template-columns: 50px 1fr; }
    .mod-meta .mod-tag, .mod-meta .mod-duration { display: none; }
    .nl-timeline--horizontal { flex-direction: column; }
    .nl-timeline--horizontal::before { display: none; }
    .nl-founder__avatar-inner { font-size: 40px; }
}

/* ── MISSING CLASS FIXES ─────────────────────────────────────────── */
.contact-form-intro { /* intro text block left of form */ }
.nl-founder__bio    { flex: 1; }
.nl-timeline__body  { flex: 1; }
/* ═══════════════════════════════════════════════════════════
   LEGAL / PROSE PAGES — append to assets/css/nextlearns.css
   ═══════════════════════════════════════════════════════════ */

/* ── Legal content wrapper ── */
.nl-legal-content {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 0;
  padding-bottom: 80px;
}

/* ── Prose typography (WordPress editor output) ── */
.nl-legal-content h2 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 700;
  color: var(--text-main);
  margin: 56px 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.nl-legal-content h3 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(18px, 2.5vw, 22px);
  font-weight: 600;
  color: var(--text-main);
  margin: 40px 0 12px;
}

.nl-legal-content p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--text-dim);
  margin: 0 0 20px;
}

.nl-legal-content strong {
  color: var(--text-main);
  font-weight: 600;
}

.nl-legal-content em {
  color: var(--accent);
  font-style: normal;
}

.nl-legal-content a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity .2s;
}

.nl-legal-content a:hover {
  opacity: .75;
}

/* ── Lists ── */
.nl-legal-content ul,
.nl-legal-content ol {
  padding-left: 24px;
  margin: 0 0 24px;
}

.nl-legal-content li {
  font-size: 16px;
  line-height: 1.75;
  color: var(--text-dim);
  margin-bottom: 8px;
}

.nl-legal-content ul li::marker {
  color: var(--accent);
}

.nl-legal-content ol li::marker {
  color: var(--accent);
  font-weight: 600;
}

/* ── Info card (optional — for highlighted blocks) ── */
.nl-legal-content blockquote {
  background: var(--card-bg);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-md);
  padding: 20px 24px;
  margin: 24px 0;
}

.nl-legal-content blockquote p {
  color: var(--text-main);
  margin-bottom: 0;
}

/* ── Table (if used in legal content) ── */
.nl-legal-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
}

.nl-legal-content th,
.nl-legal-content td {
  text-align: left;
  padding: 12px 16px;
  font-size: 15px;
  border-bottom: 1px solid var(--border);
}

.nl-legal-content th {
  color: var(--text-main);
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.nl-legal-content td {
  color: var(--text-dim);
}

/* ── Last-updated line ── */
.nl-legal-updated {
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  font-size: 13px;
  color: var(--text-dim);
  opacity: .6;
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .nl-legal-content {
    padding-left: 16px;
    padding-right: 16px;
  }

  .nl-legal-content h2 {
    margin-top: 40px;
  }
}


/* =====================================================================
   WOOCOMMERCE — Full Dark Theme Override  v5.0.0
   ===================================================================== */

/* ── Wrapper ──────────────────────────────────────────────────────── */
.nl-woo-wrap {
    max-width: 1000px;
    margin: 0 auto;
    padding-top: 0;
    padding-bottom: 80px;
}

/* ── WC Notices (success, error, info) ─────────────────────────────── */
.woocommerce-message,
.woocommerce-info {
    background: rgba(79,143,255,.08) !important;
    border: 1px solid rgba(79,143,255,.25) !important;
    border-radius: 12px !important;
    color: var(--text-main) !important;
    padding: 16px 20px !important;
    margin-bottom: 24px !important;
    font-size: 14px;
    line-height: 1.6;
}
.woocommerce-message::before,
.woocommerce-info::before {
    color: var(--accent) !important;
}
.woocommerce-error {
    background: rgba(239,68,68,.08) !important;
    border: 1px solid rgba(239,68,68,.25) !important;
    border-radius: 12px !important;
    color: #fca5a5 !important;
    padding: 16px 20px !important;
    margin-bottom: 24px !important;
    list-style: none !important;
    font-size: 14px;
}
.woocommerce-error li {
    color: #fca5a5 !important;
}
.woocommerce-message a,
.woocommerce-info a {
    color: var(--accent) !important;
    font-weight: 600;
}
.woocommerce-message .button,
.woocommerce-info .button {
    background: var(--accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 100px !important;
    padding: 8px 20px !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    cursor: pointer !important;
    float: right !important;
}

/* ── Global WC buttons ─────────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit,
.woocommerce #place_order {
    background: var(--accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 100px !important;
    padding: 14px 32px !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    cursor: pointer !important;
    transition: transform .3s ease, box-shadow .3s ease !important;
    box-shadow: 0 10px 40px var(--accent-glow) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce #place_order:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 16px 50px var(--accent-glow) !important;
    color: #fff !important;
    background: var(--accent) !important;
}
.woocommerce a.button.alt.disabled,
.woocommerce button.button.alt.disabled {
    opacity: .5 !important;
    cursor: not-allowed !important;
}

/* ── Global WC forms ───────────────────────────────────────────────── */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea,
.woocommerce-page form .form-row select,
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="password"],
.woocommerce input[type="number"],
.woocommerce select,
.woocommerce textarea,
.select2-container--default .select2-selection--single {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    padding: 14px 18px !important;
    color: var(--text-main) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    outline: none !important;
    width: 100% !important;
    transition: border-color .25s, box-shadow .25s !important;
    -webkit-appearance: none !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce input[type="text"]:focus,
.woocommerce input[type="email"]:focus,
.woocommerce input[type="tel"]:focus,
.woocommerce input[type="password"]:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px var(--accent-glow) !important;
}
.woocommerce form .form-row input.input-text::placeholder,
.woocommerce input::placeholder {
    color: rgba(148,163,184,.5) !important;
}
.woocommerce form .form-row label,
.woocommerce-page form .form-row label {
    color: var(--text-dim) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    margin-bottom: 8px !important;
    display: block !important;
}
.woocommerce form .form-row label .required {
    color: var(--accent) !important;
}
.woocommerce form .form-row {
    margin-bottom: 20px !important;
}

/* ── Select2 dropdown override ────────────────────────────────────── */
.select2-container--default .select2-selection--single {
    height: auto !important;
    line-height: 1.4 !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text-main) !important;
    padding: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 50% !important;
    transform: translateY(-50%) !important;
    right: 12px !important;
}
.select2-dropdown {
    background: #0f172a !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}
.select2-results__option {
    color: var(--text-dim) !important;
    padding: 10px 16px !important;
}
.select2-results__option--highlighted {
    background: var(--accent) !important;
    color: #fff !important;
}

/* ═══════════════════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE
   ═══════════════════════════════════════════════════════════════════ */
.woocommerce div.product {
    max-width: 900px;
    margin: 0 auto;
}
.woocommerce div.product div.images {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    padding: 20px;
}
.woocommerce div.product div.images img {
    border-radius: var(--radius-md);
}
.woocommerce div.product div.summary {
    color: var(--text-main);
}
.woocommerce div.product .product_title {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 800;
    letter-spacing: -.04em;
    color: var(--text-main);
    margin-bottom: 16px;
}
.woocommerce div.product .price {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 36px;
    font-weight: 800;
    color: var(--accent) !important;
    margin-bottom: 24px;
}
.woocommerce div.product .price del {
    color: var(--text-dim) !important;
    opacity: .5;
    font-size: 22px;
}
.woocommerce div.product .price ins {
    text-decoration: none;
    color: var(--accent) !important;
}
.woocommerce div.product .woocommerce-product-details__short-description {
    color: var(--text-dim);
    font-size: 16px;
    line-height: 1.7;
    margin-bottom: 28px;
}
.woocommerce div.product form.cart {
    margin-bottom: 32px;
}
.woocommerce div.product form.cart .quantity {
    display: none; /* single product site, always qty 1 */
}
.woocommerce div.product .woocommerce-tabs {
    margin-top: 60px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
    list-style: none;
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--border);
    margin: 0 0 32px;
    padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before {
    display: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    color: var(--text-dim);
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 14px 24px;
    display: block;
    border-bottom: 2px solid transparent;
    transition: color .25s, border-color .25s;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--accent);
    border-bottom-color: var(--accent);
}
.woocommerce div.product .woocommerce-tabs .panel {
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.7;
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px;
    color: var(--text-main);
    margin-bottom: 16px;
}

/* Sale badge */
.woocommerce span.onsale {
    background: var(--accent) !important;
    color: #fff !important;
    border-radius: 100px !important;
    font-weight: 700 !important;
    padding: 6px 16px !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    min-height: auto !important;
    min-width: auto !important;
    line-height: 1.4 !important;
}

/* Star rating */
.woocommerce .star-rating {
    color: var(--accent) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   CART PAGE
   ═══════════════════════════════════════════════════════════════════ */
.woocommerce-cart .woocommerce {
    max-width: 720px;
    margin: 0 auto;
}

/* ── Nav cart icon ─────────────────────────────────────────────────── */
.nl-nav__cart {
    position: relative;
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px;
    color: var(--text-dim);
    transition: color .25s;
}
.nl-nav__cart:hover { color: var(--accent); }
.nl-nav__cart-count {
    position: absolute; top: 2px; right: 0;
    background: var(--accent); color: #fff;
    font-size: 10px; font-weight: 800;
    width: 18px; height: 18px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    line-height: 1;
}

/* ── Cart table ────────────────────────────────────────────────────── */
.woocommerce table.shop_table {
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-lg) !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    overflow: hidden;
    background: var(--card-bg) !important;
}
.woocommerce table.shop_table th {
    background: rgba(255,255,255,.03) !important;
    color: var(--text-dim) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid var(--border) !important;
}
.woocommerce table.shop_table td {
    padding: 20px !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text-main) !important;
    vertical-align: middle !important;
    background: transparent !important;
}
.woocommerce table.shop_table td.product-name a {
    color: var(--text-main) !important;
    font-weight: 600;
}
.woocommerce table.shop_table td.product-price,
.woocommerce table.shop_table td.product-subtotal {
    color: var(--text-main) !important;
    font-weight: 700 !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
}
.woocommerce table.shop_table img {
    width: 64px !important;
    border-radius: 12px !important;
}
.woocommerce a.remove {
    color: #ef4444 !important;
    font-size: 20px !important;
    font-weight: 700 !important;
}

/* Cart quantity input */
.woocommerce .quantity .qty {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    color: var(--text-main) !important;
    padding: 8px 12px !important;
    width: 60px !important;
    text-align: center !important;
}

/* Cart totals */
.woocommerce .cart_totals,
.woocommerce-page .cart_totals {
    background: var(--card-bg) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 32px !important;
    margin-top: 32px;
}
.woocommerce .cart_totals h2 {
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-size: 22px !important;
    color: var(--text-main) !important;
    margin-bottom: 20px !important;
}
.woocommerce .cart_totals table {
    border: none !important;
    background: transparent !important;
}
.woocommerce .cart_totals table th {
    background: transparent !important;
    border: none !important;
    color: var(--text-dim) !important;
}
.woocommerce .cart_totals table td {
    background: transparent !important;
    border: none !important;
    color: var(--text-main) !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-size: 18px !important;
    font-weight: 700 !important;
}
.woocommerce .cart_totals .order-total td {
    color: var(--accent) !important;
    font-size: 32px !important;
    font-weight: 800 !important;
}

/* Hide coupon on cart (keep it clean) */
.woocommerce-cart .coupon { display: none !important; }

/* Update cart button — subtle */
.woocommerce-cart button[name="update_cart"] {
    background: rgba(255,255,255,.06) !important;
    color: var(--text-dim) !important;
    border: 1px solid var(--border) !important;
    font-size: 13px !important;
    padding: 10px 20px !important;
}
.woocommerce-cart button[name="update_cart"]:hover {
    background: rgba(255,255,255,.1) !important;
    color: var(--text-main) !important;
}

/* Proceed to checkout — big prominent button */
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button {
    width: 100% !important;
    padding: 20px 32px !important;
    font-size: 18px !important;
    margin-top: 16px !important;
    text-align: center !important;
}

/* Cart actions row */
.woocommerce-cart .cart-collaterals {
    margin-top: 0;
}

/* Cart empty message */
.woocommerce-cart .cart-empty {
    text-align: center;
    padding: 60px 24px;
    color: var(--text-dim);
    font-size: 18px;
}
.woocommerce-cart .return-to-shop a {
    display: inline-block;
    margin-top: 16px;
}

/* Cart item product thumbnail */
.woocommerce-cart .product-thumbnail {
    width: 80px !important;
}
.woocommerce-cart .product-thumbnail img {
    border-radius: 12px !important;
    width: 64px !important;
    height: 64px !important;
    object-fit: cover !important;
}

/* Cart product remove X */
.woocommerce-cart .product-remove a.remove {
    width: 28px !important; height: 28px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    border-radius: 8px !important;
    background: rgba(239,68,68,.08) !important;
    color: #ef4444 !important;
    font-size: 16px !important;
    line-height: 1 !important;
    transition: background .25s !important;
}
.woocommerce-cart .product-remove a.remove:hover {
    background: rgba(239,68,68,.2) !important;
}

/* Quantity input */
.woocommerce-cart .quantity {
    display: none !important; /* Digital products — always 1 */
}

/* Continue shopping link */
.woocommerce-cart .return-to-shop {
    text-align: center; margin-top: 24px;
}

/* ═══════════════════════════════════════════════════════════════════
   CHECKOUT PAGE — Compact, centered, premium
   ═══════════════════════════════════════════════════════════════════ */
.woocommerce-checkout .nl-woo-wrap {
    max-width: 580px;
}

.woocommerce form.checkout {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* Hide all the junk WC adds */
.woocommerce-form-login-toggle,
.woocommerce-form-coupon-toggle,
.woocommerce-form-login,
.woocommerce-form-coupon,
.woocommerce-additional-fields,
.woocommerce-account-fields,
.create-account,
#ship-to-different-address-checkbox,
.woocommerce-shipping-fields,
.woocommerce-checkout .shop_table thead,
.woocommerce-info,
h3#order_review_heading {
    display: none !important;
}

/* Billing card */
.woocommerce-billing-fields {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 32px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.woocommerce-billing-fields h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: var(--text-main);
    margin-bottom: 20px;
    letter-spacing: -.02em;
    text-align: center;
}

/* Two-column name row */
.woocommerce-billing-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.woocommerce-billing-fields__field-wrapper .form-row-wide {
    grid-column: 1 / -1;
}
.woocommerce-billing-fields__field-wrapper label {
    display: none !important;
}

/* Order review card */
.woocommerce-checkout-review-order {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 32px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

/* Order review table */
.woocommerce table.woocommerce-checkout-review-order-table {
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    margin-bottom: 20px;
}
.woocommerce table.woocommerce-checkout-review-order-table th,
.woocommerce table.woocommerce-checkout-review-order-table td {
    background: transparent !important;
    border-bottom: 1px solid var(--border) !important;
    padding: 14px 0 !important;
}
.woocommerce table.woocommerce-checkout-review-order-table th {
    color: var(--text-dim) !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
}
.woocommerce table.woocommerce-checkout-review-order-table td {
    color: var(--text-main) !important;
}
.woocommerce table.woocommerce-checkout-review-order-table .order-total td {
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-size: 32px !important;
    font-weight: 800 !important;
    color: var(--accent) !important;
    border-bottom: none !important;
    padding-top: 20px !important;
}
.woocommerce table.woocommerce-checkout-review-order-table .order-total th {
    border-bottom: none !important;
    padding-top: 20px !important;
    vertical-align: bottom !important;
}

/* Payment methods */
.woocommerce-checkout #payment {
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 20px !important;
    border: none !important;
}
.woocommerce-checkout #payment ul.payment_methods li {
    background: rgba(255,255,255,.03) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    padding: 16px 20px !important;
    margin-bottom: 10px !important;
}
.woocommerce-checkout #payment ul.payment_methods li label {
    color: var(--text-main) !important;
    font-weight: 600 !important;
    cursor: pointer !important;
}
.woocommerce-checkout #payment div.payment_box {
    background: rgba(79,143,255,.06) !important;
    color: var(--text-dim) !important;
    border-radius: 8px !important;
    padding: 14px 18px !important;
    margin-top: 10px !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
}
.woocommerce-checkout #payment div.payment_box::before {
    display: none !important;
}

/* Place order — big blue button */
.woocommerce #place_order {
    width: 100% !important;
    margin-top: 8px !important;
    padding: 20px 32px !important;
    font-size: 18px !important;
    letter-spacing: .02em !important;
}

/* Privacy text */
.woocommerce-checkout .woocommerce-privacy-policy-text {
    color: var(--text-dim) !important;
    font-size: 12px !important;
    opacity: .6 !important;
    margin-top: 12px !important;
    text-align: center !important;
}

/* Terms checkbox */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
    text-align: center !important;
    font-size: 13px !important;
}

@media (max-width: 480px) {
    .woocommerce-billing-fields__field-wrapper {
        grid-template-columns: 1fr;
    }
    .woocommerce-billing-fields,
    .woocommerce-checkout-review-order {
        padding: 24px 20px;
    }
}
}
.woocommerce-checkout .woocommerce-privacy-policy-text a {
    color: var(--accent) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   MY ACCOUNT PAGE
   ═══════════════════════════════════════════════════════════════════ */
.woocommerce-account .nl-woo-wrap {
    max-width: 960px;
}

/* Navigation sidebar */
.woocommerce-account .woocommerce-MyAccount-navigation {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 8px;
    margin-bottom: 32px;
    backdrop-filter: blur(12px);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    flex: 1;
    min-width: fit-content;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 12px 20px;
    color: var(--text-dim);
    font-size: 14px;
    font-weight: 600;
    border-radius: 12px;
    text-align: center;
    transition: background .25s, color .25s;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    background: rgba(255,255,255,.04);
    color: var(--text-main);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--dashboard.is-active a {
    background: var(--accent);
    color: #fff;
}

/* Content area */
.woocommerce-account .woocommerce-MyAccount-content {
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.7;
}
.woocommerce-account .woocommerce-MyAccount-content p {
    margin-bottom: 16px;
}
.woocommerce-account .woocommerce-MyAccount-content a {
    color: var(--accent);
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    color: var(--text-main);
    margin-bottom: 16px;
}

/* Order table */
.woocommerce-account .woocommerce-orders-table__cell-order-actions a {
    display: inline-block;
    margin: 2px 4px;
}

/* Login / Register form */
.woocommerce form.login,
.woocommerce form.register {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 40px;
    backdrop-filter: blur(12px);
    max-width: 480px;
    margin: 0 auto;
}
.woocommerce form.login h2,
.woocommerce form.register h2,
.woocommerce .woocommerce-form-login h2 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 28px;
    color: var(--text-main);
    text-align: center;
    margin-bottom: 28px;
}
.woocommerce form.login .form-row,
.woocommerce form.register .form-row {
    margin-bottom: 20px !important;
}
.woocommerce form.login .woocommerce-form__label-for-checkbox {
    color: var(--text-dim) !important;
    font-size: 14px !important;
}
.woocommerce .lost_password a {
    color: var(--accent) !important;
    font-size: 14px;
}

/* ═══════════════════════════════════════════════════════════════════
   ORDER RECEIVED / THANK YOU (if they reach WC default)
   ═══════════════════════════════════════════════════════════════════ */
.woocommerce-order-received .woocommerce-thankyou-order-received {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px;
    font-weight: 700;
    color: var(--accent);
    text-align: center;
    margin-bottom: 32px;
}
.woocommerce-order-received .woocommerce-order-overview {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 16px;
    margin-bottom: 40px;
}
.woocommerce-order-received .woocommerce-order-overview li {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 20px;
    text-align: center;
}
.woocommerce-order-received .woocommerce-order-overview li strong {
    display: block;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 20px;
    color: var(--text-main);
    margin-top: 8px;
}

/* ═══════════════════════════════════════════════════════════════════
   WC RESPONSIVE
   ═══════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        flex-direction: column;
    }
    .woocommerce-checkout .nl-woo-wrap {
        padding-left: 16px;
        padding-right: 16px;
    }
    .woocommerce-billing-fields,
    .woocommerce-checkout-review-order {
        padding: 24px 20px;
    }
    .woocommerce table.shop_table {
        font-size: 14px;
    }
    .woocommerce table.shop_table img {
        width: 48px !important;
    }
    .woocommerce div.product div.images,
    .woocommerce div.product div.summary {
        float: none !important;
        width: 100% !important;
    }
}

@media (max-width: 480px) {
    .woocommerce form.login,
    .woocommerce form.register {
        padding: 28px 20px;
    }
    .woocommerce table.woocommerce-checkout-review-order-table .order-total td {
        font-size: 22px !important;
    }
}


/* =====================================================================
   NEXTLEARNS v5.1 — Premium Features
   Hamburger · Cookie · Sticky CTA · Exit popup · Preloader
   Scroll progress · Back-to-top · Micro-interactions
   ===================================================================== */

/* ── SCROLL PROGRESS BAR ──────────────────────────────────────────── */
.nl-scroll-progress {
    position: fixed;
    top: 0; left: 0;
    height: 3px;
    width: 0%;
    background: linear-gradient(90deg, var(--accent), #7cb8ff);
    z-index: 10001;
    transition: width 50ms linear;
    pointer-events: none;
}

/* ── HAMBURGER BUTTON ─────────────────────────────────────────────── */
.nl-hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px 4px;
    z-index: 10003;
}
.nl-hamburger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text-main);
    border-radius: 2px;
    transition: transform .3s ease, opacity .3s ease;
    transform-origin: center;
}
.nl-hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nl-hamburger.is-open span:nth-child(2) { opacity: 0; }
.nl-hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 980px) {
    .nl-hamburger { display: flex; }
    .nl-desktop-cta { display: none !important; }
    .nl-nav__badge { display: none; }
}

/* ── MOBILE DRAWER ────────────────────────────────────────────────── */
.nl-mobile-drawer {
    position: fixed;
    top: 0; right: 0;
    width: 300px;
    max-width: 85vw;
    height: 100vh;
    background: rgba(12,18,32,0.98);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border-left: 1px solid var(--border);
    z-index: 10002;
    transform: translateX(100%);
    transition: transform .4s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
}
.nl-mobile-drawer.is-open { transform: translateX(0); }

.nl-mobile-drawer__inner {
    display: flex;
    flex-direction: column;
    padding: 100px 32px 40px;
    gap: 8px;
}
.nl-mobile-drawer__inner a {
    color: var(--text-dim);
    font-size: 18px;
    font-weight: 600;
    font-family: 'Bricolage Grotesque', sans-serif;
    padding: 14px 0;
    border-bottom: 1px solid var(--border);
    transition: color .25s, padding-left .25s;
}
.nl-mobile-drawer__inner a:hover,
.nl-mobile-drawer__inner a.is-active {
    color: var(--accent);
    padding-left: 8px;
}
.nl-mobile-drawer__inner .btn-mag {
    border-bottom: none;
    padding: 16px 32px;
    font-size: 16px;
}

.nl-drawer-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.6);
    z-index: 10001;
    opacity: 0;
    visibility: hidden;
    transition: opacity .35s ease, visibility .35s ease;
}
.nl-drawer-overlay.is-visible {
    opacity: 1;
    visibility: visible;
}

/* ── STICKY MOBILE CTA ───────────────────────────────────────────── */
.nl-mobile-cta {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    padding: 12px 20px;
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    background: rgba(12,18,32,0.95);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid var(--border);
    z-index: 9997;
    transform: translateY(100%);
    transition: transform .4s cubic-bezier(.4,0,.2,1);
    display: none;
}
.nl-mobile-cta.is-visible { transform: translateY(0); }
.nl-mobile-cta .btn-mag { width: 100%; justify-content: center; font-size: 16px; padding: 16px; }

@media (max-width: 980px) {
    .nl-mobile-cta { display: block; }
    /* Push WhatsApp float above mobile CTA */
    /* wa-float is in footer now, no position override needed */
}

/* ── PRELOADER ────────────────────────────────────────────────────── */
.nl-preloader {
    position: fixed;
    inset: 0;
    background: var(--bg);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .5s ease, visibility .5s ease;
}
.nl-preloader.is-done {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}
.nl-preloader__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}
.nl-preloader__logo {
    animation: preloaderPulse 1.2s ease-in-out infinite alternate;
}
@keyframes preloaderPulse {
    0%   { opacity: .4; transform: scale(.96); }
    100% { opacity: 1;  transform: scale(1); }
}
.nl-preloader__bar {
    width: 120px;
    height: 3px;
    background: rgba(255,255,255,.08);
    border-radius: 4px;
    overflow: hidden;
}
.nl-preloader__fill {
    width: 0%;
    height: 100%;
    background: var(--accent);
    border-radius: 4px;
    animation: preloaderFill 1.5s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes preloaderFill {
    0%   { width: 0%; }
    60%  { width: 70%; }
    100% { width: 100%; }
}

/* ── COOKIE CONSENT ───────────────────────────────────────────────── */
.nl-cookie {
    position: fixed;
    bottom: 24px; left: 24px; right: 24px;
    z-index: 9998;
    opacity: 0;
    transform: translateY(20px);
    visibility: hidden;
    transition: opacity .4s ease, transform .4s ease, visibility .4s ease;
    pointer-events: none;
}
.nl-cookie.is-visible {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
    pointer-events: auto;
}
.nl-cookie__inner {
    max-width: 680px;
    margin: 0 auto;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    padding: 20px 28px;
    display: flex;
    align-items: center;
    gap: 20px;
}
.nl-cookie p {
    flex: 1;
    color: var(--text-dim);
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
}
.nl-cookie a {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 2px;
}

@media (max-width: 600px) {
    .nl-cookie { bottom: 80px; left: 12px; right: 12px; }
    .nl-cookie__inner { flex-direction: column; text-align: center; padding: 20px; gap: 14px; }
}

/* ── BACK TO TOP ──────────────────────────────────────────────────── */
.nl-btt {
    position: fixed;
    bottom: 30px; left: 30px;
    width: 44px; height: 44px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--text-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 9996;
    opacity: 0;
    transform: translateY(10px) scale(.9);
    visibility: hidden;
    transition: opacity .3s, transform .3s, visibility .3s, color .25s, border-color .25s;
}
.nl-btt.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
    visibility: visible;
}
.nl-btt:hover {
    color: var(--accent);
    border-color: var(--accent);
}
@media (max-width: 980px) {
    .nl-btt { bottom: 90px; left: 20px; }
}

/* ── EXIT-INTENT POPUP ────────────────────────────────────────────── */
.nl-exit-popup {
    position: fixed;
    inset: 0;
    z-index: 99998;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0,0,0,.7);
    opacity: 0;
    visibility: hidden;
    transition: opacity .35s ease, visibility .35s ease;
}
.nl-exit-popup.is-visible {
    opacity: 1;
    visibility: visible;
}
.nl-exit-popup__card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    padding: 48px 40px;
    max-width: 440px;
    width: 100%;
    text-align: center;
    position: relative;
    transform: scale(.9) translateY(20px);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
}
.nl-exit-popup.is-visible .nl-exit-popup__card {
    transform: scale(1) translateY(0);
}
.nl-exit-popup__close {
    position: absolute;
    top: 16px; right: 20px;
    background: none;
    border: none;
    color: var(--text-dim);
    font-size: 28px;
    cursor: pointer;
    transition: color .25s;
    line-height: 1;
}
.nl-exit-popup__close:hover { color: var(--text-main); }
.nl-exit-popup__emoji { font-size: 56px; display: block; margin-bottom: 16px; }
.nl-exit-popup__card h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(22px, 4vw, 28px);
    font-weight: 800;
    color: var(--text-main);
    margin-bottom: 12px;
    letter-spacing: -.02em;
}
.nl-exit-popup__card p {
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 24px;
}
.nl-exit-popup__dismiss {
    display: block;
    margin-top: 16px;
    color: var(--text-dim);
    font-size: 13px;
    cursor: pointer;
    opacity: .6;
    transition: opacity .25s;
}
.nl-exit-popup__dismiss:hover { opacity: 1; }

/* ── BUTTON RIPPLE EFFECT ─────────────────────────────────────────── */
.btn-mag {
    position: relative;
    overflow: hidden;
}
.btn-mag .ripple {
    position: absolute;
    border-radius: 50%;
    background: rgba(255,255,255,.25);
    transform: scale(0);
    animation: rippleAnim .6s ease-out;
    pointer-events: none;
}
@keyframes rippleAnim {
    to { transform: scale(4); opacity: 0; }
}

/* ── CARD HOVER GLOW ──────────────────────────────────────────────── */
.bento-card::after,
.t-card::after,
.value-card::after,
.next-step-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    opacity: 0;
    transition: opacity .4s ease;
    background: radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(79,143,255,.06), transparent 40%);
    pointer-events: none;
    z-index: 0;
}
.bento-card:hover::after,
.t-card:hover::after,
.value-card:hover::after,
.next-step-card:hover::after {
    opacity: 1;
}

/* ── LINK UNDERLINE ANIMATION ─────────────────────────────────────── */
.nl-nav__links a,
.footer-nav__col a,
.nl-mobile-drawer__inner a:not(.btn-mag) {
    position: relative;
}
.nl-nav__links a::after,
.footer-nav__col a::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0%;
    height: 1.5px;
    background: var(--accent);
    transition: width .3s ease;
}
.nl-nav__links a:hover::after,
.nl-nav__links a.is-active::after,
.footer-nav__col a:hover::after {
    width: 100%;
}




/* =====================================================================
   ELEMENTOR COMPATIBILITY
   Ensures Elementor sections inherit our dark theme
   ===================================================================== */

/* ── Elementor inherits dark bg ───────────────────────────────────── */
.elementor-page,
.elementor {
    background: var(--bg) !important;
    color: var(--text-main) !important;
}

/* Elementor sections — transparent by default (dark bg shows through) */
.elementor-section {
    background-color: transparent;
}

/* Elementor headings */
.elementor-heading-title {
    font-family: 'Bricolage Grotesque', sans-serif !important;
    color: var(--text-main) !important;
    letter-spacing: -.02em !important;
}

/* Elementor text */
.elementor-widget-text-editor,
.elementor-widget-text-editor p {
    color: var(--text-dim) !important;
    line-height: 1.7 !important;
}

/* Elementor buttons — inherit our accent */
.elementor-button {
    background-color: var(--accent) !important;
    color: #fff !important;
    border-radius: 100px !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-weight: 700 !important;
    border: none !important;
    transition: transform .3s, box-shadow .3s !important;
    box-shadow: 0 10px 40px var(--accent-glow) !important;
}
.elementor-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 16px 50px var(--accent-glow) !important;
    background-color: var(--accent) !important;
    color: #fff !important;
}

/* Elementor icons */
.elementor-icon {
    color: var(--accent) !important;
}

/* Elementor dividers */
.elementor-divider-separator {
    border-color: var(--border) !important;
}

/* Elementor image boxes / icon boxes */
.elementor-widget-icon-box .elementor-icon-box-title {
    color: var(--text-main) !important;
}
.elementor-widget-icon-box .elementor-icon-box-description {
    color: var(--text-dim) !important;
}

/* Elementor counters */
.elementor-counter-number-wrapper {
    color: var(--accent) !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
}
.elementor-counter-title {
    color: var(--text-dim) !important;
}

/* Elementor testimonials */
.elementor-testimonial-content {
    color: var(--text-dim) !important;
}
.elementor-testimonial-name {
    color: var(--text-main) !important;
}

/* Elementor accordion / toggles */
.elementor-accordion .elementor-accordion-item {
    background: var(--card-bg) !important;
    border: 1px solid var(--border) !important;
    border-radius: 16px !important;
    margin-bottom: 12px !important;
    overflow: hidden !important;
}
.elementor-accordion .elementor-tab-title {
    color: var(--text-main) !important;
    background: transparent !important;
}
.elementor-accordion .elementor-tab-title.elementor-active {
    color: var(--accent) !important;
}
.elementor-accordion .elementor-tab-content {
    color: var(--text-dim) !important;
    background: transparent !important;
    border-top: 1px solid var(--border) !important;
}

/* Elementor tabs */
.elementor-tab-title {
    color: var(--text-dim) !important;
}
.elementor-tab-title.elementor-active {
    color: var(--accent) !important;
}

/* Elementor forms (if using Elementor Pro forms) */
.elementor-field-textual {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    color: var(--text-main) !important;
}
.elementor-field-textual:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px var(--accent-glow) !important;
}

/* Canvas template — full bleed */
.nl-elementor-canvas {
    background: var(--bg) !important;
    color: var(--text-main) !important;
}

/* Elementor content wrapper — no extra padding on canvas */
#nl-elementor-content {
    min-height: 60vh;
}

/* Remove default Elementor white gaps */
.elementor-section-wrap > .elementor-section,
.elementor-inner > .elementor-section {
    background: transparent;
}


/* =====================================================================
   COURSES CATALOG PAGE
   ===================================================================== */

.nl-courses-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
}

.nl-course-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: border-color .3s, transform .3s;
    display: flex;
    flex-direction: column;
}
.nl-course-card:hover {
    border-color: rgba(79,143,255,.25);
    transform: translateY(-4px);
}

/* Image */
.nl-course-card__image {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: rgba(255,255,255,.03);
}
.nl-course-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.nl-course-card__image--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
}
.nl-course-card__badge {
    position: absolute;
    top: 12px;
    right: 12px;
    background: var(--accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 4px 12px;
    border-radius: 100px;
}

/* Body */
.nl-course-card__body {
    padding: 28px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.nl-course-card__title {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 22px;
    font-weight: 800;
    color: var(--text-main);
    margin-bottom: 10px;
    letter-spacing: -.02em;
}
.nl-course-card__desc {
    color: var(--text-dim);
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 16px;
}
.nl-course-card__features {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.nl-course-card__features li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--text-dim);
    line-height: 1.5;
}

/* Footer */
.nl-course-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-top: 20px;
    border-top: 1px solid var(--border);
}
.nl-course-card__price {
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.nl-course-card__price-sale {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px;
    font-weight: 800;
    color: var(--accent);
}
.nl-course-card__price-regular {
    font-size: 14px;
    color: var(--text-dim);
    text-decoration: line-through;
    opacity: .5;
}

@media (max-width: 600px) {
    .nl-courses-grid {
        grid-template-columns: 1fr;
    }
}


/* =====================================================================
   NEXT-LEVEL UPGRADES
   ===================================================================== */

/* ── SKIP TO CONTENT (accessibility) ──────────────────────────────── */
.nl-skip-link {
    position: absolute; top: -100px; left: 16px;
    background: var(--accent); color: #fff;
    padding: 12px 24px; border-radius: 0 0 12px 12px;
    font-weight: 700; font-size: 14px; z-index: 100000;
    transition: top .3s;
}
.nl-skip-link:focus { top: 0; }

/* ── ANNOUNCEMENT BAR ─────────────────────────────────────────────── */
.nl-announce {
    position: relative; z-index: 9998;
    text-align: center; padding: 10px 48px 10px 20px;
    font-size: 14px; font-weight: 600; color: #fff;
}
.nl-announce__inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: center; gap: 12px; }
.nl-announce__text { color: #fff !important; text-decoration: none; }
.nl-announce__close {
    position: absolute; right: 16px; top: 50%; transform: translateY(-50%);
    background: none; border: none; color: rgba(255,255,255,.7);
    font-size: 16px; cursor: pointer; padding: 4px;
}
.nl-announce__close:hover { color: #fff; }
.nl-announce + .nl-nav { top: 0; } /* nav sits below */

/* ── COUNTDOWN TIMER ──────────────────────────────────────────────── */
.nl-countdown {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 9990;
    background: rgba(12,18,32,.97); backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid var(--border);
    padding: 14px 24px;
    display: flex; align-items: center; justify-content: center; gap: 20px;
}
.nl-countdown__label { color: var(--text-dim); font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.nl-countdown__boxes { display: flex; gap: 10px; }
.nl-countdown__box {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 10px; padding: 8px 14px; text-align: center; min-width: 56px;
}
.nl-countdown__box span {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 22px; font-weight: 800; color: var(--accent); display: block;
}
.nl-countdown__box small { font-size: 10px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .08em; }

@media (max-width: 600px) {
    .nl-countdown { flex-direction: column; gap: 8px; padding: 12px 16px; }
    .nl-countdown__box { padding: 6px 10px; min-width: 48px; }
    .nl-countdown__box span { font-size: 18px; }
}

/* ── EMAIL CAPTURE POPUP ──────────────────────────────────────────── */
.nl-email-popup { position: fixed; inset: 0; z-index: 100001; display: flex; align-items: center; justify-content: center; }
.nl-email-popup__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(4px); }
.nl-email-popup__card {
    position: relative; z-index: 1;
    background: var(--bg); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 48px 40px;
    max-width: 440px; width: 90%; text-align: center;
    animation: nlPopIn .4s cubic-bezier(.22,1,.36,1);
}
@keyframes nlPopIn { from { opacity: 0; transform: scale(.9) translateY(20px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.nl-email-popup__x {
    position: absolute; top: 16px; right: 16px;
    background: none; border: none; color: var(--text-dim);
    font-size: 20px; cursor: pointer; padding: 4px;
}
.nl-email-popup__icon { font-size: 48px; margin-bottom: 16px; }
.nl-email-popup__card h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 26px; font-weight: 800; margin-bottom: 12px; color: var(--text-main);
}
.nl-email-popup__card p { color: var(--text-dim); font-size: 15px; line-height: 1.6; margin-bottom: 24px; }
.nl-email-popup__form { display: flex; flex-direction: column; gap: 12px; }
.nl-email-popup__note { display: block; margin-top: 12px; font-size: 12px; color: var(--text-dim); opacity: .6; }

@media (max-width: 480px) {
    .nl-email-popup__card { padding: 36px 24px; }
}

/* ── SOCIAL PROOF NOTIFICATION ────────────────────────────────────── */
.nl-proof {
    position: fixed; bottom: 24px; left: 24px; z-index: 9980;
    animation: nlSlideUp .5s cubic-bezier(.22,1,.36,1);
}
@keyframes nlSlideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.nl-proof__inner {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 16px; padding: 14px 20px;
    display: flex; align-items: center; gap: 12px;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 12px 40px rgba(0,0,0,.3);
    max-width: 320px;
}
.nl-proof__icon { font-size: 28px; flex-shrink: 0; }
.nl-proof__text { font-size: 13px; color: var(--text-dim); line-height: 1.4; }
.nl-proof__text strong { color: var(--text-main); }

@media (max-width: 600px) {
    .nl-proof { left: 12px; right: 12px; bottom: 80px; }
    .nl-proof__inner { max-width: 100%; }
}

/* ── SMOOTH PAGE TRANSITIONS ──────────────────────────────────────── */
.nl-page-fade { animation: nlFadeIn .4s ease-out; }
@keyframes nlFadeIn { from { opacity: 0; } to { opacity: 1; } }

/* ── PARALLAX GLOW ENHANCEMENT ────────────────────────────────────── */
.glow {
    transition: transform .3s ease-out;
}
.nl-hero { overflow: hidden; }

/* ── KEYBOARD FOCUS STYLES ────────────────────────────────────────── */
*:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
    border-radius: 4px;
}
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
    outline: none;
}


/* =====================================================================
   ANNOUNCEMENT BAR
   ===================================================================== */
.nl-announce {
    position: fixed; top: 0; left: 0; right: 0; z-index: 10000;
    padding: 10px 24px; text-align: center;
    font-size: 13px; font-weight: 600; color: #fff;
    letter-spacing: .02em;
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.nl-announce a { color: #fff; text-decoration: underline; }
.nl-announce__close {
    position: absolute; right: 16px; top: 50%; transform: translateY(-50%);
    background: none; border: none; color: rgba(255,255,255,.7); font-size: 18px;
    cursor: pointer; padding: 4px 8px; line-height: 1;
}
.nl-announce__close:hover { color: #fff; }
body.has-announce .nl-nav { top: 38px; }
body.has-announce .nl-scroll-progress { top: 38px; }
body.has-announce .nl-hero { padding-top: calc(var(--nav-h, 80px) + 38px); }


/* =====================================================================
   COUNTDOWN TIMER
   ===================================================================== */
.nl-countdown {
    text-align: center; padding: 20px 0 10px;
}
.nl-countdown__label {
    display: block; font-size: 13px; font-weight: 600; color: var(--accent);
    text-transform: uppercase; letter-spacing: .1em; margin-bottom: 12px;
}
.nl-countdown__boxes {
    display: flex; justify-content: center; gap: 12px;
}
.nl-countdown__box {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 12px 16px; min-width: 64px; text-align: center;
}
.nl-countdown__box span {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 28px; font-weight: 800; color: var(--text-main); display: block;
    line-height: 1;
}
.nl-countdown__box small {
    font-size: 10px; color: var(--text-dim); text-transform: uppercase;
    letter-spacing: .08em; margin-top: 4px; display: block;
}
.nl-countdown__expired {
    color: var(--text-dim); font-size: 14px; font-style: italic;
}


/* =====================================================================
   PAGE TRANSITIONS
   ===================================================================== */
.nl-page-fade {
    animation: nlFadeIn .4s ease-out;
}
@keyframes nlFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}


/* =====================================================================
   SKIP TO CONTENT
   ===================================================================== */
.nl-skip-link {
    position: fixed; top: -100px; left: 16px; z-index: 99999;
    background: var(--accent); color: #fff;
    padding: 10px 20px; border-radius: 100px;
    font-weight: 700; font-size: 14px; text-decoration: none;
    transition: top .3s;
}
.nl-skip-link:focus {
    top: 16px; outline: 3px solid #fff; outline-offset: 2px;
}


/* =====================================================================
   SOCIAL PROOF NOTIFICATION
   ===================================================================== */
.nl-proof {
    position: fixed; bottom: 24px; left: 24px; z-index: 9998;
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 16px; padding: 16px 20px;
    display: flex; align-items: center; gap: 12px;
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 20px 50px rgba(0,0,0,.4);
    max-width: 340px;
}
.nl-proof__avatar {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--accent-glow); color: var(--accent);
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; font-weight: 800; flex-shrink: 0;
}
.nl-proof__text { font-size: 13px; color: var(--text-dim); line-height: 1.4; }
.nl-proof__text strong { color: var(--text-main); font-weight: 700; }
@keyframes nlSlideUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 480px) {
    .nl-proof { left: 12px; right: 12px; max-width: none; bottom: 80px; }
}


/* =====================================================================
   EMAIL CAPTURE POPUP
   ===================================================================== */
.nl-email-popup {
    position: fixed; inset: 0; z-index: 99999;
    display: flex; align-items: center; justify-content: center;
}
.nl-email-popup__overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.7); backdrop-filter: blur(6px);
    cursor: pointer;
}
.nl-email-popup__card {
    position: relative; z-index: 1;
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 48px 40px;
    max-width: 420px; width: 90%; text-align: center;
    backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
    animation: nlPopIn .4s cubic-bezier(.4,0,.2,1);
}
@keyframes nlPopIn {
    from { opacity: 0; transform: scale(.9) translateY(20px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.nl-email-popup__x {
    position: absolute; top: 16px; right: 16px;
    background: none; border: none; color: var(--text-dim);
    font-size: 20px; cursor: pointer; padding: 4px 8px;
}
.nl-email-popup__x:hover { color: var(--text-main); }
.nl-email-popup__icon { font-size: 48px; margin-bottom: 16px; }
.nl-email-popup__card h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 24px; font-weight: 800; color: var(--text-main);
    margin-bottom: 10px;
}
.nl-email-popup__card p {
    color: var(--text-dim); font-size: 15px; line-height: 1.6;
    margin-bottom: 24px;
}
.nl-email-popup__form {
    display: flex; gap: 10px;
}
.nl-email-popup__form input {
    flex: 1; background: rgba(255,255,255,.04); border: 1px solid var(--border);
    border-radius: 100px; padding: 12px 20px; color: var(--text-main);
    font-size: 14px; font-family: 'Inter', sans-serif;
}
.nl-email-popup__form input:focus {
    border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); outline: none;
}
.nl-email-popup__form button {
    background: var(--accent); color: #fff; border: none;
    border-radius: 100px; padding: 12px 24px; font-weight: 700;
    font-size: 14px; cursor: pointer; white-space: nowrap;
    font-family: 'Inter', sans-serif;
    transition: transform .3s, box-shadow .3s;
}
.nl-email-popup__form button:hover {
    transform: translateY(-2px); box-shadow: 0 10px 30px var(--accent-glow);
}
.nl-email-popup__note {
    display: block; margin-top: 12px; font-size: 11px; color: var(--text-dim); opacity: .5;
}
.nl-email-popup__success {
    color: var(--accent); font-size: 18px; font-weight: 700;
}

@media (max-width: 480px) {
    .nl-email-popup__card { padding: 36px 24px; }
    .nl-email-popup__form { flex-direction: column; }
}


/* =====================================================================
   PARALLAX GLOW (enhanced hero)
   ===================================================================== */
.glow {
    position: absolute; width: 500px; height: 500px;
    border-radius: 50%; pointer-events: none;
    background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
    filter: blur(80px); opacity: .6;
    transition: transform .15s ease-out;
}
body:not(.nl-page-lesson) .nl-hero { position: relative; overflow: hidden; }


/* =====================================================================
   FOCUS VISIBLE — keyboard accessibility
   ===================================================================== */
:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
    border-radius: 4px;
}
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
    outline: none;
}


/* =====================================================================
   FORMATIONS — Expandable detail + Cart summary
   ===================================================================== */
.nl-course-card__click { cursor: pointer; }
a.nl-course-card__link,
div.nl-course-card__link {
    display: block;
    text-decoration: none;
    color: inherit;
}
a.nl-course-card__link:hover { text-decoration: none; }
.nl-course-card__more {
    font-size: 13px; font-weight: 600; color: var(--accent);
    transition: color .25s;
}
.nl-course-card.is-expanded .nl-course-card__more { display: none; }

/* Always-visible CTA below card */
.nl-course-card__cta {
    padding: 0 28px 24px;
}

.nl-course-card__detail {
    max-height: 0; overflow: hidden;
    transition: max-height .45s cubic-bezier(.4,0,.2,1), padding .3s ease;
    padding: 0 28px;
}
.nl-course-card.is-expanded .nl-course-card__detail {
    max-height: 600px; padding: 0 28px 28px;
}
.nl-course-card__detail-section {
    border-top: 1px solid var(--border); padding-top: 20px; margin-bottom: 20px;
}
.nl-course-card__detail-section h4 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 16px; font-weight: 700; color: var(--text-main);
    margin-bottom: 14px;
}

.nl-cart-summary {
    background: var(--card-bg); border: 1px solid rgba(79,143,255,.25);
    border-radius: var(--radius-lg); padding: 24px 32px;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}


/* =====================================================================
   NO PAYMENT METHODS — styled notice
   ===================================================================== */
.woocommerce-checkout .woocommerce-notice--warning,
.woocommerce-checkout .woocommerce-NoticeGroup-checkout .woocommerce-error,
.woocommerce-checkout .wc-block-components-notice-banner {
    background: rgba(251,191,36,.06) !important;
    border: 1px solid rgba(251,191,36,.25) !important;
    border-radius: 12px !important;
    color: #fcd34d !important;
    padding: 20px 24px !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
}

/* ── Clear cart link ───────────────────────────────────────────────── */
.nl-clear-cart {
    display: inline-block;
    font-size: 13px;
    color: #ef4444;
    text-decoration: underline;
    cursor: pointer;
    margin-top: 12px;
    opacity: .7;
    transition: opacity .25s;
}
.nl-clear-cart:hover { opacity: 1; color: #ef4444; }


/* =====================================================================
   WOOCOMMERCE BLOCKS — Dark Theme Override
   Covers block-based Cart + Checkout (WC 8.3+)
   ===================================================================== */

/* ── Global block overrides ───────────────────────────────────────── */
.wc-block-cart,
.wc-block-checkout,
.wp-block-woocommerce-cart,
.wp-block-woocommerce-checkout {
    --wc-block-components-form-border-color: rgba(148,163,184,0.12) !important;
    --wc-block-components-form-text-color: #f1f5f9 !important;
    --wc-block-components-form-placeholder-color: #64748b !important;
    color: #f1f5f9 !important;
}

/* Background */
.wc-block-cart .wc-block-components-main,
.wc-block-checkout .wc-block-components-main,
.wc-block-cart .wc-block-components-sidebar,
.wc-block-checkout .wc-block-components-sidebar,
.wc-block-cart__main,
.wc-block-checkout__main,
.wc-block-cart__sidebar,
.wc-block-checkout__sidebar {
    background: transparent !important;
}

/* ── Text colors ──────────────────────────────────────────────────── */
.wc-block-cart h2,
.wc-block-checkout h2,
.wc-block-cart .wc-block-components-product-name,
.wc-block-checkout .wc-block-components-product-name,
.wc-block-components-order-summary .wc-block-components-product-name,
.wc-block-components-totals-item__label,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    color: #f1f5f9 !important;
}
.wc-block-cart .wc-block-components-product-metadata,
.wc-block-checkout .wc-block-components-product-metadata,
.wc-block-components-totals-item__value,
.wc-block-components-product-price,
.wc-block-cart .wc-block-components-quantity-selector,
.wc-block-checkout p,
.wc-block-checkout label,
.wc-block-cart p {
    color: #94a3b8 !important;
}

/* ── Total price accent ───────────────────────────────────────────── */
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    color: var(--accent, #4f8fff) !important;
    font-size: 28px !important;
    font-weight: 800 !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
}

/* ── Input fields ─────────────────────────────────────────────────── */
.wc-block-components-text-input input,
.wc-block-components-text-input textarea,
.wc-block-components-combobox .components-form-token-field__input,
.wc-block-checkout .wc-block-components-text-input input,
.wc-block-checkout select {
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(148,163,184,0.12) !important;
    border-radius: 12px !important;
    color: #f1f5f9 !important;
    padding: 12px 16px !important;
}
.wc-block-components-text-input input:focus,
.wc-block-checkout .wc-block-components-text-input input:focus {
    border-color: var(--accent, #4f8fff) !important;
    box-shadow: 0 0 0 3px rgba(79,143,255,0.15) !important;
}
.wc-block-components-text-input label,
.wc-block-checkout label {
    color: #94a3b8 !important;
}

/* ── Buttons ──────────────────────────────────────────────────────── */
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wc-block-cart .wc-block-components-button,
.wc-block-checkout .wc-block-components-button {
    background: var(--accent, #4f8fff) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 100px !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    padding: 16px 32px !important;
    transition: transform .3s, box-shadow .3s !important;
    box-shadow: 0 8px 30px rgba(79,143,255,0.15) !important;
}
.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover,
.wc-block-cart .wc-block-components-button:hover,
.wc-block-checkout .wc-block-components-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 40px rgba(79,143,255,0.25) !important;
    background: var(--accent, #4f8fff) !important;
}

/* ── Cart table / product rows ────────────────────────────────────── */
.wc-block-cart-items,
.wc-block-cart-items__row {
    border-color: rgba(148,163,184,0.08) !important;
}
.wc-block-cart-items .wc-block-components-product-name a {
    color: #f1f5f9 !important;
    font-weight: 600 !important;
}
.wc-block-cart-item__image img {
    border-radius: 12px !important;
}

/* ── Remove/quantity ──────────────────────────────────────────────── */
.wc-block-cart-item__remove-link {
    color: #ef4444 !important;
}
.wc-block-components-quantity-selector {
    border-color: rgba(148,163,184,0.12) !important;
}
.wc-block-components-quantity-selector input {
    color: #f1f5f9 !important;
    background: transparent !important;
}
.wc-block-components-quantity-selector button {
    color: #94a3b8 !important;
}

/* ── Order summary / sidebar ──────────────────────────────────────── */
.wc-block-components-order-summary,
.wc-block-components-totals-wrapper {
    border-color: rgba(148,163,184,0.08) !important;
}

/* ── Payment methods ──────────────────────────────────────────────── */
.wc-block-components-radio-control__option,
.wc-block-checkout__payment-method {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(148,163,184,0.08) !important;
    border-radius: 12px !important;
    margin-bottom: 8px !important;
    color: #f1f5f9 !important;
}
.wc-block-components-radio-control__label {
    color: #f1f5f9 !important;
}
.wc-block-components-radio-control__description {
    color: #94a3b8 !important;
}

/* ── Notices ──────────────────────────────────────────────────────── */
.wc-block-components-notice-banner {
    border-radius: 12px !important;
}
.wc-block-components-notice-banner.is-error {
    background: rgba(239,68,68,0.08) !important;
    border-color: rgba(239,68,68,0.25) !important;
    color: #fca5a5 !important;
}
.wc-block-components-notice-banner.is-success {
    background: rgba(79,143,255,0.08) !important;
    border-color: rgba(79,143,255,0.25) !important;
    color: #93c5fd !important;
}
.wc-block-components-notice-banner.is-info {
    background: rgba(79,143,255,0.08) !important;
    border-color: rgba(79,143,255,0.25) !important;
    color: #93c5fd !important;
}

/* ── Checkboxes & links ───────────────────────────────────────────── */
.wc-block-checkout a {
    color: var(--accent, #4f8fff) !important;
}
.wc-block-components-checkbox .wc-block-components-checkbox__label {
    color: #94a3b8 !important;
}

/* ── Privacy text ─────────────────────────────────────────────────── */
.wc-block-checkout__terms,
.wc-block-checkout__privacy-policy {
    color: #64748b !important;
    font-size: 12px !important;
}

/* ── Narrow layout ────────────────────────────────────────────────── */
.wc-block-checkout.is-large {
    max-width: 680px !important;
    margin: 0 auto !important;
}
.wc-block-cart {
    max-width: 720px !important;
    margin: 0 auto !important;
}

/* ── Newsletter hide (block checkout version) ─────────────────────── */
.wc-block-checkout__newsletter,
.wc-block-components-checkbox:has(input[id*="newsletter"]),
.wc-block-components-checkbox:has(input[id*="subscribe"]),
.mailpoet_checkout_optin {
    display: none !important;
}


/* =====================================================================
   MY ACCOUNT — Dark Theme
   ===================================================================== */
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
    color: #f1f5f9;
}

/* Sidebar navigation */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation li {
    margin-bottom: 4px;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
    display: block;
    padding: 12px 20px;
    border-radius: 12px;
    color: var(--text-dim) !important;
    font-weight: 500;
    font-size: 14px;
    transition: all .25s;
    text-decoration: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
    background: rgba(255,255,255,.04);
    color: var(--text-main) !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--dashboard.is-active a {
    background: rgba(79,143,255,.08);
    color: var(--accent) !important;
    font-weight: 700;
}

/* Content area */
.woocommerce-account .woocommerce-MyAccount-content {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 32px;
    backdrop-filter: blur(12px);
}
.woocommerce-account .woocommerce-MyAccount-content p {
    color: var(--text-dim);
    line-height: 1.7;
}
.woocommerce-account .woocommerce-MyAccount-content a {
    color: var(--accent) !important;
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
    color: var(--text-main);
    font-family: 'Bricolage Grotesque', sans-serif;
}

/* Tables in account */
.woocommerce-account table.woocommerce-orders-table,
.woocommerce-account table.woocommerce-table--order-details,
.woocommerce-account table {
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    overflow: hidden;
    width: 100%;
    background: transparent !important;
}
.woocommerce-account table th {
    background: rgba(255,255,255,.03) !important;
    color: var(--text-dim) !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--border) !important;
}
.woocommerce-account table td {
    padding: 14px 16px !important;
    color: var(--text-main) !important;
    border-bottom: 1px solid var(--border) !important;
    background: transparent !important;
}
.woocommerce-account table td a {
    color: var(--accent) !important;
}

/* Buttons */
.woocommerce-account .woocommerce-Button,
.woocommerce-account .button,
.woocommerce-account input[type="submit"] {
    background: var(--accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 100px !important;
    font-weight: 700 !important;
    padding: 12px 28px !important;
    cursor: pointer !important;
    transition: transform .25s, box-shadow .25s !important;
}
.woocommerce-account .woocommerce-Button:hover,
.woocommerce-account .button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(79,143,255,.2) !important;
}

/* Form fields in account */
.woocommerce-account .woocommerce-form-row input,
.woocommerce-account .woocommerce-form-row select,
.woocommerce-account fieldset input,
.woocommerce-account .form-row input {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    color: var(--text-main) !important;
    padding: 12px 16px !important;
    width: 100% !important;
}
.woocommerce-account .woocommerce-form-row input:focus,
.woocommerce-account .form-row input:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(79,143,255,.15) !important;
    outline: none !important;
}
.woocommerce-account .woocommerce-form-row label,
.woocommerce-account .form-row label {
    color: var(--text-dim) !important;
    font-size: 13px !important;
    margin-bottom: 6px !important;
    display: block !important;
}

/* Addresses */
.woocommerce-account .woocommerce-Addresses .woocommerce-Address {
    background: rgba(255,255,255,.02);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 20px;
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address address {
    color: var(--text-dim);
    font-style: normal;
}

/* Notices */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info {
    background: rgba(79,143,255,.06) !important;
    border: 1px solid rgba(79,143,255,.2) !important;
    border-radius: 12px !important;
    color: var(--text-main) !important;
    padding: 16px 20px !important;
}
.woocommerce-account .woocommerce-error {
    background: rgba(239,68,68,.06) !important;
    border: 1px solid rgba(239,68,68,.2) !important;
    border-radius: 12px !important;
    color: #fca5a5 !important;
    padding: 16px 20px !important;
}

/* Layout — side by side on desktop */
@media (min-width: 769px) {
    .woocommerce-account .woocommerce {
        display: grid;
        grid-template-columns: 220px 1fr;
        gap: 32px;
        max-width: 900px;
        margin: 0 auto;
    }
}
@media (max-width: 768px) {
    .woocommerce-account .woocommerce-MyAccount-navigation {
        margin-bottom: 24px;
    }
    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        display: flex;
        gap: 8px;
        overflow-x: auto;
        padding-bottom: 8px;
    }
    .woocommerce-account .woocommerce-MyAccount-navigation li a {
        white-space: nowrap;
        padding: 10px 16px;
        font-size: 13px;
    }
    .woocommerce-account .woocommerce-MyAccount-content {
        padding: 24px 20px;
    }
}

/* WC Block-based Account pages */
.wc-block-order-confirmation-summary,
.wc-block-order-confirmation-totals,
.wc-block-order-confirmation-downloads {
    color: #f1f5f9 !important;
}


/* =====================================================================
   KILL ALL ANIMATIONS ON WC PAGES — prevents checkout stutter
   ===================================================================== */
.woocommerce-cart,
.woocommerce-checkout,
.woocommerce-account,
.nl-wc-page {
    animation: none !important;
}
.woocommerce-cart *,
.woocommerce-checkout *,
.woocommerce-account *,
.nl-wc-page * {
    animation-duration: 0s !important;
    transition-duration: 0s !important;
}
/* Re-enable transitions on interactive elements only */
.nl-wc-page .btn-mag,
.nl-wc-page a,
.nl-wc-page button,
.nl-wc-page input,
.nl-wc-page select,
.nl-wc-page textarea {
    transition-duration: 0.25s !important;
}
/* Hide scroll progress + glow on WC pages */
.nl-wc-page .nl-scroll-progress,
.nl-wc-page .glow,
.nl-wc-page .nl-preloader,
.nl-wc-page .nl-exit-popup {
    display: none !important;
}


/* =====================================================================
   TUTOR LMS — NextLearns Dark Theme Override
   Matches the navy (#0c1220) + blue accent (#4f8fff) design system.
   ===================================================================== */

/* ── Global Tutor overrides ───────────────────────────────────────── */
.tutor-wrap,
.tutor-page-wrap,
.tutor-course-loop-wrap,
.tutor-single-course-content,
.tutor-dashboard,
.tutor-course-content-wrap {
    background: transparent !important;
    color: #e2e8f0 !important;
}
.tutor-wrap a { color: #4f8fff; }
.tutor-wrap a:hover { color: #7db3ff; }

/* ── Course Archive / Grid ────────────────────────────────────────── */
.tutor-course-card,
.tutor-card {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.06) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    transition: transform .3s, box-shadow .3s !important;
}
.tutor-course-card:hover,
.tutor-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 20px 50px rgba(0,0,0,.3) !important;
    border-color: rgba(79,143,255,.15) !important;
}
.tutor-course-card .tutor-card-body,
.tutor-card .tutor-card-body {
    padding: 20px !important;
}
.tutor-course-name,
.tutor-course-card .tutor-course-name a,
.tutor-card h3 a,
.tutor-card-body h3 a {
    color: #f1f5f9 !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-weight: 700 !important;
    font-size: 18px !important;
}
.tutor-course-card .tutor-course-name a:hover { color: #4f8fff !important; }
.tutor-card-body p,
.tutor-course-card p { color: #94a3b8 !important; }
.tutor-course-card .tutor-card-footer,
.tutor-card .tutor-card-footer {
    border-top: 1px solid rgba(255,255,255,.04) !important;
    padding: 14px 20px !important;
}

/* Course thumbnail */
.tutor-course-card .tutor-course-thumbnail img,
.tutor-card img { border-radius: 0 !important; }

/* Price */
.tutor-course-price,
.tutor-course-card .tutor-course-price .tutor-fs-4 {
    color: #4f8fff !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-weight: 800 !important;
}

/* ── Single Course Page ───────────────────────────────────────────── */
.tutor-single-course-segment,
.tutor-course-details-page .tutor-course-details-content {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 16px !important;
    padding: 28px !important;
    margin-bottom: 24px !important;
}
.tutor-single-course-segment h2,
.tutor-single-course-segment h3,
.tutor-course-details-content h2 {
    color: #fff !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
}

/* Course sidebar */
.tutor-single-course-sidebar,
.tutor-course-sidebar {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.06) !important;
    border-radius: 16px !important;
    padding: 24px !important;
}

/* ── Enroll / Add to Cart button ──────────────────────────────────── */
.tutor-btn-primary,
.tutor-enroll-btn,
.tutor-btn.tutor-btn-primary,
.tutor-course-purchase-btn,
.tutor-card .tutor-btn-primary,
button.tutor-btn-primary {
    background: #4f8fff !important;
    color: #fff !important;
    border: none !important;
    border-radius: 100px !important;
    font-weight: 700 !important;
    padding: 14px 32px !important;
    font-size: 15px !important;
    transition: transform .2s, box-shadow .2s !important;
    font-family: 'Inter', sans-serif !important;
}
.tutor-btn-primary:hover,
.tutor-enroll-btn:hover,
button.tutor-btn-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 30px rgba(79,143,255,.25) !important;
    background: #4f8fff !important;
    color: #fff !important;
}
.tutor-btn-outline-primary {
    border: 2px solid #4f8fff !important;
    color: #4f8fff !important;
    background: transparent !important;
    border-radius: 100px !important;
    font-weight: 700 !important;
    padding: 12px 28px !important;
}
.tutor-btn-outline-primary:hover {
    background: rgba(79,143,255,.1) !important;
}

/* ── Curriculum / Lessons list ────────────────────────────────────── */
.tutor-accordion,
.tutor-course-topics-wrap {
    background: transparent !important;
}
.tutor-accordion-item,
.tutor-topics-in-single-lesson {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 12px !important;
    margin-bottom: 8px !important;
    overflow: hidden !important;
}
.tutor-accordion-item-header,
.tutor-course-topic-title {
    background: rgba(255,255,255,.02) !important;
    color: #f1f5f9 !important;
    padding: 16px 20px !important;
    font-weight: 600 !important;
    border-bottom: 1px solid rgba(255,255,255,.03) !important;
}
.tutor-accordion-item-body-content,
.tutor-course-lesson {
    padding: 0 !important;
}
.tutor-course-lesson a,
.tutor-lessons-under-topic a {
    display: flex !important;
    align-items: center !important;
    padding: 14px 20px !important;
    color: #94a3b8 !important;
    border-bottom: 1px solid rgba(255,255,255,.02) !important;
    transition: background .2s !important;
}
.tutor-course-lesson a:hover,
.tutor-lessons-under-topic a:hover {
    background: rgba(79,143,255,.05) !important;
    color: #f1f5f9 !important;
    text-decoration: none !important;
}
.tutor-course-lesson .tutor-lesson-icon { color: #4f8fff !important; margin-right: 12px; }

/* ── Lesson Player / Content ──────────────────────────────────────── */
.tutor-lesson-content-area,
.tutor-single-lesson-wrap {
    background: #0c1220 !important;
    color: #e2e8f0 !important;
}
.tutor-lesson-sidebar,
.tutor-sidebar-tabs-wrap {
    background: rgba(15,26,46,.95) !important;
    border-right: 1px solid rgba(255,255,255,.04) !important;
}
.tutor-lesson-sidebar .tutor-sidebar-tabs-content a {
    color: #94a3b8 !important;
    padding: 12px 16px !important;
    border-bottom: 1px solid rgba(255,255,255,.03) !important;
}
.tutor-lesson-sidebar .tutor-sidebar-tabs-content a:hover,
.tutor-lesson-sidebar .tutor-sidebar-tabs-content a.active {
    background: rgba(79,143,255,.08) !important;
    color: #4f8fff !important;
}

/* Video player wrapper */
.tutor-video-player-wrap,
.tutor-lesson-video-wrap {
    border-radius: 12px !important;
    overflow: hidden !important;
    margin-bottom: 24px !important;
}

/* ── Student Dashboard ────────────────────────────────────────────── */
.tutor-dashboard-page-wrap,
.tutor-dashboard-content {
    background: transparent !important;
    color: #e2e8f0 !important;
}
.tutor-dashboard-header {
    background: rgba(255,255,255,.02) !important;
    border-bottom: 1px solid rgba(255,255,255,.04) !important;
}
.tutor-dashboard-menu-item a {
    color: #94a3b8 !important;
    transition: color .2s !important;
}
.tutor-dashboard-menu-item a:hover,
.tutor-dashboard-menu-item.active a {
    color: #4f8fff !important;
}

/* Dashboard cards */
.tutor-dashboard .tutor-card {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 16px !important;
}

/* ── Progress Bar ─────────────────────────────────────────────────── */
.tutor-progress-bar {
    background: rgba(255,255,255,.06) !important;
    border-radius: 100px !important;
    height: 8px !important;
    overflow: hidden !important;
}
.tutor-progress-value,
.tutor-progress-bar .tutor-progress-filled {
    background: #4f8fff !important;
    border-radius: 100px !important;
}

/* ── Ratings / Reviews ────────────────────────────────────────────── */
.tutor-ratings .tutor-ratings-stars { color: #f59e0b !important; }
.tutor-review-comment {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.04) !important;
    border-radius: 12px !important;
    padding: 20px !important;
    margin-bottom: 12px !important;
}
.tutor-review-comment p { color: #94a3b8 !important; }
.tutor-review-comment .tutor-reviewer-name { color: #f1f5f9 !important; font-weight: 700 !important; }

/* ── Quizzes ──────────────────────────────────────────────────────── */
.tutor-quiz-wrap {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 16px !important;
    padding: 28px !important;
}
.tutor-quiz-wrap h3 { color: #fff !important; }
.tutor-quiz-question-desc { color: #94a3b8 !important; }
.tutor-quiz-answer-item {
    background: rgba(255,255,255,.03) !important;
    border: 1px solid rgba(255,255,255,.06) !important;
    border-radius: 12px !important;
    padding: 14px 18px !important;
    margin-bottom: 8px !important;
    color: #e2e8f0 !important;
    transition: border-color .2s !important;
}
.tutor-quiz-answer-item:hover,
.tutor-quiz-answer-item.selected {
    border-color: rgba(79,143,255,.3) !important;
    background: rgba(79,143,255,.05) !important;
}

/* ── Forms (Tutor) ────────────────────────────────────────────────── */
.tutor-form-control,
.tutor-wrap input[type="text"],
.tutor-wrap input[type="email"],
.tutor-wrap input[type="password"],
.tutor-wrap textarea,
.tutor-wrap select {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 12px !important;
    color: #f1f5f9 !important;
    padding: 12px 16px !important;
    font-family: 'Inter', sans-serif !important;
}
.tutor-form-control:focus,
.tutor-wrap input:focus {
    border-color: #4f8fff !important;
    box-shadow: 0 0 0 3px rgba(79,143,255,.12) !important;
    outline: none !important;
}
.tutor-wrap label { color: #94a3b8 !important; }

/* ── Notices / Alerts ─────────────────────────────────────────────── */
.tutor-alert-primary {
    background: rgba(79,143,255,.06) !important;
    border: 1px solid rgba(79,143,255,.15) !important;
    color: #93c5fd !important;
    border-radius: 12px !important;
}
.tutor-alert-success {
    background: rgba(34,197,94,.06) !important;
    border: 1px solid rgba(34,197,94,.15) !important;
    color: #86efac !important;
    border-radius: 12px !important;
}
.tutor-alert-warning {
    background: rgba(245,158,11,.06) !important;
    border: 1px solid rgba(245,158,11,.15) !important;
    color: #fcd34d !important;
    border-radius: 12px !important;
}
.tutor-alert-danger {
    background: rgba(239,68,68,.06) !important;
    border: 1px solid rgba(239,68,68,.15) !important;
    color: #fca5a5 !important;
    border-radius: 12px !important;
}

/* ── Badges / Tags ────────────────────────────────────────────────── */
.tutor-badge {
    border-radius: 100px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 4px 12px !important;
}
.tutor-badge-primary {
    background: rgba(79,143,255,.12) !important;
    color: #4f8fff !important;
}
.tutor-badge-success {
    background: rgba(34,197,94,.12) !important;
    color: #22c55e !important;
}

/* ── Pagination ───────────────────────────────────────────────────── */
.tutor-pagination .page-numbers {
    background: rgba(255,255,255,.03) !important;
    border: 1px solid rgba(255,255,255,.06) !important;
    color: #94a3b8 !important;
    border-radius: 8px !important;
    padding: 8px 14px !important;
}
.tutor-pagination .page-numbers.current {
    background: #4f8fff !important;
    color: #fff !important;
    border-color: #4f8fff !important;
}

/* ── Certificate ──────────────────────────────────────────────────── */
.tutor-certificate-wrap {
    background: rgba(255,255,255,.02) !important;
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 16px !important;
    padding: 32px !important;
}

/* ── Typography overrides ─────────────────────────────────────────── */
.tutor-fs-2, .tutor-fs-3, .tutor-fs-4,
.tutor-wrap h1, .tutor-wrap h2, .tutor-wrap h3, .tutor-wrap h4 {
    color: #fff !important;
    font-family: 'Bricolage Grotesque', sans-serif !important;
}
.tutor-wrap p, .tutor-fs-6, .tutor-fs-7 { color: #94a3b8 !important; }
.tutor-color-secondary { color: #64748b !important; }
.tutor-color-primary { color: #4f8fff !important; }

/* ── Table overrides ──────────────────────────────────────────────── */
.tutor-wrap table {
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}
.tutor-wrap table th {
    background: rgba(255,255,255,.03) !important;
    color: #94a3b8 !important;
    border-bottom: 1px solid rgba(255,255,255,.05) !important;
}
.tutor-wrap table td {
    color: #e2e8f0 !important;
    border-bottom: 1px solid rgba(255,255,255,.03) !important;
}

/* ── Icon colors ──────────────────────────────────────────────────── */
.tutor-icon-24 { color: #94a3b8 !important; }
.tutor-wrap .tutor-icon-lock { color: #64748b !important; }
.tutor-wrap .tutor-icon-check { color: #22c55e !important; }


/* =====================================================================
   2026 STRUCTURE + HOMEPAGE FIXES
   ===================================================================== */
.nl-nav__links a.is-active,
.nl-mobile-drawer a.is-active {
    color: var(--text-main);
}

.nl-hero {
    max-width: 980px;
    margin: 0 auto;
    padding: 184px 24px 88px;
}

.nl-hero__actions {
    display: flex;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 8px;
}

.nl-hero__proof {
    margin-top: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 10px 22px;
    font-size: 13px;
    color: var(--text-dim);
    flex-wrap: wrap;
}

.nl-section {
    position: relative;
    padding: 88px 24px;
}

.nl-section--first {
    padding-top: 32px;
}

.nl-section-grid {
    margin-top: 40px;
}

.nl-section-cta {
    text-align: center;
    margin-top: 36px;
}

.bento-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: minmax(280px, auto);
    align-items: stretch;
}

.bento-card {
    min-height: 280px;
    justify-content: flex-start;
    gap: 16px;
}

.bento-icon {
    font-size: 34px;
    line-height: 1;
}

.bento-card h3 {
    font-size: clamp(26px, 3vw, 32px);
    margin-bottom: 0;
}

.bento-card p {
    font-size: 15px;
    max-width: 42ch;
}

.nl-steps-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.nl-step-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 28px 28px 30px;
    position: relative;
    overflow: visible;
}

.nl-step-card__index {
    position: static;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    padding: 0 14px;
    margin-bottom: 18px;
    background: rgba(79,143,255,.12);
    border: 1px solid rgba(79,143,255,.22);
    color: #ddebff;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    border-radius: 999px;
}

.nl-step-card__icon {
    font-size: 36px;
    margin-bottom: 16px;
}

.nl-step-card__title {
    font-size: 18px;
    font-weight: 800;
    color: var(--text-main);
    margin-bottom: 8px;
}

.nl-step-card__desc {
    color: var(--text-dim);
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

.nl-course-card__link {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    color: inherit;
}

.nl-course-card__more {
    color: var(--text-main);
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
}

@media (max-width: 1024px) {
    .nl-hero {
        padding-top: 168px;
    }

    .bento-grid,
    .nl-steps-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 767px) {
    .nl-hero {
        padding: 148px 20px 64px;
    }

    .nl-hero p {
        font-size: 17px;
        margin-bottom: 28px;
    }

    .nl-hero__proof {
        width: 100%;
        border-radius: 20px;
        padding: 12px 16px;
    }

    .nl-section,
    .nl-section--first {
        padding: 64px 20px;
    }

    .bento-grid,
    .nl-steps-grid,
    .nl-courses-grid,
    .t-grid {
        grid-template-columns: 1fr;
    }

    .bento-card,
    .nl-step-card,
    .nl-course-card__body,
    .t-card {
        padding-left: 22px;
        padding-right: 22px;
    }
}

/* ===== v8 course architecture refresh ===== */
.nl-course-card__meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 16px;
}
.nl-course-card__meta-row span{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(79,143,255,.08);
  border:1px solid rgba(79,143,255,.16);
  color:var(--text-dim);
  font-size:12px;
  line-height:1;
}
.nl-course-card__features li span{color:var(--accent);font-weight:700;display:inline-block;margin-right:8px;}
.nl-hero--catalog{padding-bottom:72px;}
.nl-section--catalog{padding-top:24px;}
.nl-section--tight{padding-top:56px;padding-bottom:96px;}
.section-heading--left{text-align:left;max-width:none;margin:0 0 18px;}
.nl-course-layout{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(300px,.8fr);
  gap:28px;
  align-items:start;
}
.nl-copy-card,.nl-side-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:24px;
  padding:28px;
  backdrop-filter:blur(12px);
}
.nl-copy-card + .nl-copy-card,.nl-side-card + .nl-side-card{margin-top:20px;}
.nl-copy-card__lead{font-size:18px;line-height:1.7;color:var(--text-main);margin:0 0 16px;}
.nl-copy-card__content,.nl-copy-card__content p{color:var(--text-dim);line-height:1.75;}
.nl-program-list{display:flex;flex-direction:column;gap:14px;margin-top:20px;}
.nl-program-item{display:grid;grid-template-columns:58px minmax(0,1fr);gap:16px;padding:18px;border-radius:18px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);}
.nl-program-item__num{width:58px;height:58px;border-radius:16px;background:rgba(79,143,255,.12);display:flex;align-items:center;justify-content:center;color:var(--accent);font:800 20px/1 'Bricolage Grotesque',sans-serif;}
.nl-program-item h3{margin:0 0 6px;font-size:18px;color:var(--text-main);}
.nl-program-item p{margin:0;color:var(--text-dim);line-height:1.6;}
.nl-check-list{display:flex;flex-direction:column;gap:12px;padding:0;margin:16px 0 0;list-style:none;}
.nl-check-list li{position:relative;padding-left:26px;color:var(--text-main);line-height:1.6;}
.nl-check-list li:before{content:'✓';position:absolute;left:0;top:0;color:var(--accent);font-weight:700;}
.nl-side-card h3{margin:0;color:var(--text-main);font-size:20px;}
.nl-side-card p{color:var(--text-dim);line-height:1.7;}
.nl-side-card--cta{position:sticky;top:110px;}
.nl-side-card__help{display:inline-block;margin-top:14px;color:var(--accent);font-size:14px;}
.nl-course-hero__hook{max-width:760px;margin:0 auto 22px;}
.nl-course-hero__meta{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:0 0 26px;}
.nl-course-hero__meta span{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(79,143,255,.08);border:1px solid rgba(79,143,255,.16);color:var(--text-dim);font-size:13px;}
.nl-course-hero__actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px;}
.nl-course-hero__price{display:flex;align-items:baseline;gap:12px;}
.nl-course-hero__price-current{font:800 clamp(28px,4vw,40px)/1 'Bricolage Grotesque',sans-serif;color:var(--accent);}
.nl-course-hero__price-old{color:var(--text-dim);text-decoration:line-through;font-size:18px;}
@media (max-width: 980px){
  .nl-course-layout{grid-template-columns:1fr;}
  .nl-side-card--cta{position:static;}
}
@media (max-width: 767px){
  .nl-copy-card,.nl-side-card{padding:22px;}
  .nl-program-item{grid-template-columns:48px minmax(0,1fr);padding:16px;}
  .nl-program-item__num{width:48px;height:48px;font-size:18px;}
}

/* =====================================================================
   COURSE DETAIL PAGE — richer flagship layout
   ===================================================================== */
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 22px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);
  color:var(--text-main);font-weight:600;text-decoration:none;
  transition:transform .25s, border-color .25s, background .25s;
}
.btn-ghost:hover{transform:translateY(-2px);border-color:rgba(79,143,255,.35);background:rgba(79,143,255,.08);text-decoration:none;}
.nl-course-hero--rich{padding-bottom:72px;}
.nl-course-hero__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:32px;align-items:center;}
.nl-course-hero__content{text-align:left;}
.nl-course-hero__content .nl-course-hero__hook{margin-left:0;}
.nl-course-hero__content .nl-course-hero__meta,.nl-course-hero__content .nl-course-hero__actions{justify-content:flex-start;}
.nl-proof-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.nl-proof-strip span{display:inline-flex;align-items:center;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:var(--text-dim);font-size:13px;}
.nl-course-showcase-card{background:linear-gradient(180deg,rgba(16,28,52,.92),rgba(12,18,32,.96));border:1px solid rgba(79,143,255,.18);border-radius:28px;padding:28px;box-shadow:0 28px 80px rgba(0,0,0,.35);}
.nl-course-showcase-card__eyebrow{display:inline-block;margin-bottom:12px;color:var(--accent);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;}
.nl-course-showcase-card h2{font:800 clamp(24px,3vw,34px)/1.05 'Bricolage Grotesque',sans-serif;color:#fff;margin:0 0 18px;}
.nl-course-showcase-card__image{display:block;width:100%;margin-top:18px;border-radius:18px;border:1px solid rgba(255,255,255,.08);}
.nl-feature-grid,.nl-deliverables-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.nl-feature-tile,.nl-deliverable-card{padding:20px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);}
.nl-feature-tile p,.nl-deliverable-card strong{margin:0;color:var(--text-main);line-height:1.6;display:block;}
.nl-course-final-cta{padding-top:0;}
.nl-final-cta-card{max-width:980px;margin:0 auto;padding:38px;border-radius:28px;background:linear-gradient(180deg,rgba(19,35,66,.9),rgba(12,18,32,.98));border:1px solid rgba(79,143,255,.14);text-align:center;box-shadow:0 24px 80px rgba(0,0,0,.28);}
.nl-final-cta-card h2{font:800 clamp(30px,4vw,50px)/1.02 'Bricolage Grotesque',sans-serif;color:#fff;margin:12px 0;}
.nl-final-cta-card p{max-width:760px;margin:0 auto 24px;color:var(--text-dim);font-size:17px;line-height:1.75;}
@media (max-width: 980px){
  .nl-course-hero__inner,.nl-feature-grid,.nl-deliverables-grid{grid-template-columns:1fr;}
  .nl-course-hero__content{text-align:center;}
  .nl-course-hero__content .nl-course-hero__meta,.nl-course-hero__content .nl-course-hero__actions,.nl-proof-strip{justify-content:center;}
}


/* ── FAQ refresh (homepage + course pages) ───────────────────────── */
.faq-list{max-width:980px;margin:48px auto 0;display:grid;gap:16px;}
.faq-item{border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.02));border-radius:22px;overflow:hidden;box-shadow:0 14px 36px rgba(2,8,23,.18);transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;}
.faq-item:hover{border-color:rgba(79,143,255,.35);transform:translateY(-2px);box-shadow:0 18px 40px rgba(2,8,23,.24);}
.faq-item:first-child{border-top:1px solid rgba(255,255,255,.08);}
.faq-item summary,.faq-q{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px 26px;cursor:pointer;font:800 18px/1.35 'Bricolage Grotesque',sans-serif;color:var(--text-main);}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after,.faq-q .faq-icon{content:'+';flex:0 0 auto;width:38px;height:38px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(79,143,255,.12);color:var(--accent);font-size:22px;font-weight:700;transition:transform .24s ease,background .24s ease;}
.faq-item[open] summary::after,.faq-item.open .faq-icon{transform:rotate(45deg);background:rgba(79,143,255,.18);}
.faq-item__body,.faq-a{padding:0 26px 24px;color:var(--text-dim);font-size:15px;line-height:1.72;}
.faq-item__body p,.faq-a p{margin:0;}
@media (max-width: 768px){.faq-list{gap:12px;margin-top:32px;}.faq-item summary,.faq-q{padding:18px 18px;font-size:16px;}.faq-item summary::after,.faq-q .faq-icon{width:34px;height:34px;border-radius:10px;font-size:20px;}.faq-item__body,.faq-a{padding:0 18px 18px;font-size:14px;}}



.footer-socials{display:flex;align-items:center;gap:10px;}
.footer-socials__handle{font-size:13px;color:var(--text-dim);font-weight:600;}
/* ===== v9 fixes: course count, card footer, minimalist FAQ ===== */
.nl-courses-grid[data-count="1"]{grid-template-columns:minmax(0,420px);justify-content:center;}
.nl-courses-grid[data-count="2"]{grid-template-columns:repeat(2,minmax(0,420px));justify-content:center;}
@media (max-width: 900px){
  .nl-courses-grid[data-count="2"]{grid-template-columns:1fr;}
}
.nl-course-card{min-height:100%;}
.nl-course-card__body{gap:0;min-height:100%;}
.nl-course-card__desc{margin-bottom:14px;}
.nl-course-card__features{margin-bottom:18px;}
.nl-course-card__footer{margin-top:auto;align-items:flex-end;flex-wrap:wrap;row-gap:10px;}
.nl-course-card__more{margin-left:auto;}
.nl-course-card__price{flex-wrap:wrap;}
.nl-course-card__price-note{font-size:13px;color:var(--text-dim);}
.nl-course-card__cta{padding:0 28px 28px;}
@media (max-width:767px){.nl-course-card__cta{padding:0 22px 22px;}}

.faq-list,
.faq-list--course{max-width:100%;margin:28px auto 0;display:grid;gap:12px;}
.faq-item,
.faq-item--minimal{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.025);
  border-radius:18px;
  overflow:hidden;
  box-shadow:none;
  transition:border-color .22s ease, background .22s ease;
}
.faq-item:hover,
.faq-item--minimal:hover{
  transform:none;
  border-color:rgba(79,143,255,.22);
  background:rgba(255,255,255,.035);
}
.faq-item summary,
.faq-item--minimal summary,
.faq-q{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 22px;
  cursor:pointer;
  font:700 17px/1.45 'Bricolage Grotesque',sans-serif;
  color:var(--text-main);
}
.faq-item summary::-webkit-details-marker,
.faq-item--minimal summary::-webkit-details-marker{display:none;}
.faq-item summary::after,
.faq-item--minimal summary::after,
.faq-q .faq-icon{
  content:'+';
  flex:0 0 auto;
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  color:var(--accent);
  border:1px solid rgba(79,143,255,.18);
  font-size:18px;
  font-weight:600;
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
}
.faq-item[open] summary::after,
.faq-item--minimal[open] summary::after,
.faq-item.open .faq-icon{
  transform:rotate(45deg);
  background:rgba(79,143,255,.08);
  border-color:rgba(79,143,255,.3);
}
.faq-item__body,
.faq-a{
  padding:0 22px 20px;
  color:var(--text-dim);
  font-size:15px;
  line-height:1.72;
}
.faq-item__body p,.faq-a p{margin:0;max-width:72ch;}
@media (max-width:768px){
  .faq-list,.faq-list--course{gap:10px;margin-top:22px;}
  .faq-item summary,.faq-item--minimal summary,.faq-q{padding:16px 16px;font-size:15px;}
  .faq-item summary::after,.faq-item--minimal summary::after,.faq-q .faq-icon{width:26px;height:26px;font-size:17px;}
  .faq-item__body,.faq-a{padding:0 16px 16px;font-size:14px;}
}

/* ── COURSE PROGRAMME TEMPLATE ─────────────────────────────────────── */
.nl-page-programme-course .nl-hero h1 {
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.nl-course-programme-image-wrap {
    margin-top: 28px;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: rgba(255,255,255,0.02);
}

.nl-course-programme-image {
    display: block;
    width: 100%;
    height: auto;
}

.nl-course-programme-price {
    margin-top: 20px;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(42px, 7vw, 72px);
    font-weight: 800;
    line-height: 1;
    color: var(--text);
}

.nl-course-programme-price span {
    font-size: .42em;
    color: var(--accent);
    vertical-align: super;
    margin-left: 6px;
}

.nl-course-programme-help {
    margin-top: 14px;
    color: var(--text-dim);
    font-size: 14px;
}

.nl-course-programme-help a {
    color: inherit;
    text-decoration: none;
}

.nl-page-programme-course .curriculum {
    margin-top: 46px;
}

.nl-page-programme-course .mod-tag {
    min-width: 120px;
}

@media (max-width: 980px) {
    .nl-page-programme-course .mod-row {
        grid-template-columns: 60px 1fr;
        gap: 14px;
    }

    .nl-page-programme-course .mod-tag {
        grid-column: 2;
        text-align: left;
        margin-top: 6px;
    }
}

/* ===== v14 editor/frontend polish ===== */
.nl-course-card{
  position:relative;
  background:linear-gradient(180deg,rgba(13,24,45,.92),rgba(9,16,31,.98));
  border-color:rgba(255,255,255,.07);
  box-shadow:0 22px 60px rgba(3,8,20,.22);
}
.nl-course-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(180deg,rgba(110,168,255,.22),rgba(255,255,255,.02));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:.55;
  pointer-events:none;
}
.nl-course-card:hover{
  transform:translateY(-8px);
  box-shadow:0 28px 80px rgba(6,13,28,.34);
  border-color:rgba(110,168,255,.22);
}
.nl-course-card__image{background:radial-gradient(circle at 50% 20%,rgba(94,151,255,.16),transparent 46%),linear-gradient(180deg,#15243f,#0f1729);}
.nl-course-card__image::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:40%;
  background:linear-gradient(180deg,rgba(0,0,0,0),rgba(7,12,22,.42));
  pointer-events:none;
}
.nl-course-card__image img{transition:transform .5s ease, filter .35s ease;filter:saturate(1.02) contrast(1.02);}
.nl-course-card:hover .nl-course-card__image img{transform:scale(1.04);}
.nl-course-card__badge{top:14px;right:14px;padding:5px 12px;background:linear-gradient(180deg,#68a0ff,#4f8fff);box-shadow:0 10px 18px rgba(79,143,255,.22);}
.nl-course-card__title{font-size:24px;line-height:1.02;margin-bottom:12px;}
.nl-course-card__desc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:4.5em;}
.nl-course-card__meta-row span{background:rgba(79,143,255,.10);border-color:rgba(79,143,255,.18);color:rgba(255,255,255,.78);}
.nl-course-card__features li{color:rgba(255,255,255,.78);}
.nl-course-card__features li span{display:inline-flex;width:20px;height:20px;align-items:center;justify-content:center;border-radius:999px;background:rgba(79,143,255,.14);margin-right:0;flex-shrink:0;}
.nl-course-card__footer{padding-top:18px;border-top-color:rgba(255,255,255,.07);}
.nl-course-card__price-sale{font-size:28px;color:#8cb4ff;}
.nl-course-card__more{display:inline-flex;align-items:center;gap:8px;color:#fff;opacity:.92;}
.nl-course-card__more::after{content:"→";transition:transform .2s ease;}
.nl-course-card:hover .nl-course-card__more::after{transform:translateX(3px);}
.nl-course-card__cta{padding-top:0;}
.nl-course-card__cta .btn-mag{box-shadow:0 14px 24px rgba(79,143,255,.18);}

.nl-page-programme-course .nl-section{position:relative;}
.nl-page-programme-course .section-heading{max-width:900px;}
.nl-page-programme-course .nl-timeline{
  margin-top:42px;
  padding:12px 0;
}
.nl-page-programme-course .nl-timeline::before{left:35px;background:linear-gradient(180deg,rgba(79,143,255,.28),rgba(255,255,255,.08));}
.nl-page-programme-course .nl-timeline__item{
  gap:24px;
  padding:26px 28px 26px 0;
  margin-left:10px;
  border-bottom-color:rgba(255,255,255,.06);
}
.nl-page-programme-course .nl-timeline__item::after{
  content:"";
  position:absolute;
  inset:10px 0 10px 56px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.05);
  z-index:0;
  transition:border-color .25s ease, transform .25s ease, background .25s ease;
}
.nl-page-programme-course .nl-timeline__item > *{position:relative;z-index:1;}
.nl-page-programme-course .nl-timeline__item:hover::after{border-color:rgba(79,143,255,.22);transform:translateX(4px);background:linear-gradient(180deg,rgba(79,143,255,.06),rgba(255,255,255,.02));}
.nl-page-programme-course .nl-timeline__num{width:50px;height:50px;font-size:14px;box-shadow:0 0 0 8px rgba(8,15,28,.9);}
.nl-page-programme-course .nl-timeline__body{padding:4px 26px 4px 0;}
.nl-page-programme-course .nl-timeline__label{margin-bottom:10px;}
.nl-page-programme-course .nl-timeline__title{font-size:26px;line-height:1.06;margin-bottom:8px;}

.nl-page-programme-course .curriculum{
  margin-top:42px;
  background:linear-gradient(180deg,rgba(14,22,40,.95),rgba(9,16,30,.98));
  border:1px solid rgba(255,255,255,.07);
  border-radius:28px;
  box-shadow:0 28px 80px rgba(0,0,0,.22);
}
.nl-page-programme-course .mod-row{
  position:relative;
  grid-template-columns:88px minmax(0,1fr) 140px;
  gap:18px;
  padding:26px 28px;
  border-bottom-color:rgba(255,255,255,.06);
  transition:transform .25s ease, background .25s ease;
}
.nl-page-programme-course .mod-row::before{
  content:"";
  position:absolute;
  left:22px;
  top:18px;
  bottom:18px;
  width:3px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(79,143,255,.72),rgba(79,143,255,0));
  opacity:.55;
}
.nl-page-programme-course .mod-row:hover{background:linear-gradient(90deg,rgba(79,143,255,.06),rgba(255,255,255,.015));transform:translateX(4px);}
.nl-page-programme-course .mod-num{
  width:52px;height:52px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(79,143,255,.12);
  border:1px solid rgba(79,143,255,.22);
  font-size:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.nl-page-programme-course .mod-title h4{font-size:22px;line-height:1.08;margin-bottom:8px;color:#fff;}
.nl-page-programme-course .mod-title p{font-size:14px;line-height:1.72;color:rgba(255,255,255,.72);margin:0;max-width:70ch;}
.nl-page-programme-course .mod-tag{
  align-self:center;
  justify-self:end;
  display:inline-flex;align-items:center;
  padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.62);
  letter-spacing:.12em;
}
.nl-page-programme-course .nl-copy-card,
.nl-page-programme-course .check-box,
.nl-page-programme-course .nl-deliverable-card,
.nl-page-programme-course .nl-feature-tile,
.nl-page-programme-course .nl-final-cta-card{
  box-shadow:0 22px 60px rgba(0,0,0,.18);
}

@media (max-width:980px){
  .nl-page-programme-course .nl-timeline__item{padding-right:0;}
  .nl-page-programme-course .nl-timeline__item::after{inset:10px 0 10px 54px;}
  .nl-page-programme-course .mod-row{grid-template-columns:70px minmax(0,1fr);}
  .nl-page-programme-course .mod-tag{justify-self:start;margin-top:8px;}
}
@media (max-width:767px){
  .nl-page-programme-course .nl-timeline__title{font-size:22px;}
  .nl-page-programme-course .mod-row{padding:22px 20px;gap:14px;}
  .nl-page-programme-course .mod-row::before{left:14px;top:14px;bottom:14px;}
  .nl-page-programme-course .mod-num{width:46px;height:46px;border-radius:16px;font-size:16px;}
  .nl-course-card__title{font-size:22px;}
}

/* ===== v18 single course readability + visual polish ===== */
.nl-page-programme-course .nl-overview-card{
  overflow:hidden;
}
.nl-page-programme-course .nl-overview-layout{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(280px,.9fr);
  gap:28px;
  align-items:start;
}
.nl-page-programme-course .nl-overview-main{
  min-width:0;
}
.nl-page-programme-course .nl-overview-main .section-heading{
  max-width:13ch;
  margin-bottom:18px;
}
.nl-page-programme-course .nl-overview-copy{
  display:grid;
  gap:14px;
  margin-top:20px;
}
.nl-page-programme-course .nl-overview-copy p{
  margin:0;
  color:rgba(255,255,255,.82);
  line-height:1.82;
  max-width:68ch;
}
.nl-page-programme-course .nl-overview-side{
  display:grid;
  gap:18px;
}
.nl-page-programme-course .nl-overview-media{
  position:relative;
  min-height:220px;
  border-radius:24px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(20,32,58,.96),rgba(10,16,30,.98));
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 18px 40px rgba(0,0,0,.2);
}
.nl-page-programme-course .nl-overview-media::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:45%;
  background:linear-gradient(180deg,rgba(0,0,0,0),rgba(8,14,26,.52));
}
.nl-page-programme-course .nl-overview-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.nl-page-programme-course .nl-overview-highlights{
  padding:20px 20px 18px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(18,30,54,.92),rgba(11,18,34,.98));
  border:1px solid rgba(255,255,255,.07);
}
.nl-page-programme-course .nl-mini-points{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.nl-page-programme-course .nl-mini-point{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:12px 0;
  border-top:1px solid rgba(255,255,255,.06);
  color:rgba(255,255,255,.82);
  line-height:1.6;
}
.nl-page-programme-course .nl-mini-point:first-child{
  border-top:none;
  padding-top:0;
}
.nl-page-programme-course .nl-mini-point__icon,
.nl-page-programme-course .nl-benefit-row__icon{
  width:24px;
  height:24px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#8fb7ff;
  background:rgba(79,143,255,.12);
  border:1px solid rgba(79,143,255,.2);
  flex-shrink:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.nl-page-programme-course .nl-benefit-grid{
  gap:22px;
}
.nl-page-programme-course .nl-benefit-card{
  position:relative;
  overflow:hidden;
  padding:30px 30px 26px;
  background:linear-gradient(180deg,rgba(14,24,45,.96),rgba(9,16,31,.98));
  border:1px solid rgba(255,255,255,.07);
}
.nl-page-programme-course .nl-benefit-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:1px;
  background:linear-gradient(90deg,rgba(79,143,255,.55),rgba(255,255,255,0));
  opacity:.9;
}
.nl-page-programme-course .nl-benefit-card--accent::before{
  background:linear-gradient(90deg,rgba(120,170,255,.85),rgba(255,255,255,0));
}
.nl-page-programme-course .nl-benefit-card h3{
  font-size:31px;
  line-height:1.05;
  margin-bottom:10px;
}
.nl-page-programme-course .nl-benefit-card__intro{
  margin:0 0 18px;
  color:rgba(255,255,255,.66);
  max-width:44ch;
  line-height:1.72;
}
.nl-page-programme-course .nl-benefit-card__rows{
  display:grid;
  gap:0;
}
.nl-page-programme-course .nl-benefit-row{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:16px 0;
  border-top:1px solid rgba(255,255,255,.06);
}
.nl-page-programme-course .nl-benefit-row:first-child{
  border-top:none;
  padding-top:4px;
}
.nl-page-programme-course .nl-benefit-row__text{
  color:rgba(255,255,255,.86);
  line-height:1.65;
}
@media (max-width:980px){
  .nl-page-programme-course .nl-overview-layout{
    grid-template-columns:1fr;
  }
  .nl-page-programme-course .nl-overview-main .section-heading{
    max-width:15ch;
  }
}
@media (max-width:767px){
  .nl-page-programme-course .nl-overview-card,
  .nl-page-programme-course .nl-benefit-card{
    padding:22px 20px;
  }
  .nl-page-programme-course .nl-benefit-card h3{
    font-size:25px;
  }
  .nl-page-programme-course .nl-overview-media{
    min-height:180px;
  }
}


/* v19 — formations toolbar, empty states, icon polish, micro-interactions */
.nl-catalog-toolbar{display:grid;grid-template-columns:minmax(0,1.2fr) auto;gap:14px;align-items:end;margin:0 auto 18px;max-width:1240px;padding:18px;border-radius:24px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.025));backdrop-filter:blur(10px);box-shadow:0 16px 42px rgba(2,8,23,.14)}
.nl-catalog-toolbar__search{position:relative;display:flex;align-items:center}
.nl-catalog-toolbar__icon{position:absolute;left:16px;color:rgba(255,255,255,.54);display:inline-flex;pointer-events:none}
.nl-catalog-toolbar__input,.nl-catalog-toolbar__field select{width:100%;min-height:52px;border-radius:16px;border:1px solid rgba(255,255,255,.09);background:rgba(12,18,32,.58);color:var(--text-main);padding:0 16px;transition:border-color .24s ease,box-shadow .24s ease,transform .24s ease}
.nl-catalog-toolbar__input{padding-left:48px}
.nl-catalog-toolbar__input:focus,.nl-catalog-toolbar__field select:focus{outline:none;border-color:rgba(79,143,255,.5);box-shadow:0 0 0 4px rgba(79,143,255,.12)}
.nl-catalog-toolbar__controls{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:12px}
.nl-catalog-toolbar__field{display:flex;flex-direction:column;gap:8px}
.nl-catalog-toolbar__field span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.6);font-weight:700;padding-left:4px}
.nl-catalog-feedback{max-width:1240px;margin:0 auto 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--text-dim)}
.nl-catalog-feedback p{margin:0}
.nl-catalog-feedback strong{color:var(--text-main)}
.nl-catalog-feedback__reset{border:0;background:none;color:#8cb4ff;font-weight:700;cursor:pointer;padding:0}
.nl-catalog-empty{max-width:760px;margin:28px auto 0;padding:28px;border-radius:24px;border:1px dashed rgba(255,255,255,.14);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.02));text-align:center}
.nl-catalog-empty__icon,.nl-empty-card__icon{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:rgba(79,143,255,.14);color:#8cb4ff;box-shadow:inset 0 0 0 1px rgba(79,143,255,.16)}
.nl-catalog-empty h3,.nl-empty-card h3{margin:14px 0 8px;font-size:24px;color:var(--text-main)}
.nl-catalog-empty p,.nl-empty-card p{margin:0;color:var(--text-dim)}
.nl-course-card{transition:transform .28s cubic-bezier(.22,1,.36,1),box-shadow .28s cubic-bezier(.22,1,.36,1),border-color .28s ease,opacity .22s ease}
.nl-course-card:hover{transform:translateY(-8px) scale(1.006)}
.nl-course-card.is-hidden{display:none !important}
.nl-course-card__meta-row span,.nl-course-card__badge,.nl-course-card__features li span,.nl-benefit-row,.nl-deliverable-card,.mod-row,.faq-item{transition:transform .24s ease,border-color .24s ease,background .24s ease,box-shadow .24s ease}
.nl-course-card__link:focus-visible,.nl-course-card__cta .btn-mag:focus-visible,.nl-catalog-empty .btn-ghost:focus-visible{outline:2px solid rgba(140,180,255,.85);outline-offset:4px}
.nl-course-card__image--placeholder{position:relative;overflow:hidden}
.nl-course-card__image--placeholder::before{content:"";position:absolute;inset:-20%;background:radial-gradient(circle at 50% 20%,rgba(79,143,255,.22),transparent 42%);animation:nlPulseFloat 5.5s ease-in-out infinite}
@keyframes nlPulseFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.04)}}
.nl-benefit-grid{align-items:stretch}
.nl-benefit-card{position:relative;overflow:hidden}
.nl-benefit-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(79,143,255,.08),transparent 45%);pointer-events:none}
.nl-benefit-card__rows{display:grid;gap:12px}
.nl-benefit-row{display:grid;grid-template-columns:42px 1fr;gap:14px;align-items:start;padding:14px 14px 14px 12px;border-radius:18px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.025);box-shadow:0 8px 22px rgba(2,8,23,.08)}
.nl-benefit-row:hover{transform:translateX(4px);border-color:rgba(79,143,255,.22);background:rgba(79,143,255,.06)}
.nl-benefit-row__icon{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(79,143,255,.2),rgba(79,143,255,.1));color:#8cb4ff;box-shadow:inset 0 0 0 1px rgba(79,143,255,.14)}
.nl-benefit-row__text{padding-top:2px}
.nl-empty-inline{display:grid;grid-template-columns:42px 1fr;gap:14px;align-items:start;padding:14px;border-radius:18px;border:1px dashed rgba(255,255,255,.11);background:rgba(255,255,255,.02);color:var(--text-dim)}
.nl-deliverables-grid{gap:16px}
.nl-deliverable-card{display:grid;grid-template-columns:44px 1fr;gap:14px;align-items:start;padding:20px 18px;border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 28px rgba(2,8,23,.12)}
.nl-deliverable-card:hover{transform:translateY(-4px);border-color:rgba(79,143,255,.24);background:linear-gradient(180deg,rgba(79,143,255,.08),rgba(255,255,255,.025))}
.nl-deliverable-card__icon{width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:rgba(79,143,255,.14);color:#8cb4ff;box-shadow:inset 0 0 0 1px rgba(79,143,255,.16)}
.nl-empty-card{display:grid;grid-template-columns:56px 1fr;gap:18px;align-items:start;padding:22px;border-radius:22px;border:1px dashed rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015))}
.nl-empty-card__icon{margin-top:2px}
.nl-overview-highlights,.nl-overview-media,.nl-copy-card,.mod-row{will-change:transform}
.nl-overview-highlights:hover,.nl-overview-media:hover,.nl-copy-card:hover{transform:translateY(-2px)}
@media (max-width: 980px){.nl-catalog-toolbar{grid-template-columns:1fr}.nl-catalog-toolbar__controls{grid-template-columns:1fr 1fr}}
@media (max-width: 767px){.nl-catalog-toolbar{padding:14px;border-radius:18px}.nl-catalog-toolbar__controls{grid-template-columns:1fr}.nl-catalog-feedback{align-items:flex-start;flex-direction:column}.nl-empty-card{grid-template-columns:1fr}.nl-benefit-row,.nl-empty-inline,.nl-deliverable-card{grid-template-columns:1fr}.nl-benefit-row__icon,.nl-deliverable-card__icon,.nl-empty-card__icon{margin-bottom:4px}}


/* ── BRAND ALIVE POLISH ───────────────────────────────────────────── */
body{background:
 radial-gradient(circle at 20% 0%, rgba(79,143,255,.12), transparent 28%),
 radial-gradient(circle at 80% 10%, rgba(91,155,255,.08), transparent 24%),
 linear-gradient(180deg, #09101d 0%, #0c1220 26%, #0b1120 100%);
}
body::after{
 content:""; position:fixed; inset:0; pointer-events:none; z-index:-1;
 background:linear-gradient(180deg, rgba(255,255,255,.02), transparent 18%, transparent 82%, rgba(79,143,255,.03));
}
.nl-section--rhythm,.nl-section--rhythm-alt{position:relative;}
.nl-section--rhythm::before,.nl-section--rhythm-alt::before{
 content:""; position:absolute; inset:18px 24px auto; height:1px;
 background:linear-gradient(90deg, transparent, rgba(148,163,184,.18), transparent);
}
.nl-section--rhythm-alt{background:linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,0)); border-radius:40px;}
.nl-hero--alive{position:relative; isolation:isolate;}
.nl-hero__mesh{position:absolute; inset:110px 12% auto; height:420px; z-index:-1; pointer-events:none;
 background:
 radial-gradient(circle at 50% 50%, rgba(79,143,255,.18), transparent 42%),
 linear-gradient(135deg, rgba(255,255,255,.05), transparent 30%, rgba(79,143,255,.06) 65%, transparent 80%);
 filter: blur(10px);
 opacity:.9;
}
.nl-hero--alive .card-label{display:inline-flex; align-items:center; gap:10px; padding:10px 14px; border-radius:999px; background:rgba(255,255,255,.04); border:1px solid rgba(148,163,184,.14); box-shadow:0 14px 40px rgba(0,0,0,.18);}
.nl-hero--alive h1{max-width:10ch; margin-left:auto; margin-right:auto; text-wrap:balance;}
.nl-hero--alive p{max-width:760px; color:#c1d0e7; font-size:clamp(18px, 2vw, 21px); text-wrap:pretty;}
.nl-hero__chips{display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin:22px auto 0; max-width:900px;}
.nl-chip{display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; font-size:12px; font-weight:700; letter-spacing:.03em; color:#d9e7ff; background:rgba(255,255,255,.045); border:1px solid rgba(148,163,184,.14); box-shadow: inset 0 1px 0 rgba(255,255,255,.08);}
.nl-chip::before{content:""; width:6px; height:6px; border-radius:50%; background:linear-gradient(180deg, #90b7ff, #4f8fff); box-shadow:0 0 0 6px rgba(79,143,255,.12);}
.btn-ghost{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 24px; border-radius:999px; border:1px solid rgba(148,163,184,.16); color:#e2ecff; background:rgba(255,255,255,.03); transition:transform .28s ease, border-color .28s ease, background .28s ease, box-shadow .28s ease;}
.btn-ghost:hover{transform:translateY(-2px); border-color:rgba(79,143,255,.38); background:rgba(79,143,255,.08); box-shadow:0 16px 34px rgba(79,143,255,.10); color:#fff;}
.btn-mag{position:relative; overflow:hidden;}
.btn-mag::before{content:""; position:absolute; inset:0; background:linear-gradient(120deg, transparent 15%, rgba(255,255,255,.22) 50%, transparent 85%); transform:translateX(-120%); transition:transform .7s ease;}
.btn-mag:hover::before{transform:translateX(120%);}
.nl-hero__actions{display:flex; flex-wrap:wrap; gap:14px; justify-content:center; align-items:center;}
.nl-hero__proof{display:inline-flex; align-items:center; gap:10px; margin-top:18px; padding:12px 18px; border-radius:999px; background:rgba(255,255,255,.035); border:1px solid rgba(148,163,184,.12); color:#c2d0e4; box-shadow:0 16px 40px rgba(0,0,0,.16);}
.nl-hero__mini-grid{max-width:980px; margin:34px auto 0; display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px;}
.nl-hero__mini-card,.nl-hero__floating{background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)); border:1px solid rgba(148,163,184,.12); border-radius:24px; box-shadow:0 20px 50px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.06); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);}
.nl-hero__mini-card{padding:18px 18px 16px; text-align:left; position:relative; overflow:hidden;}
.nl-hero__mini-card::after{content:""; position:absolute; right:-24px; top:-24px; width:90px; height:90px; border-radius:50%; background:radial-gradient(circle, rgba(79,143,255,.18), transparent 66%);}
.nl-hero__mini-card strong{display:block; font-family:'Bricolage Grotesque', sans-serif; font-size:18px; margin-bottom:8px;}
.nl-hero__mini-card span{display:block; color:#9eb2cd; font-size:14px; line-height:1.6;}
.nl-hero__floating{position:absolute; padding:14px 16px; text-align:left; width:210px; z-index:1;}
.nl-hero__floating span{display:block; color:#8fb5ff; font-size:11px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:6px;}
.nl-hero__floating strong{display:block; font-size:16px; line-height:1.3;}
.nl-hero__floating--one{top:22%; left:8%;}
.nl-hero__floating--two{right:9%; top:32%;}
.section-heading{position:relative; display:inline-block; margin-bottom:20px;}
.section-heading::after{content:""; display:block; width:84px; height:4px; border-radius:999px; margin-top:16px; background:linear-gradient(90deg, var(--accent), rgba(79,143,255,0));}
.section-heading--left::after{margin-left:0;}
.section-sub{color:#a7b9d1; max-width:700px;}
.bento-card,.nl-step-card,.t-card,.nl-copy-card,.nl-benefit-card,.nl-deliverable-card,.nl-empty-card,.nl-course-card,.stat-pill,.faq-item,.mod-row,.nl-timeline__item{
 box-shadow:0 20px 60px rgba(0,0,0,.16);
}
.bento-card,.t-card,.nl-copy-card,.nl-benefit-card,.nl-deliverable-card,.nl-course-card,.faq-item,.mod-row,.nl-timeline__item{position:relative; overflow:hidden;}
.bento-card::before,.nl-step-card::before,.t-card::before,.nl-copy-card::before,.nl-benefit-card::before,.nl-course-card::before,.faq-item::before,.mod-row::before,.nl-timeline__item::before{
 content:""; position:absolute; inset:0; background:radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 0%), rgba(79,143,255,.12), transparent 42%); opacity:0; transition:opacity .35s ease; pointer-events:none;
}
.bento-card:hover::before,.nl-step-card:hover::before,.t-card:hover::before,.nl-copy-card:hover::before,.nl-benefit-card:hover::before,.nl-course-card:hover::before,.faq-item:hover::before,.mod-row:hover::before,.nl-timeline__item:hover::before{opacity:1;}
.nl-courses-grid,.nl-steps-grid,.t-grid,.nl-deliverables-grid,.nl-feature-grid{gap:22px;}
.nl-course-card{transition:transform .35s cubic-bezier(.22,1,.36,1), border-color .35s ease, box-shadow .35s ease;}
.nl-course-card:hover{transform:translateY(-8px) scale(1.01); border-color:rgba(79,143,255,.22); box-shadow:0 32px 80px rgba(0,0,0,.24), 0 0 0 1px rgba(79,143,255,.08) inset;}
.nl-course-card__image{position:relative;}
.nl-course-card__image::after{content:""; position:absolute; inset:auto 0 0; height:45%; background:linear-gradient(180deg, transparent, rgba(12,18,32,.55));}
.nl-course-card__badge{backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); box-shadow:0 10px 24px rgba(0,0,0,.18);}
.nl-course-card__title{line-height:1.05; text-wrap:balance;}
.nl-course-card__desc{color:#aabbd2;}
.nl-course-card__more{position:relative;}
.nl-course-card__more::after{content:""; position:absolute; left:0; bottom:-4px; width:100%; height:1px; transform:scaleX(0); transform-origin:left; transition:transform .3s ease; background:currentColor; opacity:.55;}
.nl-course-card:hover .nl-course-card__more::after{transform:scaleX(1);}
.nl-overview-card{background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.025));}
.nl-overview-layout{align-items:start; gap:34px;}
.nl-overview-copy p + p{margin-top:14px;}
.nl-overview-highlights{padding:18px; border-radius:22px; background:rgba(255,255,255,.035); border:1px solid rgba(148,163,184,.1);}
.nl-mini-point{display:flex; gap:12px; align-items:flex-start; padding:12px 0; border-top:1px solid rgba(148,163,184,.08);}
.nl-mini-point:first-child{border-top:none; padding-top:0;}
.nl-mini-point__icon{display:inline-grid; place-items:center; width:22px; height:22px; border-radius:50%; background:rgba(79,143,255,.16); color:#cfe0ff; font-size:12px; flex:0 0 22px;}
.nl-timeline{position:relative; gap:18px;}
.nl-timeline::before{content:""; position:absolute; left:22px; top:6px; bottom:6px; width:1px; background:linear-gradient(180deg, rgba(79,143,255,.45), rgba(79,143,255,0));}
.nl-timeline__item{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); border-radius:24px; border:1px solid rgba(148,163,184,.1);}
.nl-timeline__num{box-shadow:0 10px 24px rgba(79,143,255,.18);}
.curriculum{background:linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.016));}
.mod-row{position:relative; grid-template-columns:88px 1fr 180px;}
.mod-num{position:relative;}
.mod-num::after{content:""; position:absolute; left:-12px; top:50%; width:8px; height:8px; border-radius:50%; background:var(--accent); transform:translateY(-50%); box-shadow:0 0 0 8px rgba(79,143,255,.12);}
.mod-title h4{font-size:22px;}
.mod-title p{font-size:15px; color:#9eb0c8;}
.nl-benefit-grid{gap:24px;}
.nl-benefit-card{background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.028));}
.nl-benefit-card--accent{background:linear-gradient(180deg, rgba(79,143,255,.11), rgba(255,255,255,.03));}
.nl-benefit-row{display:flex; gap:12px; align-items:flex-start; padding:15px 0; border-top:1px solid rgba(148,163,184,.08);}
.nl-benefit-row:first-child{border-top:none; padding-top:0;}
.nl-benefit-row__icon{display:inline-grid; place-items:center; width:24px; height:24px; border-radius:50%; background:rgba(79,143,255,.16); color:#e2edff; flex:0 0 24px; box-shadow:0 0 0 8px rgba(79,143,255,.08);}
.nl-benefit-row__text{color:#d8e4f6; line-height:1.65;}
.nl-deliverable-card{display:flex; align-items:flex-start; gap:14px; padding:22px; background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); border:1px solid rgba(148,163,184,.08); border-radius:22px; transition:transform .3s ease, border-color .3s ease;}
.nl-deliverable-card:hover{transform:translateY(-4px); border-color:rgba(79,143,255,.2);}
.nl-deliverable-card__icon{display:inline-grid; place-items:center; width:36px; height:36px; border-radius:14px; background:rgba(79,143,255,.14); color:#d9e8ff;}
.faq-item{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.022)); border-radius:22px; border:1px solid rgba(148,163,184,.1); transition:transform .28s ease, border-color .28s ease;}
.faq-item:hover{transform:translateY(-3px); border-color:rgba(79,143,255,.22);}
.faq-item summary{list-style:none; cursor:pointer; font-size:18px; font-weight:700; padding:24px 28px; position:relative;}
.faq-item summary::after{content:'+'; position:absolute; right:26px; top:50%; transform:translateY(-50%); color:#9cc0ff; font-size:22px;}
.faq-item[open] summary::after,.faq-item.open summary::after{content:'−';}
.faq-item__body{padding:0 28px 24px; color:#acc0db; line-height:1.7;}
.nl-empty-card,.nl-catalog-empty{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.018)); border:1px solid rgba(148,163,184,.08); border-radius:28px;}
.nl-empty-card__icon,.nl-catalog-empty__icon{width:54px; height:54px; border-radius:18px; display:grid; place-items:center; background:rgba(79,143,255,.12); color:#d9e8ff; box-shadow:0 0 0 10px rgba(79,143,255,.06);}
.nl-catalog-toolbar{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.024)); border:1px solid rgba(148,163,184,.08); border-radius:28px; padding:18px; box-shadow:0 20px 60px rgba(0,0,0,.16);}
.nl-catalog-feedback{display:flex; justify-content:space-between; align-items:center; gap:16px; margin:18px 0 10px; color:#b5c4d7;}
.nl-catalog-toolbar__input, .nl-catalog-toolbar select{transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease;}
.nl-catalog-toolbar__input:focus, .nl-catalog-toolbar select:focus{border-color:rgba(79,143,255,.4); box-shadow:0 0 0 4px rgba(79,143,255,.12); transform:translateY(-1px); outline:none;}
@media (max-width: 1100px){
 .nl-hero__floating{display:none;}
 .nl-hero__mini-grid{grid-template-columns:1fr; max-width:760px;}
}
@media (max-width: 768px){
 .nl-hero{padding:170px 20px 90px;}
 .nl-hero--alive h1{max-width:12ch;}
 .nl-hero__proof{font-size:13px; flex-wrap:wrap; justify-content:center;}
 .btn-ghost,.btn-mag{width:100%; justify-content:center;}
 .nl-hero__actions{max-width:440px; margin:0 auto;}
 .nl-section--rhythm-alt{border-radius:28px;}
 .section-heading::after{width:60px; margin-top:12px;}
 .mod-row{grid-template-columns:70px 1fr;}
 .mod-tag{grid-column:2; text-align:left; margin-top:10px;}
}
@media (prefers-reduced-motion: reduce){
 .nl-course-card,.nl-deliverable-card,.faq-item,.btn-mag,.btn-ghost{transition:none !important;}
 .nl-hero__floating,[data-float-card]{animation:none !important;}
}


/* v22 cleanup + livability fixes */
.nl-hero__floating{display:none !important;}
.nl-hero__actions .btn-ghost--hero{display:none !important;}
.nl-hero__mini-grid .nl-hero__mini-card:first-child strong{max-width:14ch;}

.nl-aff-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 36px;max-width:900px;}
.nl-aff-tag{background:rgba(79,143,255,.08);border:1px solid rgba(79,143,255,.15);border-radius:999px;padding:8px 18px;font-size:13px;font-weight:600;color:#93c5fd;}
.nl-aff-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.nl-aff-anchor{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;border:1px solid rgba(255,255,255,.1);border-radius:100px;color:var(--text-dim);font-weight:600;font-size:15px;transition:border-color .25s ease,background .25s ease,color .25s ease;}
.nl-aff-anchor:hover{border-color:rgba(79,143,255,.28);background:rgba(79,143,255,.08);color:var(--text-main);}
.nl-aff-steps,.nl-aff-benefits{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:48px;max-width:900px;margin-left:auto;margin-right:auto;}
.nl-aff-step{padding:28px 24px !important;overflow:visible !important;}
.nl-aff-step__index{position:static;display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 14px;margin-bottom:18px;background:rgba(79,143,255,.12);border:1px solid rgba(79,143,255,.22);color:#ddebff;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.08em;}
.nl-aff-step__icon{font-size:34px;margin-bottom:14px;line-height:1;}
.nl-aff-step__title{font-size:20px;font-weight:800;color:var(--text-main);margin:0 0 10px;}
.nl-aff-step__desc{color:var(--text-dim);font-size:14px;line-height:1.7;margin:0;}
.nl-aff-benefit{background:var(--card-bg);border:1px solid var(--border);border-radius:18px;padding:28px 24px;box-shadow:0 20px 50px rgba(2,8,23,.16);}
.nl-aff-benefit__icon{font-size:30px;margin-bottom:14px;line-height:1;}
.nl-aff-benefit__title{font-size:17px;font-weight:800;color:var(--text-main);margin:0 0 8px;}
.nl-aff-benefit__desc{color:var(--text-dim);font-size:14px;line-height:1.65;margin:0 0 14px;}
.nl-aff-benefit__meta{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-size:13px;font-weight:700;padding:8px 12px;border-radius:999px;background:rgba(79,143,255,.08);border:1px solid rgba(79,143,255,.14);}
.nl-aff-cta{background:rgba(79,143,255,.06);border:1px solid rgba(79,143,255,.15);border-radius:24px;padding:48px 40px;text-align:center;max-width:700px;margin:0 auto;}
.nl-aff-cta__title{font-size:clamp(24px,4vw,32px);font-weight:800;color:var(--text-main);margin:0 0 12px;}
.nl-aff-cta__desc{color:var(--text-dim);font-size:16px;margin:0 auto 28px;max-width:480px;}
.nl-aff-cta__button{padding:18px 48px;font-size:18px;}

.nl-contact-faq{max-width:980px;margin:42px auto 0;display:grid;gap:16px;}
.nl-contact-faq__item{background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));border:1px solid rgba(148,163,184,.12);border-radius:22px;box-shadow:0 18px 46px rgba(2,8,23,.16);overflow:hidden;}
.nl-contact-faq__item[open]{border-color:rgba(79,143,255,.26);box-shadow:0 24px 56px rgba(2,8,23,.22), 0 0 0 1px rgba(79,143,255,.06) inset;}
.nl-contact-faq__q{list-style:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;font:800 18px/1.4 'Bricolage Grotesque',sans-serif;color:var(--text-main);}
.nl-contact-faq__q::-webkit-details-marker{display:none;}
.nl-contact-faq__q::after{content:'+';flex:0 0 auto;width:36px;height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(79,143,255,.12);border:1px solid rgba(79,143,255,.18);color:#9cc0ff;font-size:22px;font-weight:700;transition:transform .24s ease,background .24s ease;}
.nl-contact-faq__item[open] .nl-contact-faq__q::after{transform:rotate(45deg);background:rgba(79,143,255,.18);}
.nl-contact-faq__a{padding:0 24px 24px;color:#b8c7dc;font-size:15px;line-height:1.75;max-width:78ch;}
@media (max-width: 768px){.nl-aff-actions{gap:10px;}.nl-aff-anchor{padding:14px 20px;width:100%;justify-content:center;}.nl-aff-steps,.nl-aff-benefits{grid-template-columns:1fr;}.nl-aff-cta{padding:32px 22px;}.nl-contact-faq{gap:12px;margin-top:28px;}.nl-contact-faq__q{padding:18px 18px;font-size:16px;}.nl-contact-faq__q::after{width:30px;height:30px;border-radius:10px;font-size:18px;}.nl-contact-faq__a{padding:0 18px 18px;font-size:14px;}}


/* v29 — single course cleanup + CTA safety */
.nl-page-course-single .nl-hero--course{position:relative;overflow:hidden}
.nl-page-course-single .nl-hero--course h1{max-width:12ch;margin-left:auto;margin-right:auto;text-wrap:balance}
.nl-page-course-single .nl-hero--course p{max-width:760px}
.nl-course-cta-note{margin:14px auto 0;max-width:760px;padding:10px 14px;border-radius:999px;background:rgba(245,158,11,.10);border:1px solid rgba(245,158,11,.24);color:#fcd9a2;font-size:13px;line-height:1.5;text-align:center}


/* popup removed */
.nl-exit-popup, .nl-email-popup { display:none !important; }
