:root {
    --bp-ink: #1f2318;
    --bp-muted: rgba(31, 35, 24, 0.72);
    --bp-border: rgba(31, 35, 24, 0.14);
    --bp-bg: rgba(255, 255, 255, 0.34);
    --bp-bg-2: rgba(255, 255, 255, 0.22);
    --bp-shadow: 0 10px 22px rgba(0, 0, 0, 0.06);
    --bp-shadow-soft: 0 6px 16px rgba(0, 0, 0, 0.06);

    --bp-radius: clamp(14px, 1.8vw, 18px);
    --bp-radius-lg: clamp(16px, 2.2vw, 22px);
    --bp-gap: clamp(10px, 2vw, 14px);
    --bp-pad: clamp(12px, 2vw, 16px);

    --bp-serif: "Libre Baskerville", serif;
    --bp-sans: "Inter", system-ui, sans-serif;

    --bp-sage: rgba(75, 107, 7, 0.10);
    --bp-amber: rgba(189, 116, 38, 0.10);
    --bp-olive: rgba(47, 59, 0, 0.10);
    --bp-stone: rgba(31, 35, 24, 0.06);

    --bp-sage-border: rgba(75, 107, 7, 0.28);
    --bp-amber-border: rgba(189, 116, 38, 0.30);
    --bp-olive-border: rgba(47, 59, 0, 0.26);
    --bp-stone-border: rgba(31, 35, 24, 0.22);
}

.ps-practice-tabs,
.ps-practice-tabs .tab-content,
.ps-practice-tabs .tab-pane,
.ps-practice-tabs .html-fill-item,
.ps-practice-tabs .html-fill-container,
.ps-practice-tabs .bslib-gap-spacing,
.ps-practice-tabs .card,
.ps-practice-tabs .card-body {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

.ps-practice-tabs .tab-content,
.ps-practice-tabs .tab-pane,
.ps-practice-tabs .card-body {
    overflow-x: hidden !important;
}

.ps-sortable-page,
.ps-sortable-page * {
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
}

.ps-sortable-page {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    padding: 0;
}

.ps-sortable-page [id$="bucket_list_source"] .bucket-list-container {
    border: 1px solid var(--bp-border);
    background: var(--bp-bg);
    border-radius: var(--bp-radius-lg);
    padding: var(--bp-pad);
    box-shadow: var(--bp-shadow);
}

.ps-sortable-page [id$="bucket_list_source"] .rank-list-container {
    background: var(--bp-bg-2);
    border: 1px dashed rgba(31, 35, 24, 0.22);
    border-radius: var(--bp-radius);
    padding: clamp(10px, 1.8vw, 12px);
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

.ps-sortable-page [id$="bucket_list_source"] .rank-list {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--bp-gap);
    width: 100%;
    max-width: 100%;
}

.ps-sortable-page [id$="bucket_list_source"] .rank-list-item {
    flex: 0 0 clamp(220px, 30vw, 320px);
    margin: 0;
    max-width: 100%;
}


.ps-sortable-page [id$="bucket_list_targets"] .bucket-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(clamp(220px, 26vw, 320px), 1fr));
    gap: var(--bp-gap);
    width: 100%;
    max-width: 100%;
}

.ps-sortable-page [id$="bucket_list_targets"] .bucket-list-container {
    border: 1px solid var(--bp-border);
    background: var(--bp-bg);
    border-radius: var(--bp-radius-lg);
    padding: var(--bp-pad);
    box-shadow: var(--bp-shadow);
    width: 100%;
    max-width: 100%;
}

.ps-sortable-page .bucket-list-header {
    font-family: var(--bp-serif);
    font-weight: 600;
    font-size: clamp(0.95rem, 1.2vw, 1.05rem);
    margin: 0 0 clamp(8px, 1.5vw, 12px) 0;
    color: var(--bp-ink);
}

.ps-sortable-page [id$="bucket_list_targets"] .rank-list-container {
    background: var(--bp-bg-2);
    border: 1px dashed rgba(31, 35, 24, 0.22);
    border-radius: var(--bp-radius);
    padding: clamp(10px, 1.8vw, 12px);
    width: 100%;
    max-width: 100%;
    min-height: 70px;
}

.ps-sortable-page [id$="bucket_list_targets"] .bucket-list-container:nth-child(1) .rank-list-container {
    background: var(--bp-sage);
    border-color: var(--bp-sage-border);
}

.ps-sortable-page [id$="bucket_list_targets"] .bucket-list-container:nth-child(2) .rank-list-container {
    background: var(--bp-amber);
    border-color: var(--bp-amber-border);
}

