/* ================================================================
   MyWorkshopr v2 — Left Rail Workspace
   Redesign: left sidebar nav, activity feed overview,
   published templates tab, warm editorial feel.
   Uses platform-tokens.css exclusively.
   ================================================================ */

@keyframes mwReveal {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
    @keyframes mwReveal { from, to { opacity: 1; transform: none; } }
}

/* ================================================================
   LAYOUT — Full-width grid: rail + content
   ================================================================ */
.mw-layout {
    display: none;
    grid-template-columns: 240px 1fr;
    min-height: calc(100vh - 92px); /* minus headers */
}
.mw-layout.is-visible {
    display: grid;
}

/* ================================================================
   LEFT RAIL
   ================================================================ */
.mw-rail {
    background: var(--bg-surface, #fff);
    border-right: 1px solid var(--border-default, #E7E5E4);
    padding: 20px 0;
    position: relative;
}
.mw-rail-inner {
    position: sticky;
    top: 92px; /* below two-tier header */
}

/* Profile */
.mw-profile {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 20px 16px;
    border-bottom: 1px solid var(--border-subtle, #F5F5F4);
    margin-bottom: 8px;
}
.mw-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--mainsite-gradient, linear-gradient(135deg, #E54D4D 0%, #C73E3E 100%));
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 16px;
    flex-shrink: 0;
}
.mw-profile-info { min-width: 0; }
.mw-profile-name {
    font-weight: 600;
    font-size: 15px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-primary, #1E1E26);
}
.mw-profile-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 3px;
}
.mw-profile-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 3px 10px;
    border-radius: 20px;
    line-height: 1.3;
    position: relative;
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.15s;
}
.mw-profile-badge:hover {
    opacity: 0.85;
}
.mw-profile-badge::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}
.mw-profile-badge--member {
    background: linear-gradient(135deg, #E54D4D 0%, #C73E3E 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(229, 77, 77, 0.3);
}
.mw-profile-badge--member::before {
    background: #FCA5A5;
    box-shadow: 0 0 4px rgba(255, 255, 255, 0.6);
}
.mw-profile-badge--pro {
    background: linear-gradient(135deg, #D97706 0%, #F59E0B 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(217, 119, 6, 0.35);
}
.mw-profile-badge--pro::before {
    background: #FDE68A;
    box-shadow: 0 0 4px rgba(255, 255, 255, 0.6);
}
.mw-profile-badge--signup {
    background: var(--bg-secondary, #F5F5F4);
    color: var(--mainsite-primary, #E54D4D);
    border: 1px solid var(--border-default, #E7E5E4);
    cursor: pointer;
    transition: all 0.15s;
}
.mw-profile-badge--signup:hover {
    background: color-mix(in srgb, var(--mainsite-primary, #E54D4D) 10%, transparent);
    border-color: var(--mainsite-primary, #E54D4D);
}
.mw-profile-badge--signup::before {
    background: var(--mainsite-primary, #E54D4D);
}

/* DNA badge in rail */
.mw-dna-link {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 12px 12px;
    padding: 12px 14px;
    background: var(--phase-reflect-very-light, #D1FAE5);
    border: 1px solid color-mix(in srgb, var(--phase-reflect, #10B981) 20%, transparent);
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.2s;
}
.mw-dna-link:hover {
    background: #bbf7d0;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px color-mix(in srgb, var(--phase-reflect, #10B981) 20%, transparent);
}
.mw-dna-badge {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: contain;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--phase-reflect, #10B981) 25%, transparent);
    flex-shrink: 0;
}
.mw-dna-type {
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: var(--phase-reflect, #10B981);
    padding: 2px 7px;
    border-radius: 20px;
    display: inline-block;
    line-height: 1.4;
}
.mw-dna-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary, #1E1E26);
    margin-top: 2px;
}
.mw-dna-link--cta .mw-dna-cta-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--phase-reflect, #10B981) 15%, transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--phase-reflect, #10B981);
}
.mw-dna-link--cta .mw-dna-cta-icon .icon {
    width: 22px;
    height: 22px;
}
.mw-dna-cta-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--phase-reflect, #10B981);
}
.mw-dna-cta-sub {
    font-size: 11px;
    color: var(--text-secondary, #78716C);
}

/* Nav items */
.mw-nav-section {
    padding: 14px 20px 4px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-tertiary, #A8A29E);
}
.mw-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 20px;
    font-size: 14px;
    color: var(--text-secondary, #78716C);
    cursor: pointer;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
    font-family: var(--font-body, 'Source Sans 3', sans-serif);
    transition: all 0.15s ease;
    position: relative;
}
.mw-nav-item:hover {
    color: var(--text-primary, #1E1E26);
    background: var(--bg-page, #FAFAFA);
}
.mw-nav-item:focus-visible {
    outline: 2px solid var(--mainsite-primary, #E54D4D);
    outline-offset: -2px;
    border-radius: var(--radius-md, 6px);
}
.mw-nav-item.active {
    color: var(--mainsite-primary, #E54D4D);
    font-weight: 600;
    background: var(--mainsite-very-light, #FEF2F2);
}
.mw-nav-item.active::before {
    content: '';
    position: absolute;
    right: 0;
    top: 4px;
    bottom: 4px;
    width: 3px;
    background: var(--mainsite-primary, #E54D4D);
    border-radius: 3px 0 0 3px;
}
.mw-nav-item .icon { width: 18px; height: 18px; }
.mw-nav-badge {
    margin-left: auto;
    font-size: 11px;
    font-weight: 700;
    background: var(--bg-page, #F5F5F4);
    color: var(--text-secondary, #78716C);
    padding: 1px 7px;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
}
.mw-nav-item.active .mw-nav-badge {
    background: var(--mainsite-light, #FEE2E2);
    color: var(--mainsite-primary, #E54D4D);
}
@keyframes mw-badgePop {
    0% { transform: scale(0.5); opacity: 0; }
    70% { transform: scale(1.1); }
    100% { transform: scale(1); opacity: 1; }
}
.mw-nav-badge:not(:empty) {
    animation: mw-badgePop 0.3s ease-out;
}
.mw-nav-divider {
    height: 1px;
    background: var(--border-subtle, #F5F5F4);
    margin: 8px 16px;
}

/* ================================================================
   CONTENT AREA
   ================================================================ */
.mw-content {
    background: transparent;
    padding: 0;
    min-width: 0;
    overflow-y: auto;
}

/* Tab panels */
.mw-panel {
    display: none;
    animation: mwReveal 0.3s ease-out;
}
.mw-panel.active {
    display: block;
    animation: mw-fadeIn 0.25s ease-out;
}

/* Tab header */
.mw-tab-header {
    padding: 24px 32px 0;
}
.mw-tab-title {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 22px;
    font-weight: 700;
    color: var(--text-primary, #1E1E26);
    margin-bottom: 2px;
}
.mw-tab-subtitle {
    font-size: 14px;
    color: var(--text-secondary, #78716C);
    margin-bottom: 16px;
}

/* Tab toolbar */
.mw-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 32px 16px;
}
.mw-filters {
    display: flex;
    gap: 6px;
}
.mw-pill {
    padding: 5px 14px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    border: 1px solid var(--border-default, #E7E5E4);
    background: var(--bg-surface, #fff);
    color: var(--text-secondary, #78716C);
    cursor: pointer;
    font-family: var(--font-body);
}
.mw-pill.active {
    background: var(--text-primary, #1E1E26);
    color: #fff;
    border-color: var(--text-primary, #1E1E26);
}

/* ================================================================
   OVERVIEW TAB
   ================================================================ */
.mw-overview {
    padding: 28px 32px;
    animation: mw-fadeIn 0.3s ease-out;
}
@keyframes mw-fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.mw-greeting {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary, #1E1E26);
    margin-bottom: 4px;
}
.mw-greeting-sub {
    font-size: 14px;
    color: var(--text-secondary, #78716C);
    margin-bottom: 24px;
}

/* Stat cards */
.mw-stat-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 28px;
}
.mw-stat-card {
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: var(--radius-xl, 12px);
    padding: var(--space-6, 24px);
    cursor: pointer;
    transition: all 200ms ease;
    min-height: 120px;
}
.mw-stat-card:hover {
    border-color: var(--border-strong, #D6D3D1);
    box-shadow: var(--shadow-lg, 0 4px 16px rgba(44,36,22,0.08));
    transform: translateY(-2px);
}
.mw-stat-card:focus-visible,
.mw-ws-card:focus-visible,
.mw-quick-card:focus-visible {
    outline: 2px solid var(--mainsite-primary, #E54D4D);
    outline-offset: 2px;
}
.mw-stat-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
}
.mw-stat-icon .icon { width: 18px; height: 18px; }
.mw-stat-icon--fav { background: var(--mainsite-very-light, #FEF2F2); color: var(--mainsite-primary, #E54D4D); }
.mw-stat-icon--notes { background: var(--phase-plan-very-light, #F0F9FF); color: var(--phase-plan, #0284C7); }
.mw-stat-icon--ws { background: var(--phase-facilitate-very-light, #EDE9FE); color: var(--phase-facilitate, #7C4DFF); }
.mw-stat-icon--pub { background: var(--phase-reflect-very-light, #D1FAE5); color: var(--phase-reflect, #10B981); }
.mw-stat-val {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary, #1E1E26);
    line-height: 1;
}
.mw-stat-label {
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
    margin-top: 2px;
}

/* Activity feed */
.mw-section-title {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.mw-section-title a {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    color: var(--mainsite-primary, #E54D4D);
    text-decoration: none;
}
.mw-activity-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 28px;
}
.mw-activity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: 8px;
    font-size: 14px;
    transition: border-color 0.15s;
}
.mw-activity-item:hover { border-color: var(--border-strong, #D6D3D1); }
.mw-activity-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.mw-activity-dot--fav { background: var(--mainsite-primary, #E54D4D); }
.mw-activity-dot--note { background: var(--phase-plan, #0284C7); }
.mw-activity-dot--ws { background: var(--phase-facilitate, #7C4DFF); }
.mw-activity-dot--pub { background: var(--phase-reflect, #10B981); }
.mw-activity-text {
    flex: 1;
    color: var(--text-secondary, #78716C);
}
.mw-activity-text strong { color: var(--text-primary, #1E1E26); }
.mw-activity-time {
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
    white-space: nowrap;
}

/* Quick actions */
.mw-quick-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.mw-quick-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: 10px;
    text-decoration: none;
    color: var(--text-primary, #1E1E26);
    transition: border-color 0.15s, box-shadow 0.15s;
}
.mw-quick-card:hover {
    border-color: var(--mainsite-primary, #E54D4D);
    background: var(--bg-surface, #fff);
    box-shadow: 0 2px 8px rgba(229, 77, 77, 0.08);
    transform: translateY(-1px);
}
.mw-quick-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--mainsite-very-light, #FEF2F2);
    color: var(--mainsite-primary, #E54D4D);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.mw-quick-icon .icon { width: 18px; height: 18px; }
.mw-quick-text { font-size: 14px; font-weight: 600; }
.mw-quick-sub { font-size: 12px; color: var(--text-tertiary, #A8A29E); font-weight: 400; }

/* ================================================================
   WORKSHOPS TAB
   ================================================================ */
.mw-workshops-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 0 32px 32px;
}
.mw-ws-card {
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: var(--radius-xl, 12px);
    padding: var(--space-5, 20px);
    display: flex;
    flex-direction: column;
    gap: 10px;
    cursor: pointer;
    transition: all 200ms ease;
    min-height: 220px;
}
.mw-ws-card:hover {
    border-color: var(--border-strong, #D6D3D1);
    box-shadow: var(--shadow-lg, 0 4px 16px rgba(44,36,22,0.08));
    transform: translateY(-2px);
}
.mw-ws-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.mw-ws-title {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
}
.mw-ws-status {
    font-size: 10px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 100px;
    white-space: nowrap;
    flex-shrink: 0;
}
.mw-ws-status--private { background: var(--bg-page, #F5F5F4); color: var(--text-secondary, #78716C); }
.mw-ws-status--shared { background: var(--phase-plan-very-light, #F0F9FF); color: var(--phase-plan, #0284C7); }
.mw-ws-status--public { background: var(--phase-reflect-very-light, #D1FAE5); color: var(--phase-reflect, #10B981); }

.mw-ws-shared-badge {
    font-size: 10px;
    font-weight: 600;
    color: var(--phase-plan, #0284C7);
    background: color-mix(in srgb, var(--phase-plan, #0284C7) 10%, transparent);
    padding: 2px 8px;
    border-radius: 100px;
}

.mw-ws-meta {
    display: flex;
    gap: 14px;
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
}
.mw-ws-meta span { display: flex; align-items: center; gap: 3px; }
.mw-ws-meta .icon { width: 14px; height: 14px; }

.mw-ws-dots { display: flex; gap: 4px; }
.mw-ws-dot {
    width: 6px; height: 6px; border-radius: 50%;
}
.mw-ws-dot--exercise { background: #2563EB; }
.mw-ws-dot--icebreaker { background: #22C55E; }
.mw-ws-dot--custom { background: var(--text-tertiary, #A8A29E); }

.mw-ws-actions {
    display: flex;
    gap: 6px;
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid var(--border-subtle, #F5F5F4);
}
.mw-ws-action {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary, #78716C);
    display: flex;
    align-items: center;
    gap: 3px;
    cursor: pointer;
    padding: 3px 0;
    background: none;
    border: none;
    font-family: var(--font-body);
}
.mw-ws-action:hover { color: var(--mainsite-primary, #E54D4D); }
.mw-ws-action .icon { width: 14px; height: 14px; }

/* ================================================================
   PUBLISHED TAB
   ================================================================ */
.mw-pub-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 0 32px;
    margin-bottom: 20px;
}
.mw-pub-stat {
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: 10px;
    padding: 16px;
    text-align: center;
}
.mw-pub-stat-val {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 32px;
    font-weight: 700;
}
.mw-pub-stat-label {
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
    margin-top: 2px;
}

.mw-pub-list {
    padding: 0 32px 32px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.mw-pub-row {
    display: flex;
    align-items: center;
    gap: 16px;
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: var(--radius-xl, 12px);
    padding: var(--space-5, 20px);
    transition: all 200ms ease;
}
.mw-pub-row:hover {
    border-color: var(--border-strong, #D6D3D1);
    box-shadow: var(--shadow-lg, 0 4px 16px rgba(44,36,22,0.08));
}
.mw-pub-row--unpublished { opacity: 0.6; }
.mw-pub-info { flex: 1; min-width: 0; }
.mw-pub-name { font-weight: 600; font-size: 15px; margin-bottom: 3px; }
.mw-pub-meta {
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.mw-pub-meta span { display: flex; align-items: center; gap: 3px; }
.mw-pub-meta .icon { width: 14px; height: 14px; }
.mw-pub-status {
    font-size: 11px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 100px;
    flex-shrink: 0;
}
.mw-pub-status--live { background: var(--phase-reflect-very-light, #D1FAE5); color: var(--phase-reflect, #10B981); }
.mw-pub-status--unpublished { background: var(--bg-page, #F5F5F4); color: var(--text-secondary, #78716C); }
.mw-pub-actions {
    display: flex;
    gap: 4px;
}

/* ================================================================
   FAVORITES TAB
   ================================================================ */
.mw-fav-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 0 32px 32px;
}
.mw-fav-card {
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: var(--radius-xl, 12px);
    padding: var(--space-6, 24px);
    cursor: pointer;
    transition: all 200ms ease;
    position: relative;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    min-height: 180px;
}
.mw-fav-card:hover {
    border-color: var(--border-strong, #D6D3D1);
    box-shadow: var(--shadow-lg, 0 4px 16px rgba(44,36,22,0.08));
    transform: translateY(-2px);
}
.mw-fav-type {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 2px 7px;
    border-radius: 4px;
    display: inline-block;
    margin-bottom: 8px;
}
.mw-fav-type--exercise { background: #EFF6FF; color: #2563EB; }
.mw-fav-type--icebreaker { background: #F0FDF4; color: #22C55E; }
.mw-fav-type--workshop { background: var(--phase-facilitate-very-light, #EDE9FE); color: var(--phase-facilitate, #7C4DFF); }
.mw-fav-type--tip { background: #FEF3C7; color: #F59E0B; }
.mw-fav-title {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 4px;
    line-height: 1.3;
}
.mw-fav-desc {
    font-size: 13px;
    color: var(--text-secondary, #78716C);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mw-fav-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px solid var(--border-subtle, #F5F5F4);
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
}
.mw-fav-heart {
    position: absolute;
    top: 12px;
    right: 12px;
    color: var(--mainsite-primary, #E54D4D);
    cursor: pointer;
}
.mw-fav-heart .icon { width: 16px; height: 16px; }

/* ================================================================
   NOTES & COMMENTS TAB
   ================================================================ */
.mw-notes-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 0 32px 32px;
}
.mw-note-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: var(--space-6, 24px);
    min-height: 160px;
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: var(--radius-xl, 12px);
    text-decoration: none;
    color: inherit;
    transition: all 200ms ease;
}
.mw-note-card:hover {
    border-color: var(--border-strong, #D6D3D1);
    box-shadow: var(--shadow-lg, 0 4px 16px rgba(44,36,22,0.08));
    transform: translateY(-2px);
}
.mw-note-header {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
}
.mw-note-header strong { flex: 1; }
.mw-note-time {
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
}
.mw-note-body {
    font-size: 14px;
    color: var(--text-secondary, #78716C);
    line-height: 1.5;
}

/* ================================================================
   CONTRIBUTIONS TAB
   ================================================================ */
.mw-contrib-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    padding: 0 32px 16px;
}
.mw-contrib-card {
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: var(--radius-xl, 12px);
    padding: var(--space-5, 20px);
    transition: all 200ms ease;
}
.mw-contrib-card:hover {
    border-color: var(--border-strong, #D6D3D1);
}
.mw-contrib-top {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}
.mw-contrib-name { font-weight: 600; font-size: 15px; flex: 1; }
.mw-contrib-badge {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 2px 8px;
    border-radius: 4px;
}
.mw-contrib-badge--exercise { background: #EFF6FF; color: #2563EB; }
.mw-contrib-badge--icebreaker { background: #F0FDF4; color: #22C55E; }
.mw-contrib-status {
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 100px;
}
.mw-contrib-status--draft { background: var(--bg-page); color: var(--text-secondary); }
.mw-contrib-status--submitted { background: var(--phase-plan-very-light); color: var(--phase-plan); }
.mw-contrib-status--under_review { background: #FEF3C7; color: #F59E0B; }
.mw-contrib-status--approved { background: var(--phase-reflect-very-light); color: var(--phase-reflect); }
.mw-contrib-status--rejected { background: var(--mainsite-very-light); color: var(--mainsite-primary); }
.mw-contrib-meta {
    font-size: 12px;
    color: var(--text-tertiary, #A8A29E);
    margin-bottom: 4px;
}
.mw-contrib-overview {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mw-contrib-rejection {
    margin-top: 8px;
    padding: 8px 12px;
    background: var(--mainsite-very-light);
    border-radius: 6px;
    font-size: 13px;
    color: var(--mainsite-primary);
}
.mw-contrib-actions {
    display: flex;
    gap: 6px;
    margin-top: 8px;
}

/* ================================================================
   EMPTY STATES
   ================================================================ */
.mw-empty {
    text-align: center;
    padding: 48px 32px;
}
.mw-empty-icon {
    width: 56px;
    height: 56px;
    margin: 0 auto 16px;
    border-radius: 50%;
    background: var(--bg-page, #F5F5F4);
    display: flex;
    align-items: center;
    justify-content: center;
}
.mw-empty-icon .icon { width: 24px; height: 24px; color: var(--text-tertiary, #A8A29E); }
.mw-empty-title {
    font-family: var(--font-heading, 'Fraunces', serif);
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 6px;
}
.mw-empty-desc {
    font-size: 14px;
    color: var(--text-secondary, #78716C);
    max-width: 360px;
    margin: 0 auto 16px;
    line-height: 1.5;
}

/* ================================================================
   AUTH REQUIRED STATE
   ================================================================ */
.mw-auth-required {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 2rem;
    grid-column: 1 / -1;
}
.mw-auth-card {
    text-align: center;
    max-width: 400px;
}
.mw-auth-card h2 {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
}
.mw-auth-card p {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}
.mw-auth-buttons {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
}
.mw-auth-signin {
    background: none;
    border: none;
    font-size: 14px;
    color: var(--text-secondary);
    cursor: pointer;
    font-family: var(--font-body);
}

/* ================================================================
   LOADING STATE
   ================================================================ */
.mw-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    min-height: 50vh;
    color: var(--text-secondary);
    font-size: 15px;
    grid-column: 1 / -1;
}

/* ================================================================
   ICON BUTTONS (shared)
   ================================================================ */
.mw-icon-btn {
    width: 30px;
    height: 30px;
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: 6px;
    background: var(--bg-surface, #fff);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--text-tertiary, #A8A29E);
    transition: color 0.1s, border-color 0.1s;
}
.mw-icon-btn:hover {
    color: var(--text-primary, #1E1E26);
    border-color: var(--border-strong, #D6D3D1);
}
.mw-icon-btn .icon { width: 16px; height: 16px; }

/* ================================================================
   CONTRIBUTION SLIDE-IN PANEL
   ================================================================ */
.contribution-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.35);
    z-index: 999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
}
.contribution-overlay.open { opacity: 1; visibility: visible; }

.contribution-panel {
    position: fixed;
    top: 0;
    right: -480px;
    width: 480px;
    max-width: 100vw;
    height: 100vh;
    background: var(--bg-surface, #fff);
    z-index: 1000;
    overflow-y: auto;
    transition: right 0.25s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: -8px 0 32px rgba(0,0,0,0.1);
}
.contribution-panel.open { right: 0; }

.cp-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 24px 24px 16px;
    border-bottom: 1px solid var(--border-subtle);
}
.cp-title {
    font-family: var(--font-heading);
    font-size: 18px;
    font-weight: 700;
}
.cp-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
    margin-top: 2px;
}

.cp-type-switch {
    display: flex;
    gap: 8px;
    padding: 12px 24px;
}
.cp-type-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: 1px solid var(--border-default, #E7E5E4);
    border-radius: 100px;
    font-size: 13px;
    font-weight: 600;
    background: var(--bg-surface, #fff);
    color: var(--text-secondary, #78716C);
    cursor: pointer;
    font-family: var(--font-body);
    transition: all 0.15s;
}
.cp-type-btn .icon {
    width: 16px;
    height: 16px;
}
.cp-type-btn:hover {
    border-color: var(--border-strong, #D6D3D1);
    color: var(--text-primary, #1E1E26);
    background: var(--bg-secondary, #FAFAF9);
}
.cp-type-btn.active {
    background: var(--text-primary, #1E1E26);
    color: #fff;
    border-color: var(--text-primary, #1E1E26);
}
.cp-type-btn:focus-visible,
.mw-pill:focus-visible {
    outline: 2px solid var(--mainsite-primary, #E54D4D);
    outline-offset: 2px;
}

.cp-form { padding: 0 24px 24px; }
.cp-section { margin-bottom: 16px; }
.cp-field { margin-bottom: 12px; }
.cp-field label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 4px;
}
.cp-required { color: var(--mainsite-primary); }
.cp-field input, .cp-field textarea, .cp-field select {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--border-default);
    border-radius: 8px;
    font-size: 14px;
    font-family: var(--font-body);
    background: var(--bg-page-warm, #FEF7F1);
}
.cp-field input:focus, .cp-field textarea:focus, .cp-field select:focus {
    outline: none;
    border-color: var(--mainsite-primary);
    box-shadow: 0 0 0 3px var(--mainsite-very-light);
}
.cp-field-row { display: flex; gap: 12px; }
.cp-field-row .cp-field { flex: 1; }

.cp-accordion { border: 1px solid var(--border-default); border-radius: 8px; margin-bottom: 12px; }
.cp-accordion-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 12px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    color: var(--text-secondary);
    list-style: none;
}
.cp-accordion-toggle::-webkit-details-marker { display: none; }
.cp-accordion-body { padding: 0 12px 12px; }

.cp-actions {
    display: flex;
    justify-content: flex-end;
    padding-top: 12px;
    border-top: 1px solid var(--border-subtle);
}

/* ================================================================
   WELCOME BAR
   ================================================================ */
.mw-welcome {
    background: var(--bg-surface, #fff);
    border: 1px solid var(--border-default);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 24px;
    position: relative;
}
.mw-welcome-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
}
.mw-welcome h2 {
    font-family: var(--font-heading);
    font-size: 18px;
    font-weight: 700;
}
.mw-welcome p {
    font-size: 14px;
    color: var(--text-secondary);
}
.mw-welcome-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}
.mw-welcome-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    background: var(--bg-page-warm);
    border: 1px solid var(--border-default);
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s;
}
.mw-welcome-card:hover { border-color: var(--mainsite-primary); }
.mw-welcome-card strong { font-size: 14px; display: block; }
.mw-welcome-card span { font-size: 12px; color: var(--text-secondary); }

/* SVG icon via CSS mask */
.mw-svg-icon {
    display: inline-block;
    width: 20px;
    height: 20px;
    background-color: currentColor;
    -webkit-mask-image: var(--icon-url);
    mask-image: var(--icon-url);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
}

/* Note card description style */
.listing-card-description--note {
    font-style: italic;
    color: var(--text-secondary, #78716C);
}

/* Workshop context menu buttons */
.mw-menu-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.625rem 1rem;
    background: none;
    border: none;
    font-size: 0.875rem;
    font-family: inherit;
    cursor: pointer;
    border-radius: var(--radius-md, 6px);
    color: var(--text-primary, #1E1E26);
    transition: background 0.12s ease;
}
.mw-menu-btn:hover {
    background: var(--bg-secondary, #F5F5F4);
}
.mw-menu-btn:focus-visible {
    outline: 2px solid var(--mainsite-primary, #E54D4D);
    outline-offset: -2px;
}
.mw-menu-btn .icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}
.mw-menu-btn--danger {
    color: var(--mainsite-primary, #E54D4D);
}
.mw-menu-btn--danger:hover {
    background: color-mix(in srgb, var(--mainsite-primary, #E54D4D) 8%, transparent);
}

/* Increase listing card height within myworkshopr */
.mw-content .listing-card {
    padding: var(--space-6, 24px);
    min-height: 180px;
}

/* ================================================================
   REDUCED MOTION
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
    .mw-stat-card,
    .mw-ws-card,
    .mw-fav-card,
    .mw-note-card,
    .mw-contrib-card,
    .mw-pub-row,
    .mw-quick-card,
    .mw-dna-link,
    .mw-dna-link--cta,
    .mw-nav-item,
    .mw-profile-badge,
    .mw-welcome-card,
    .listing-card,
    .contribution-panel,
    .mw-overview,
    .mw-panel.active,
    .mw-nav-badge {
        transition: none !important;
        animation: none !important;
    }
    .mw-stat-card:hover,
    .mw-ws-card:hover,
    .mw-fav-card:hover,
    .mw-note-card:hover,
    .mw-quick-card:hover,
    .mw-dna-link:hover,
    .mw-welcome-card:hover,
    .mw-content .listing-card:hover {
        transform: none !important;
    }
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 960px) {
    .mw-layout { grid-template-columns: 1fr; }
    .mw-rail { display: none; }
    .mw-stat-row { grid-template-columns: repeat(2, 1fr); }
    .mw-workshops-grid { grid-template-columns: repeat(2, 1fr); }
    .mw-fav-grid { grid-template-columns: repeat(2, 1fr); }
    .mw-quick-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
    .mw-stat-row { grid-template-columns: 1fr; }
    .mw-fav-grid { grid-template-columns: 1fr; }
    .mw-pub-stats { grid-template-columns: 1fr; }
}
