:root {
    --duo-green: #58cc02;
    --duo-green-dark: #46a302;
    --duo-blue: #1cb0f6;
    --duo-red: #ff4b4b;
    --duo-orange: #ff9600;
    --duo-purple: #ce82ff;
    --duo-bg: #131f24;
    --duo-card: #1a2e35;
    --duo-card-border: #253d47;
    --duo-text: #e5e5e5;
    --duo-muted: #8a9ca3;
}

* { box-sizing: border-box; }

body {
    background: var(--duo-bg);
    color: var(--duo-text);
    font-family: 'Nunito', sans-serif;
    min-height: 100vh;
}

/* ── Navbar ──────────────────────────────── */
.navbar {
    background: var(--duo-card) !important;
    border-bottom: 2px solid var(--duo-green);
}
.navbar-brand {
    color: var(--duo-green) !important;
    font-weight: 800;
    font-size: 1.4rem;
    letter-spacing: -0.5px;
}

/* ── Cards ───────────────────────────────── */
.card {
    background: var(--duo-card);
    border: 2px solid var(--duo-card-border);
    border-radius: 16px;
    transition: transform 0.15s, border-color 0.15s;
}
.card:hover {
    transform: translateY(-2px);
    border-color: var(--duo-green);
}
.card-title { color: #fff; }
.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--duo-card-border);
    font-weight: 700;
}

/* ── Buttons ─────────────────────────────── */
.btn-duo {
    background: var(--duo-green);
    color: #fff;
    font-weight: 700;
    border: none;
    border-bottom: 4px solid var(--duo-green-dark);
    border-radius: 12px;
    padding: 10px 24px;
    transition: filter 0.15s;
}
.btn-duo:hover { filter: brightness(1.1); color: #fff; }
.btn-duo:active { border-bottom-width: 2px; transform: translateY(2px); }

.btn-duo-blue {
    background: var(--duo-blue);
    border-bottom-color: #0e8bc7;
}
.btn-duo-orange {
    background: var(--duo-orange);
    border-bottom-color: #d47e00;
}
.btn-duo-purple {
    background: var(--duo-purple);
    border-bottom-color: #a85edb;
}
.btn-duo-purple:hover {
    background: #e0a0ff;
    border-bottom-color: var(--duo-purple);
}
.btn-duo-red {
    background: var(--duo-red);
    border-bottom-color: #cc3030;
}

.btn-sm.btn-duo { padding: 6px 14px; font-size: 0.85rem; }

/* ── Forms ───────────────────────────────── */
.form-control, .form-select {
    background: var(--duo-bg);
    border: 2px solid var(--duo-card-border);
    color: #fff;
    border-radius: 12px;
}
.form-control:focus, .form-select:focus {
    background: var(--duo-bg);
    border-color: var(--duo-green);
    color: #fff;
    box-shadow: 0 0 0 3px rgba(88,204,2,0.25);
}
.form-control::placeholder { color: var(--duo-muted); }

.form-label { font-weight: 700; color: var(--duo-muted); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.5px; }

/* ── Breadcrumb ──────────────────────────── */
.breadcrumb { background: transparent; margin-bottom: 0; }
.breadcrumb-item a { color: var(--duo-green); text-decoration: none; }
.breadcrumb-item a:hover { text-decoration: underline; }
.breadcrumb-item.active { color: var(--duo-muted); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--duo-muted); }

/* ── Badges ──────────────────────────────── */
.badge-lesson { background: var(--duo-blue); }
.badge-quiz   { background: var(--duo-orange); }
.badge-mc     { background: var(--duo-purple); }
.badge-tf     { background: var(--duo-red); }
.badge-ws     { background: var(--duo-green); }
.badge-fb     { background: var(--duo-blue); }

/* ── List items ──────────────────────────── */
.list-group-item {
    background: var(--duo-card);
    border-color: var(--duo-card-border);
    color: var(--duo-text);
}
.list-group-item:hover {
    background: var(--duo-card-border);
}

/* ── Section title ───────────────────────── */
.section-title {
    font-weight: 800;
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--duo-card-border);
}

/* ── Empty state ─────────────────────────── */
.empty-state {
    color: var(--duo-muted);
    text-align: center;
    padding: 2rem;
    font-style: italic;
}

/* ── Options list in quiz form ───────────── */
.option-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}
.option-row .form-control { flex: 1; }

/* ── Headings ────────────────────────────── */
h2, h3, h4, h5 { color: #fff; }

/* ── Text muted override ─────────────────── */
.text-muted { color: var(--duo-muted) !important; }

/* ── Sortable items ──────────────────────── */
.sortable-item {
    transition: background 0.15s;
}
.sortable-item:hover .drag-handle {
    color: var(--duo-green) !important;
}

/* ── Flash ───────────────────────────────── */
.alert { border-radius: 12px; border: none; font-weight: 600; }