.ps-sortable-page [id$="bucket_list_targets"] .bucket-list-container:nth-child(3) .rank-list-container {
    background: var(--bp-olive);
    border-color: var(--bp-olive-border);
}

.ps-sortable-page [id$="bucket_list_targets"] .bucket-list-container:nth-child(4) .rank-list-container {
    background: var(--bp-stone);
    border-color: var(--bp-stone-border);
}

/* ---------------------------------------------------------
   Draggable cards
   --------------------------------------------------------- */

.ps-sortable-page .rank-list-item {
    background: rgba(255, 255, 255, 0.52);
    border: 1px solid rgba(31, 35, 24, 0.14);
    border-radius: var(--bp-radius);
    padding: clamp(9px, 1.6vw, 12px) clamp(10px, 1.8vw, 14px);
    margin: 0 0 clamp(8px, 1.6vw, 10px) 0;

    font-family: var(--bp-sans);
    font-size: clamp(0.85rem, 1.25vw, 0.95rem);
    line-height: 1.25;
    color: rgba(31, 35, 24, 0.88);

    box-shadow: var(--bp-shadow-soft);
    cursor: grab;
    transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;

    max-width: 100%;
}

.ps-sortable-page .rank-list-item:hover {
    transform: translateY(-1px);
    background: rgba(60, 121, 6, 0.992);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.08);
    border-color: rgba(75, 107, 7, 0.22);
}

.ps-sortable-page .rank-list-item:active {
    cursor: grabbing;
    transform: scale(0.99);
}

.ps-sortable-page .sortable-ghost,
.ps-sortable-page .sortable-chosen,
.ps-sortable-page .sortable-drag {
    background: rgba(75, 107, 7, 0.14) !important;
    border: 2px dashed rgba(75, 107, 7, 0.44) !important;
    box-shadow: none !important;
    opacity: 0.75;
}

.ps-sortable-page .lecturi-checklist__submit.btn {
    border-radius: 999px !important;
    padding: clamp(9px, 1.6vw, 11px) clamp(14px, 2.2vw, 18px) !important;
    font-weight: 700 !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.10) !important;
}

@media (max-width: 900px) {
    .ps-sortable-page [id$="bucket_list_targets"] .bucket-list {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .ps-sortable-page [id$="bucket_list_source"] .rank-list-item {
        flex: 0 0 clamp(220px, 78vw, 340px);
    }
}

/* fix nav styling */

.ps-practice-tabs .nav-tabs {
    border-bottom: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 12px;
    background: #EDDAC0;
    border: 1px solid rgba(31, 35, 24, 0.10);
    border-radius: 22px;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.08);
}

.ps-practice-tabs .nav-tabs .nav-item {
    margin: 0 !important;
}

.ps-practice-tabs .nav-tabs .nav-link {
    border: 1px solid rgba(31, 35, 24, 0.18);
        background: rgba(255, 255, 255, 0.45);
        color: rgba(31, 35, 24, 0.88);
    
        border-radius: 999px;
        padding: 10px 18px;
    
        font-family: Georgia, "Iowan Old Style", "Palatino Linotype", Palatino, serif;
        font-weight: 700;
        font-size: .95rem;
        letter-spacing: 0.2px;
        line-height: 1;
    
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
    
        box-shadow: 0 10px 22px rgba(0, 0, 0, 0.06);
        transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, border-color 120ms ease;
}

.ps-practice-tabs .nav-tabs .nav-link:hover {
    transform: translateY(-1px);
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.09);
        background: rgba(255, 255, 255, 0.62);
        border-color: rgba(31, 35, 24, 0.26);
}

.ps-practice-tabs .nav-tabs .nav-link.active,
.ps-practice-tabs .nav-tabs .nav-item.show .nav-link {
    background: #3f5f1b;
        border-color: rgba(20, 28, 16, 0.22);
        color: rgba(255, 255, 255, 0.92);
        box-shadow: 0 16px 34px rgba(0, 0, 0, 0.14);
}

.ps-practice-tabs .nav-tabs .nav-link:focus,
.ps-practice-tabs .nav-tabs .nav-link:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(63, 95, 27, 0.22), 0 14px 30px rgba(0, 0, 0, 0.10);
}

.ps-practice-tabs .nav-tabs .nav-link svg,
.ps-practice-tabs .nav-tabs .nav-link i {
    flex: 0 0 auto;
    opacity: 0.9;
}

@media (max-width: 700px) {
    .ps-practice-tabs .nav-tabs {
        gap: 8px;
        padding: 10px;
    }

    .ps-practice-tabs .nav-tabs .nav-link {
        padding: 8px 14px !important;
        font-size: 0.9rem;
    }
}