/* ═══════════════════════════════════════════════════════════
   PROGETTAZIONE — Design System
   Mobile-first, professionale, moderno
   ═══════════════════════════════════════════════════════════ */

/* ─── CSS Variables ─── */
:root {
    /* Colori primari */
    --prog-primary: #4F46E5;
    --prog-primary-hover: #4338CA;
    --prog-primary-light: #EEF2FF;
    --prog-primary-50: #EEF2FF;
    --prog-primary-100: #E0E7FF;
    --prog-primary-500: #6366F1;
    --prog-primary-600: #4F46E5;
    --prog-primary-700: #4338CA;

    /* Colori neutri */
    --prog-gray-50: #F9FAFB;
    --prog-gray-100: #F3F4F6;
    --prog-gray-200: #E5E7EB;
    --prog-gray-300: #D1D5DB;
    --prog-gray-400: #9CA3AF;
    --prog-gray-500: #6B7280;
    --prog-gray-600: #4B5563;
    --prog-gray-700: #374151;
    --prog-gray-800: #1F2937;
    --prog-gray-900: #111827;

    /* Colori semantici */
    --prog-success: #059669;
    --prog-success-light: #ECFDF5;
    --prog-warning: #D97706;
    --prog-warning-light: #FFFBEB;
    --prog-danger: #DC2626;
    --prog-danger-light: #FEF2F2;
    --prog-info: #2563EB;
    --prog-info-light: #EFF6FF;

    /* Colori progetto/evento */
    --prog-progetto: #4F46E5;
    --prog-evento: #7C3AED;
    --prog-analisi: #0891B2;
    --prog-nota: #B45309;

    /* Priorità */
    --prog-alta: #DC2626;
    --prog-media: #D97706;
    --prog-bassa: #059669;

    /* Layout */
    --prog-sidebar-w: 260px;
    --prog-header-h: 64px;
    --prog-bottom-nav-h: 72px;
    --prog-radius: 12px;
    --prog-radius-sm: 8px;
    --prog-radius-xs: 6px;

    /* Shadow */
    --prog-shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --prog-shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
    --prog-shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
    --prog-shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
    --prog-shadow-xl: 0 20px 25px -5px rgba(0,0,0,0.1), 0 10px 10px -5px rgba(0,0,0,0.04);

    /* Transizioni */
    --prog-transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --prog-transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Font */
    --prog-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ─── Reset & Base ─── */
.prog-app *,
.prog-app *::before,
.prog-app *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.prog-app {
    font-family: var(--prog-font);
    font-size: 14px;
    line-height: 1.5;
    color: var(--prog-gray-800);
    background: var(--prog-gray-50);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.prog-app a { color: var(--prog-primary); text-decoration: none; }
.prog-app a:hover { color: var(--prog-primary-hover); }
.prog-app a.prog-btn { color: inherit; }
.prog-app a.prog-btn:hover { color: inherit; }
.prog-app a.prog-btn-primary,
.prog-app a.prog-btn-primary:hover,
.prog-app a.prog-btn-primary:visited { color: #fff !important; }
.prog-app a.prog-btn-danger,
.prog-app a.prog-btn-danger:hover,
.prog-app a.prog-btn-danger:visited { color: #fff !important; }
.prog-app a.prog-btn-success,
.prog-app a.prog-btn-success:hover,
.prog-app a.prog-btn-success:visited { color: #fff !important; }

/* ─── Layout: Mobile (default) ─── */
.prog-layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.prog-main {
    flex: 1;
    padding: 16px;
    padding-bottom: calc(var(--prog-bottom-nav-h) + 24px);
    max-width: 100%;
    overflow-x: hidden;
}

.prog-main--full {
    margin-left: 0 !important;
    width: 100% !important;
    max-width: 100vw !important;
    padding: 0 !important;
    min-height: 100vh;
}

/* ─── Header Mobile ─── */
.prog-header-mobile {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: #fff;
    border-bottom: 1px solid var(--prog-gray-200);
    position: sticky;
    top: 0;
    z-index: 100;
}

.prog-header-mobile__logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: 18px;
    color: var(--prog-gray-900);
}

.prog-header-mobile__logo svg {
    width: 28px;
    height: 28px;
    color: var(--prog-primary);
}

.prog-header-mobile__actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.prog-header-mobile__user {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--prog-gray-200);
}

.prog-header-mobile__user img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ─── Bottom Navigation (Mobile) ─── */
.prog-bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
    border-top: 1px solid var(--prog-gray-200);
    display: flex;
    align-items: stretch;
    justify-content: space-around;
    height: var(--prog-bottom-nav-h);
    z-index: 100;
    padding-bottom: env(safe-area-inset-bottom, 0);
    box-shadow: 0 -2px 10px rgba(0,0,0,0.05);
}

.prog-bottom-nav__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    gap: 2px;
    padding: 8px 4px;
    color: var(--prog-gray-400);
    font-size: 10px;
    font-weight: 500;
    text-decoration: none;
    transition: color var(--prog-transition);
    position: relative;
}

.prog-bottom-nav__item svg {
    width: 22px;
    height: 22px;
    transition: transform var(--prog-transition);
}

.prog-bottom-nav__item.active {
    color: var(--prog-primary);
}

.prog-bottom-nav__item.active svg {
    transform: scale(1.1);
}

.prog-bottom-nav__item--new {
    color: #fff !important;
}

.prog-bottom-nav__item--new .prog-bottom-nav__icon-wrap {
    background: var(--prog-primary);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: -20px;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.4);
}

.prog-bottom-nav__item--new svg {
    color: #fff;
}

.prog-bottom-nav__badge {
    position: absolute;
    top: 4px;
    right: calc(50% - 18px);
    background: var(--prog-danger);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    min-width: 16px;
    height: 16px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
}

/* Link Note in home dashboard → stessa home con #prog-dashboard-note */
.prog-dash-home-note-link {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: #FFFBEB;
    border: 1px solid #FDE68A;
    border-radius: var(--prog-radius);
    text-decoration: none;
    color: var(--prog-gray-900);
    transition: box-shadow var(--prog-transition), border-color var(--prog-transition);
}
.prog-dash-home-note-link:hover {
    border-color: var(--prog-nota, #B45309);
    box-shadow: var(--prog-shadow);
}
.prog-dash-home-note-link__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: #FEF3C7;
    color: var(--prog-nota, #B45309);
    display: flex;
    align-items: center;
    justify-content: center;
}
.prog-dash-home-note-link__icon svg {
    width: 24px;
    height: 24px;
}
.prog-dash-home-note-link__text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.prog-dash-home-note-link__title {
    font-weight: 700;
    font-size: 16px;
}
.prog-dash-home-note-link__desc {
    font-size: 12px;
    color: var(--prog-gray-500);
}
.prog-dash-home-note-link__arrow {
    flex-shrink: 0;
    color: var(--prog-gray-400);
}
.prog-dash-home-note-link:hover .prog-dash-home-note-link__arrow {
    color: var(--prog-nota, #B45309);
}

/* ─── Sidebar (Desktop) ─── */
.prog-sidebar {
    display: none;
    width: var(--prog-sidebar-w);
    background: #fff;
    border-right: 1px solid var(--prog-gray-200);
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 90;
    overflow-y: auto;
    flex-shrink: 0;
}

.prog-sidebar__header {
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--prog-gray-100);
}

/* Divisore sidebar (solo desktop; nascosto su mobile) */
.prog-layout-resizer {
    display: none;
}

.prog-sidebar__logo {
    width: 36px;
    height: 36px;
    background: var(--prog-primary);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.prog-sidebar__logo svg { width: 20px; height: 20px; }

.prog-sidebar__title {
    font-weight: 700;
    font-size: 16px;
    color: var(--prog-gray-900);
}

.prog-sidebar__nav {
    padding: 12px;
    padding-bottom: 80px;
    overflow-y: auto;
    flex: 1;
}

.prog-sidebar__section-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--prog-gray-400);
    padding: 16px 12px 6px;
}

.prog-sidebar__link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: var(--prog-radius-sm);
    color: var(--prog-gray-600);
    font-size: 14px;
    font-weight: 500;
    transition: all var(--prog-transition);
    text-decoration: none;
    position: relative;
}

.prog-sidebar__link svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    opacity: 0.7;
}

.prog-sidebar__link:hover {
    background: var(--prog-gray-50);
    color: var(--prog-gray-900);
}

.prog-sidebar__link.active {
    background: var(--prog-primary-light);
    color: var(--prog-primary);
    font-weight: 600;
}

.prog-sidebar__link.active svg {
    opacity: 1;
}

.prog-sidebar__link--new {
    background: var(--prog-primary) !important;
    color: #fff !important;
    margin: 8px 0;
    justify-content: center;
    font-weight: 600 !important;
}

.prog-sidebar__link--new:hover {
    background: var(--prog-primary-hover) !important;
    color: #fff !important;
}

.prog-sidebar__link--new svg { opacity: 1 !important; }

.prog-sidebar__link-badge {
    margin-left: auto;
    background: var(--prog-danger);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    min-width: 20px;
    height: 20px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
}

.prog-sidebar__user {
    padding: 16px 20px;
    border-top: 1px solid var(--prog-gray-100);
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: auto;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
}

.prog-sidebar__user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
}

.prog-sidebar__user-avatar img { width: 100%; height: 100%; object-fit: cover; }

.prog-sidebar__user-info {
    flex: 1;
    min-width: 0;
}

.prog-sidebar__user-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.prog-sidebar__user-role {
    font-size: 11px;
    color: var(--prog-gray-400);
}

.prog-sidebar__logout {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    color: var(--prog-gray-400);
    transition: all 0.2s;
    flex-shrink: 0;
    text-decoration: none;
}
.prog-sidebar__logout:hover {
    background: var(--prog-danger-light);
    color: var(--prog-danger);
}
.prog-sidebar__logout svg {
    width: 18px;
    height: 18px;
}

/* ─── Sidebar Bookmarks ─── */
.prog-sidebar-bookmarks {
    margin-top: 8px;
    border-radius: var(--prog-radius-xs);
    border: 1px solid var(--prog-gray-100);
    overflow: hidden;
}
.prog-sidebar-bookmarks__header {
    display: flex;
    align-items: center;
    background: var(--prog-gray-50);
    padding: 6px 8px;
}
.prog-sidebar-bookmarks__toggle {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: var(--prog-gray-700);
    text-align: left;
}
.prog-sidebar-bookmarks__toggle:hover { color: var(--prog-primary); }
.prog-sidebar-bookmarks__icon { width: 16px; height: 16px; flex-shrink: 0; }
.prog-sidebar-bookmarks__chevron {
    margin-left: auto;
    transition: transform var(--prog-transition);
}
.prog-sidebar-bookmarks[data-expanded="true"] .prog-sidebar-bookmarks__chevron { transform: rotate(180deg); }
.prog-sidebar-bookmarks__add {
    width: 28px; height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 0;
    background: var(--prog-primary);
    color: #fff;
    border-radius: 6px;
    cursor: pointer;
    transition: background var(--prog-transition);
}
.prog-sidebar-bookmarks__add:hover { background: var(--prog-primary-hover); }
.prog-sidebar-bookmarks__body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.25s ease;
}
.prog-sidebar-bookmarks[data-expanded="true"] .prog-sidebar-bookmarks__body { max-height: 400px; }
.prog-sidebar-bookmarks__loading,
.prog-sidebar-bookmarks__empty {
    padding: 12px;
    font-size: 12px;
    color: var(--prog-gray-500);
}
.prog-sidebar-bookmarks__list {
    max-height: 280px;
    overflow-y: auto;
    padding: 4px;
}
.prog-sidebar-bm-cat {
    margin-bottom: 6px;
}
.prog-sidebar-bm-cat__label {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--prog-gray-400);
    padding: 4px 8px;
}
.prog-sidebar-bm-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-radius: 6px;
    transition: background var(--prog-transition);
}
.prog-sidebar-bm-item:hover { background: var(--prog-gray-50); }
.prog-sidebar-bm-item__thumb {
    width: 36px;
    height: 26px;
    border-radius: 4px;
    object-fit: cover;
    flex-shrink: 0;
}
.prog-sidebar-bm-item__thumb.fallback {
    background: var(--prog-gray-100);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
}
.prog-sidebar-bm-item__info {
    flex: 1;
    min-width: 0;
}
.prog-sidebar-bm-item__title {
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.prog-sidebar-bm-item__actions {
    display: flex;
    gap: 2px;
    flex-shrink: 0;
}
.prog-sidebar-bm-item__actions button {
    width: 24px; height: 24px;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--prog-gray-400);
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.prog-sidebar-bm-item__actions button:hover { color: var(--prog-primary); background: var(--prog-gray-50); }
.prog-sidebar-bm-item__actions button.delete:hover { color: var(--prog-danger); }
.prog-sidebar-bm-preview {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px;
    background: var(--prog-gray-50);
    border-radius: 8px;
}
.prog-sidebar-bm-preview img {
    width: 60px;
    height: 42px;
    object-fit: cover;
    border-radius: 6px;
}
.prog-sidebar-bm-preview__text { font-size: 12px; color: var(--prog-gray-600); }
}

/* ─── User Dropdown (Mobile) ─── */
.prog-user-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    min-width: 200px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.05);
    z-index: 1000;
    overflow: hidden;
    animation: prog-dropdown-in 0.15s ease-out;
}
.prog-user-dropdown.active {
    display: block;
}
@keyframes prog-dropdown-in {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}
.prog-user-dropdown__info {
    padding: 14px 16px;
}
.prog-user-dropdown__name {
    font-size: 14px;
    font-weight: 600;
    color: var(--prog-gray-800);
}
.prog-user-dropdown__role {
    font-size: 12px;
    color: var(--prog-gray-400);
    margin-top: 2px;
}
.prog-user-dropdown__divider {
    height: 1px;
    background: var(--prog-gray-100);
}
.prog-user-dropdown__item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    font-size: 14px;
    color: var(--prog-gray-600);
    text-decoration: none;
    transition: background 0.15s;
}
.prog-user-dropdown__item:hover {
    background: var(--prog-gray-50);
}
.prog-user-dropdown__item--logout {
    color: var(--prog-danger);
}
.prog-user-dropdown__item--logout:hover {
    background: var(--prog-danger-light);
}
.prog-user-dropdown__item svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.prog-header-mobile__actions {
    position: relative;
}

/* ─── Page Header ─── */
.prog-page-header {
    margin-bottom: 24px;
}

.prog-page-header__title {
    font-size: 24px;
    font-weight: 800;
    color: var(--prog-gray-900);
    line-height: 1.2;
}

.prog-page-header__subtitle {
    font-size: 14px;
    color: var(--prog-gray-500);
    margin-top: 4px;
}

/* ─── Card System ─── */
.prog-card {
    background: #fff;
    border-radius: var(--prog-radius);
    border: 1px solid var(--prog-gray-200);
    overflow: hidden;
    transition: box-shadow var(--prog-transition);
}

.prog-card:hover {
    box-shadow: var(--prog-shadow-md);
}

.prog-card__header {
    padding: 16px;
    border-bottom: 1px solid var(--prog-gray-100);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.prog-card__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--prog-gray-800);
}

.prog-card__body {
    padding: 16px;
}

.prog-card__footer {
    padding: 12px 16px;
    border-top: 1px solid var(--prog-gray-100);
    background: var(--prog-gray-50);
}

/* ─── Task drag & drop ─── */
.prog-task-row.prog-task-dragging {
    opacity: 0.5;
}

.prog-task-row.prog-task-drop-over {
    box-shadow: 0 0 0 2px var(--prog-primary);
}

.prog-task-drag-handle:active {
    cursor: grabbing;
}

/* ─── Stat Cards ─── */
.prog-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 24px;
}

.prog-stat {
    background: #fff;
    border-radius: var(--prog-radius);
    border: 1px solid var(--prog-gray-200);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.prog-stat__icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.prog-stat__icon svg { width: 20px; height: 20px; }

.prog-stat__icon--primary { background: var(--prog-primary-light); color: var(--prog-primary); }
.prog-stat__icon--success { background: var(--prog-success-light); color: var(--prog-success); }
.prog-stat__icon--warning { background: var(--prog-warning-light); color: var(--prog-warning); }
.prog-stat__icon--info    { background: var(--prog-info-light); color: var(--prog-info); }
.prog-stat__icon--evento  { background: #F5F3FF; color: var(--prog-evento); }

.prog-stat__value {
    font-size: 28px;
    font-weight: 800;
    color: var(--prog-gray-900);
    line-height: 1;
}

.prog-stat__label {
    font-size: 12px;
    color: var(--prog-gray-500);
    font-weight: 500;
}

/* ─── Buttons ─── */
.prog-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: var(--prog-radius-sm);
    font-family: var(--prog-font);
    font-size: 14px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all var(--prog-transition);
    line-height: 1.4;
    text-decoration: none;
    white-space: nowrap;
}

.prog-btn svg { width: 16px; height: 16px; }

.prog-btn-primary,
a.prog-btn-primary,
a.prog-btn-primary:visited,
a.prog-btn-primary:link {
    background: var(--prog-primary);
    color: #fff !important;
    box-shadow: 0 1px 2px rgba(79,70,229,0.3);
}
.prog-btn-primary:hover,
a.prog-btn-primary:hover {
    background: var(--prog-primary-hover);
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(79,70,229,0.3);
}

.prog-btn-secondary {
    background: #fff;
    color: var(--prog-gray-700);
    border: 1px solid var(--prog-gray-300);
}
.prog-btn-secondary:hover {
    background: var(--prog-gray-50);
    border-color: var(--prog-gray-400);
}

.prog-btn-ghost {
    background: transparent;
    color: var(--prog-gray-600);
    padding: 8px 12px;
}
.prog-btn-ghost:hover {
    background: var(--prog-gray-100);
    color: var(--prog-gray-800);
}

.prog-btn-danger {
    background: var(--prog-danger);
    color: #fff;
}
.prog-btn-danger:hover { background: #B91C1C; color: #fff; }

.prog-btn-success {
    background: var(--prog-success);
    color: #fff;
}
.prog-btn-success:hover { background: #047857; color: #fff; }

.prog-btn-sm { padding: 6px 12px; font-size: 13px; }
.prog-btn-lg { padding: 14px 28px; font-size: 16px; }
.prog-btn-block { width: 100%; }
.prog-btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

/* ─── Three Doors (Nuovo) ─── */
.prog-doors {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 800px;
    margin: 0 auto;
}

.prog-door {
    background: #fff;
    border-radius: var(--prog-radius);
    border: 2px solid var(--prog-gray-200);
    padding: 24px;
    text-align: center;
    cursor: pointer;
    transition: all var(--prog-transition-slow);
    text-decoration: none;
    display: block;
    color: inherit;
    box-sizing: border-box;
}

.prog-door:hover {
    transform: translateY(-4px);
    box-shadow: var(--prog-shadow-lg);
}

.prog-door--analisi { border-color: transparent; }
.prog-door--analisi:hover { border-color: var(--prog-analisi); background: #F0FDFA; }
.prog-door--progetto { border-color: transparent; }
.prog-door--progetto:hover { border-color: var(--prog-progetto); background: var(--prog-primary-light); }
.prog-door--evento { border-color: transparent; }
.prog-door--evento:hover { border-color: var(--prog-evento); background: #F5F3FF; }
.prog-door--nota { border-color: transparent; }
.prog-door--nota:hover { border-color: var(--prog-nota); background: #FFFBEB; }

.prog-door__icon {
    width: 64px;
    height: 64px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
}

.prog-door__icon svg { width: 32px; height: 32px; }

.prog-door--analisi .prog-door__icon  { background: #CCFBF1; color: var(--prog-analisi); }
.prog-door--progetto .prog-door__icon { background: var(--prog-primary-100); color: var(--prog-progetto); }
.prog-door--evento .prog-door__icon   { background: #EDE9FE; color: var(--prog-evento); }
.prog-door--nota .prog-door__icon     { background: #FEF3C7; color: var(--prog-nota); }

.prog-door__title {
    font-size: 18px;
    font-weight: 700;
    color: var(--prog-gray-900);
    margin-bottom: 8px;
}

.prog-door__desc {
    font-size: 13px;
    color: var(--prog-gray-500);
    line-height: 1.6;
}

/* ─── Form Elements ─── */
.prog-form-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 24px;
}
@media (max-width: 480px) {
    .prog-form-grid-2 { grid-template-columns: 1fr; }
}
.prog-form-group {
    margin-bottom: 20px;
}
.prog-form-grid-2 .prog-form-group {
    margin-bottom: 0;
}

.prog-form-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-700);
    margin-bottom: 6px;
}

.prog-form-input,
.prog-form-textarea,
.prog-form-select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--prog-gray-300);
    border-radius: var(--prog-radius-sm);
    font-family: var(--prog-font);
    font-size: 14px;
    color: var(--prog-gray-800);
    background: #fff;
    transition: border-color var(--prog-transition), box-shadow var(--prog-transition);
    outline: none;
}

.prog-form-input:focus,
.prog-form-textarea:focus,
.prog-form-select:focus {
    border-color: var(--prog-primary);
    box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}

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

.prog-form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

.prog-form-hint {
    font-size: 12px;
    color: var(--prog-gray-400);
    margin-top: 4px;
}

/* ─── Rich text editor (Obiettivo, Descrizione) ─── */
.prog-rich-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 2px;
    padding: 6px 8px;
    background: var(--prog-gray-100);
    border: 1px solid var(--prog-gray-300);
    border-bottom: none;
    border-radius: var(--prog-radius-sm) var(--prog-radius-sm) 0 0;
}
.prog-tb-btn {
    width: 32px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--prog-gray-600);
    font-size: 14px;
    cursor: pointer;
    transition: background var(--prog-transition), color var(--prog-transition);
}
.prog-tb-btn:hover {
    background: var(--prog-gray-200);
    color: var(--prog-gray-800);
}
.prog-tb-sep {
    width: 1px;
    height: 18px;
    background: var(--prog-gray-300);
    margin: 0 4px;
}
.prog-rich-editor {
    min-height: 60px;
    padding: 10px 14px;
    border: 1px solid var(--prog-gray-300);
    border-radius: 0 0 var(--prog-radius-sm) var(--prog-radius-sm);
    outline: none;
    overflow-y: auto;
}
.prog-rich-editor:empty::before {
    content: attr(data-placeholder);
    color: var(--prog-gray-400);
}
.prog-rich-editor:focus {
    border-color: var(--prog-primary);
    box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}
.prog-edit-view .prog-editor-img,
.prog-rich-editor .prog-editor-img {
    max-width: 100%;
    height: auto;
    display: block;
}
.prog-edit-view .prog-editor-video,
.prog-rich-editor .prog-editor-video {
    max-width: 100%;
    display: block;
}

/* ─── Badges / Tags ─── */
.prog-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.4;
}

.prog-badge--fase-idea           { background: #F0F9FF; color: #0369A1; }
.prog-badge--fase-pianificazione { background: #FFFBEB; color: #B45309; }
.prog-badge--fase-esecuzione     { background: #ECFDF5; color: #047857; }
.prog-badge--fase-revisione      { background: #FEF3C7; color: #92400E; }
.prog-badge--fase-archiviato     { background: var(--prog-gray-100); color: var(--prog-gray-500); }

.prog-badge--priorita-alta  { background: #FEF2F2; color: var(--prog-alta); }
.prog-badge--priorita-media { background: #FFFBEB; color: var(--prog-media); }
.prog-badge--priorita-bassa { background: #ECFDF5; color: var(--prog-bassa); }

.prog-badge--stato-da_fare      { background: var(--prog-gray-100); color: var(--prog-gray-600); }
.prog-badge--stato-in_corso     { background: #DBEAFE; color: #1D4ED8; }
.prog-badge--stato-in_revisione { background: #FEF3C7; color: #92400E; }
.prog-badge--stato-completato   { background: #ECFDF5; color: #047857; }

.prog-badge--tipo-progetto { background: var(--prog-primary-light); color: var(--prog-progetto); }
.prog-badge--tipo-evento   { background: #F5F3FF; color: var(--prog-evento); }

/* ─── Progress Bar ─── */
.prog-progress {
    width: 100%;
    height: 6px;
    background: var(--prog-gray-200);
    border-radius: 3px;
    overflow: hidden;
}

.prog-progress__bar {
    height: 100%;
    background: var(--prog-primary);
    border-radius: 3px;
    transition: width var(--prog-transition-slow);
}

.prog-progress__bar--success { background: var(--prog-success); }
.prog-progress__bar--warning { background: var(--prog-warning); }
.prog-progress__bar--danger  { background: var(--prog-danger); }

/* ─── Project / Event List ─── */
.prog-project-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.prog-project-card {
    background: #fff;
    border-radius: var(--prog-radius);
    border: 1px solid var(--prog-gray-200);
    padding: 16px;
    cursor: pointer;
    transition: all var(--prog-transition);
    text-decoration: none;
    display: block;
    color: inherit;
}

.prog-project-card:hover {
    border-color: var(--prog-primary);
    box-shadow: var(--prog-shadow-md);
    color: inherit;
}

.prog-project-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 10px;
}

.prog-project-card__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--prog-gray-900);
}

.prog-project-card__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: var(--prog-gray-500);
    margin-top: 8px;
}

.prog-project-card__meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.prog-project-card__meta-item svg {
    width: 14px;
    height: 14px;
}

.prog-project-card__progress {
    margin-top: 12px;
}

.prog-project-card__progress-text {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--prog-gray-500);
    margin-bottom: 4px;
}

/* ─── Kanban Board ─── */
.prog-kanban {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 16px;
    -webkit-overflow-scrolling: touch;
}

.prog-kanban__column {
    min-width: 280px;
    max-width: 320px;
    flex-shrink: 0;
    background: var(--prog-gray-100);
    border-radius: var(--prog-radius);
    padding: 12px;
}

.prog-kanban__column-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 4px;
    margin-bottom: 8px;
}

.prog-kanban__column-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    display: flex;
    align-items: center;
    gap: 8px;
}

.prog-kanban__column-count {
    background: var(--prog-gray-300);
    color: var(--prog-gray-700);
    font-size: 11px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Kanban Cards container (drop zone) ── */
.prog-kanban__cards {
    min-height: 60px;
    padding: 4px 0;
    border-radius: var(--prog-radius-sm);
    transition: background 0.2s, border-color 0.2s;
    border: 2px dashed transparent;
}

.prog-kanban__cards--drop-target {
    border-color: var(--prog-gray-300);
    background: var(--prog-gray-50, #F9FAFB);
}

.prog-kanban__cards--drag-over {
    border-color: var(--prog-primary);
    background: var(--prog-primary-light, #EEF2FF);
}

/* ── Kanban Card ── */
button.prog-kanban__card,
.prog-kanban__card {
    background: #fff;
    border-radius: var(--prog-radius-sm);
    padding: 12px;
    margin-bottom: 8px;
    border: 1px solid var(--prog-gray-200);
    cursor: grab;
    transition: all var(--prog-transition), opacity 0.2s;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    color: inherit;
    display: block;
    -webkit-appearance: none;
    appearance: none;
    user-select: none;
    -webkit-user-select: none;
}

.prog-kanban__card:active {
    cursor: grabbing;
}

.prog-kanban__card--dragging {
    opacity: 0.4;
    transform: rotate(2deg);
    box-shadow: var(--prog-shadow-lg);
}

.prog-kanban__card:hover {
    box-shadow: var(--prog-shadow-md);
    border-color: var(--prog-primary-500);
}

.prog-kanban__card-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-800);
    margin-bottom: 8px;
}

.prog-kanban__card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.prog-kanban__card-assignee {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--prog-gray-500);
}

.prog-kanban__card-assignee img {
    width: 22px;
    height: 22px;
    border-radius: 50%;
}

.prog-kanban__card-date {
    font-size: 11px;
    color: var(--prog-gray-400);
    display: flex;
    align-items: center;
    gap: 3px;
}

.prog-kanban__card-date svg { width: 12px; height: 12px; }

.prog-kanban__add-btn {
    width: 100%;
    padding: 10px;
    border: 2px dashed var(--prog-gray-300);
    border-radius: var(--prog-radius-sm);
    background: transparent;
    color: var(--prog-gray-400);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--prog-transition);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-family: var(--prog-font);
}

.prog-kanban__add-btn:hover {
    border-color: var(--prog-primary);
    color: var(--prog-primary);
    background: var(--prog-primary-light);
}

/* ─── Tabs ─── */
.prog-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--prog-gray-200);
    margin-bottom: 20px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.prog-tabs::-webkit-scrollbar { display: none; }

.prog-tab {
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-500);
    white-space: nowrap;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all var(--prog-transition);
    background: none;
    border-left: none;
    border-right: none;
    border-top: none;
    font-family: var(--prog-font);
}

.prog-tab:hover { color: var(--prog-gray-700); }

.prog-tab.active {
    color: var(--prog-primary);
    border-bottom-color: var(--prog-primary);
}

.prog-tab-content {
    display: none;
}

.prog-tab-content.active {
    display: block;
}

/* ─── Modal / Slide Panel ─── */
.prog-modal-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.4);
    z-index: 1000;
    display: none;
    align-items: flex-end;
    justify-content: center;
    backdrop-filter: blur(2px);
}

.prog-modal-overlay.active { display: flex; }

.prog-modal {
    background: #fff;
    border-radius: var(--prog-radius) var(--prog-radius) 0 0;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    animation: prog-slide-up 0.3s ease;
}

@keyframes prog-slide-up {
    from { transform: translateY(100%); }
    to   { transform: translateY(0); }
}

.prog-modal__header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--prog-gray-200);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
}

.prog-modal__title {
    font-size: 17px;
    font-weight: 700;
    color: var(--prog-gray-900);
}

.prog-modal__close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: var(--prog-gray-100);
    color: var(--prog-gray-500);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--prog-transition);
}

.prog-modal__close:hover { background: var(--prog-gray-200); }

.prog-modal__body {
    padding: 20px;
}

.prog-modal__footer {
    padding: 16px 20px;
    border-top: 1px solid var(--prog-gray-200);
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    position: sticky;
    bottom: 0;
    background: #fff;
}

/* ─── AI Analysis Report ─── */
.prog-ai-report {
    background: linear-gradient(135deg, #F0FDFA, #ECFDF5);
    border: 1px solid #99F6E4;
    border-radius: var(--prog-radius);
    padding: 20px;
    margin-top: 20px;
}

.prog-ai-report__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.prog-ai-report__header svg { width: 24px; height: 24px; color: var(--prog-analisi); }

.prog-ai-report__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--prog-gray-900);
}

.prog-ai-section {
    background: #fff;
    border-radius: var(--prog-radius-sm);
    padding: 14px;
    margin-bottom: 12px;
    border: 1px solid var(--prog-gray-200);
}

.prog-ai-section__title {
    font-size: 13px;
    font-weight: 700;
    color: var(--prog-gray-700);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.prog-ai-section__content {
    font-size: 13px;
    color: var(--prog-gray-600);
    line-height: 1.7;
}

.prog-ai-score {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.prog-ai-score__item {
    flex: 1;
    min-width: 100px;
    text-align: center;
    padding: 12px;
    background: #fff;
    border-radius: var(--prog-radius-sm);
    border: 1px solid var(--prog-gray-200);
}

.prog-ai-score__value {
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
}

.prog-ai-score__value--good { color: var(--prog-success); }
.prog-ai-score__value--ok   { color: var(--prog-warning); }
.prog-ai-score__value--bad  { color: var(--prog-danger); }

.prog-ai-score__label {
    font-size: 11px;
    color: var(--prog-gray-500);
    margin-top: 4px;
    font-weight: 600;
}

.prog-ai-verdict {
    background: var(--prog-gray-800);
    color: #fff;
    border-radius: var(--prog-radius-sm);
    padding: 16px;
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.7;
}

.prog-ai-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}

/* ─── Idea Card (Parcheggio) ─── */
.prog-idea-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.prog-idea-card {
    background: #fff;
    border-radius: var(--prog-radius);
    border: 1px solid var(--prog-gray-200);
    padding: 16px;
    transition: all var(--prog-transition);
}

.prog-idea-card:hover {
    box-shadow: var(--prog-shadow-md);
}

.prog-idea-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
}

.prog-idea-card__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--prog-gray-900);
}

.prog-idea-card__scores {
    display: flex;
    gap: 6px;
}

.prog-idea-card__score {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
}

.prog-idea-card__author {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--prog-gray-500);
    margin-bottom: 12px;
}

.prog-idea-card__author img {
    width: 20px;
    height: 20px;
    border-radius: 50%;
}

.prog-idea-card__actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

/* ─── Loading / Spinner ─── */
.prog-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px;
    color: var(--prog-gray-400);
    gap: 12px;
}

.prog-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--prog-gray-200);
    border-top-color: var(--prog-primary);
    border-radius: 50%;
    animation: prog-spin 0.8s linear infinite;
}

@keyframes prog-spin {
    to { transform: rotate(360deg); }
}

.prog-loading-text {
    font-size: 13px;
    font-weight: 500;
}

/* ─── Empty State ─── */
.prog-empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--prog-gray-400);
}

.prog-empty__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    background: var(--prog-gray-100);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.prog-empty__icon svg { width: 28px; height: 28px; }

.prog-empty__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--prog-gray-700);
    margin-bottom: 4px;
}

.prog-empty__text {
    font-size: 13px;
    margin-bottom: 16px;
}

/* ─── Toast Notifications ─── */
.prog-toast-container {
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.prog-toast {
    background: var(--prog-gray-800);
    color: #fff;
    padding: 12px 20px;
    border-radius: var(--prog-radius-sm);
    font-size: 13px;
    font-weight: 500;
    box-shadow: var(--prog-shadow-lg);
    animation: prog-toast-in 0.3s ease;
    display: flex;
    align-items: center;
    gap: 8px;
    max-width: 350px;
}

.prog-toast--success { background: var(--prog-success); }
.prog-toast--error   { background: var(--prog-danger); }
.prog-toast--warning { background: var(--prog-warning); }

@keyframes prog-toast-in {
    from { opacity: 0; transform: translateY(-10px) scale(0.95); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ─── Wizard Steps ─── */
.prog-wizard {
    max-width: 600px;
    margin: 0 auto;
}

.prog-wizard__steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 32px;
    padding: 0 16px;
}

.prog-wizard__step {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    color: var(--prog-gray-400);
}

.prog-wizard__step-num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--prog-gray-200);
    color: var(--prog-gray-500);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
}

.prog-wizard__step.active .prog-wizard__step-num {
    background: var(--prog-primary);
    color: #fff;
}

.prog-wizard__step.completed .prog-wizard__step-num {
    background: var(--prog-success);
    color: #fff;
}

.prog-wizard__step.active { color: var(--prog-primary); }
.prog-wizard__step.completed { color: var(--prog-success); }

.prog-wizard__step-line {
    width: 32px;
    height: 2px;
    background: var(--prog-gray-200);
    margin: 0 4px;
}

.prog-wizard__step-line.completed { background: var(--prog-success); }

.prog-wizard__step-label {
    display: none;
}

.prog-wizard__panel {
    display: none;
}

.prog-wizard__panel.active {
    display: block;
}

.prog-wizard__content {
    background: #fff;
    border-radius: var(--prog-radius);
    border: 1px solid var(--prog-gray-200);
    padding: 24px;
}

.prog-wizard__footer {
    display: flex;
    justify-content: space-between;
    margin-top: 24px;
    gap: 12px;
}

/* ─── Utility Classes ─── */
.prog-flex   { display: flex; }
.prog-grid   { display: grid; }
.prog-gap-8  { gap: 8px; }
.prog-gap-12 { gap: 12px; }
.prog-gap-16 { gap: 16px; }
.prog-items-center { align-items: center; }
.prog-justify-between { justify-content: space-between; }
.prog-text-center { text-align: center; }
.prog-text-sm { font-size: 13px; }
.prog-text-xs { font-size: 12px; }
.prog-text-muted { color: var(--prog-gray-500); }
.prog-font-bold { font-weight: 700; }
.prog-mt-8  { margin-top: 8px; }
.prog-mt-16 { margin-top: 16px; }
.prog-mt-24 { margin-top: 24px; }
.prog-mb-8  { margin-bottom: 8px; }
.prog-mb-16 { margin-bottom: 16px; }
.prog-mb-24 { margin-bottom: 24px; }
.prog-hidden { display: none !important; }

/* ─── Login Page ─── */
.prog-login-required {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--prog-primary-50) 0%, #f8f9ff 50%, var(--prog-gray-50) 100%);
    padding: 20px;
}

.prog-login-box {
    background: #fff;
    border-radius: 20px;
    padding: 40px 36px;
    text-align: center;
    max-width: 420px;
    width: 100%;
    box-shadow: 0 4px 32px rgba(79,70,229,0.08), 0 0 0 1px rgba(0,0,0,0.04);
}

.prog-login-logo {
    margin-bottom: 24px;
}
.prog-login-logo__img {
    max-width: 160px;
    max-height: 80px;
    object-fit: contain;
    border-radius: 8px;
}
.prog-login-logo__default {
    width: 64px;
    height: 64px;
    background: var(--prog-primary-light);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    color: var(--prog-primary);
}
.prog-login-logo__default svg {
    width: 32px;
    height: 32px;
}

.prog-login-box__title {
    font-size: 22px;
    font-weight: 700;
    color: var(--prog-gray-900);
    margin-bottom: 6px;
}
.prog-login-box__subtitle {
    font-size: 14px;
    color: var(--prog-gray-400);
    margin-bottom: 28px;
}

.prog-login-error {
    background: var(--prog-danger-light);
    border: 1px solid #FECACA;
    color: var(--prog-danger);
    font-size: 13px;
    line-height: 1.5;
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 20px;
    text-align: left;
}
.prog-login-error svg {
    display: none;
}
.prog-login-error a {
    color: var(--prog-danger);
    font-weight: 600;
}
.prog-login-error strong {
    font-weight: 700;
}

.prog-login-form {
    text-align: left;
}
.prog-login-form .prog-form-group {
    margin-bottom: 16px;
}
.prog-login-form .prog-form-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-700);
    margin-bottom: 6px;
    display: block;
}

.prog-login-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.prog-login-input-wrap > svg:first-child {
    position: absolute;
    left: 12px;
    width: 18px;
    height: 18px;
    color: var(--prog-gray-400);
    pointer-events: none;
    z-index: 1;
}
.prog-login-input-wrap .prog-form-input {
    padding-left: 38px;
    padding-right: 42px;
    height: 44px;
    font-size: 14px;
    border-radius: 10px;
}
.prog-login-input-wrap .prog-form-input:focus {
    border-color: var(--prog-primary);
    box-shadow: 0 0 0 3px rgba(79,70,229,0.1);
}

.prog-login-toggle-pw {
    position: absolute;
    right: 8px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--prog-gray-400);
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
}
.prog-login-toggle-pw:hover { color: var(--prog-gray-600); }

.prog-login-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
    font-size: 13px;
}
.prog-login-remember {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--prog-gray-600);
    cursor: pointer;
}
.prog-login-remember input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--prog-primary);
}
.prog-login-forgot {
    color: var(--prog-primary);
    text-decoration: none;
    font-weight: 500;
}
.prog-login-forgot:hover { text-decoration: underline; }

.prog-login-submit {
    width: 100%;
    height: 46px;
    font-size: 15px;
    font-weight: 600;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.prog-btn-lg { padding: 12px 24px; }

/* ─── Messaggio successo login ─── */
.prog-login-success {
    background: #ECFDF5;
    border: 1px solid #A7F3D0;
    color: #059669;
    font-size: 13px;
    line-height: 1.5;
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 20px;
    text-align: left;
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
.prog-login-success svg {
    flex-shrink: 0;
    margin-top: 1px;
}

/* ─── Icona circolare (lostpassword / reset) ─── */
.prog-login-icon-circle {
    width: 56px;
    height: 56px;
    background: var(--prog-primary-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    color: var(--prog-primary);
}
.prog-login-icon-circle--success {
    background: #ECFDF5;
    color: #059669;
}

/* ─── Link "Torna al login" ─── */
.prog-login-back {
    margin-top: 20px;
    text-align: center;
}
.prog-login-back a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--prog-gray-500);
    text-decoration: none;
    transition: color .15s;
}
.prog-login-back a:hover {
    color: var(--prog-primary);
}

/* ─── Indicatore forza password ─── */
.prog-pw-strength {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
}
.prog-pw-strength__bar {
    flex: 1;
    height: 6px;
    background: var(--prog-gray-100);
    border-radius: 3px;
    overflow: hidden;
}
.prog-pw-strength__fill {
    height: 100%;
    width: 0;
    border-radius: 3px;
    transition: width .3s, background .3s;
}
.prog-pw-strength__label {
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

/* ─── Logo Upload (Impostazioni) ─── */
.prog-logo-upload {}
.prog-logo-preview {
    position: relative;
    display: inline-block;
    border: 2px dashed var(--prog-gray-200);
    border-radius: 12px;
    padding: 16px;
    background: var(--prog-gray-50);
}
.prog-logo-preview img {
    max-width: 200px;
    max-height: 100px;
    object-fit: contain;
    display: block;
    border-radius: 8px;
}
.prog-logo-remove {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 28px;
    height: 28px;
    background: var(--prog-danger);
    color: #fff;
    border: 2px solid #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
.prog-logo-remove:hover { background: #b91c1c; }
.prog-logo-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 24px;
    border: 2px dashed var(--prog-gray-200);
    border-radius: 12px;
    color: var(--prog-gray-400);
    font-size: 13px;
}

/* ═══════════════════════════════════════
   DESKTOP BREAKPOINT (>= 768px)
   ═══════════════════════════════════════ */
@media (min-width: 768px) {

    .prog-header-mobile { display: none; }
    .prog-bottom-nav { display: none; }

    .prog-sidebar { display: flex; flex-direction: column; }

    .prog-main {
        margin-left: var(--prog-sidebar-w);
        padding: 32px;
        padding-bottom: 32px;
        max-width: calc(100vw - var(--prog-sidebar-w));
    }

    /* Divisore ridimensionabile sidebar ↔ contenuto */
    .prog-layout-resizer {
        display: block;
        position: fixed;
        top: 0;
        bottom: 0;
        left: calc(var(--prog-sidebar-w) - 4px);
        width: 8px;
        z-index: 95;
        cursor: col-resize;
        touch-action: none;
        background: transparent;
        transition: background var(--prog-transition);
    }

    .prog-layout-resizer:hover,
    .prog-layout-resizer.prog-layout-resizer--dragging {
        background: rgba(79, 70, 229, 0.12);
    }

    body.prog-layout-resizing {
        cursor: col-resize !important;
        user-select: none !important;
    }

    body.prog-layout-resizing iframe {
        pointer-events: none;
    }

    .prog-page-header__title { font-size: 28px; }

    .prog-stats {
        grid-template-columns: repeat(4, 1fr);
        gap: 16px;
    }

    .prog-doors {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
        max-width: 960px;
    }

    .prog-idea-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .prog-project-list {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Modal: slide da destra */
    .prog-modal-overlay {
        align-items: stretch;
        justify-content: flex-end;
    }

    .prog-modal {
        border-radius: var(--prog-radius) 0 0 var(--prog-radius);
        width: 480px;
        max-width: 50vw;
        max-height: 100vh;
        animation: prog-slide-left 0.3s ease;
    }

    @keyframes prog-slide-left {
        from { transform: translateX(100%); }
        to   { transform: translateX(0); }
    }

    .prog-wizard__step-label { display: inline; }

    .prog-kanban__column {
        min-width: 300px;
    }
}

/* ═══════════════════════════════════════
   LARGE DESKTOP (>= 1200px)
   ═══════════════════════════════════════ */
@media (min-width: 1200px) {
    .prog-stats {
        grid-template-columns: repeat(4, 1fr);
    }

    .prog-doors {
        grid-template-columns: repeat(4, 1fr);
        max-width: 1120px;
    }

    .prog-idea-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .prog-project-list {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ═══════════════════════════════════════════════
   CALENDARIO
   ═══════════════════════════════════════════════ */

/* Navigazione mese */
.prog-cal-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 16px;
}

.prog-cal-nav__title {
    font-size: 18px;
    font-weight: 700;
    color: var(--prog-gray-900);
    min-width: 180px;
    text-align: center;
    text-transform: capitalize;
}

/* Legenda */
.prog-cal-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-bottom: 16px;
    font-size: 12px;
    color: var(--prog-gray-500);
}

.prog-cal-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.prog-cal-legend__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

/* Griglia calendario */
.prog-cal-grid {
    background: #fff;
    border-radius: var(--prog-radius-md);
    box-shadow: var(--prog-shadow-sm);
    border: 1px solid var(--prog-gray-100);
    overflow: hidden;
}

.prog-cal-grid__header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--prog-gray-50);
    border-bottom: 1px solid var(--prog-gray-100);
}

.prog-cal-grid__day-name {
    padding: 10px 4px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--prog-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.prog-cal-grid__day-name--weekend {
    color: var(--prog-gray-400);
}

.prog-cal-grid__body {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    min-height: 400px;
}

/* Cella giorno */
.prog-cal-cell {
    min-height: 80px;
    border-right: 1px solid var(--prog-gray-100);
    border-bottom: 1px solid var(--prog-gray-100);
    padding: 4px;
    cursor: pointer;
    transition: background 0.15s;
    position: relative;
    overflow: hidden;
}

.prog-cal-cell:nth-child(7n) {
    border-right: none;
}

.prog-cal-cell:hover {
    background: var(--prog-primary-light);
}

.prog-cal-cell--other-month {
    background: var(--prog-gray-50);
}

.prog-cal-cell--other-month .prog-cal-cell__num {
    color: var(--prog-gray-300);
}

.prog-cal-cell--today {
    background: rgba(79, 70, 229, 0.04);
}

.prog-cal-cell--today .prog-cal-cell__num {
    background: var(--prog-primary);
    color: #fff;
    border-radius: 50%;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.prog-cal-cell--selected {
    box-shadow: inset 0 0 0 2px var(--prog-primary);
}

.prog-cal-cell__num {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-700);
    margin-bottom: 2px;
    line-height: 26px;
    min-width: 26px;
    text-align: center;
}

.prog-cal-cell--weekend .prog-cal-cell__num {
    color: var(--prog-gray-400);
}

/* Evento dentro cella */
.prog-cal-event {
    display: flex;
    align-items: center;
    gap: 3px;
    padding: 1px 4px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 500;
    line-height: 1.4;
    margin-bottom: 1px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #fff;
    max-width: 100%;
}

.prog-cal-event--dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.prog-cal-cell__more {
    font-size: 10px;
    color: var(--prog-primary);
    font-weight: 600;
    padding: 0 4px;
    cursor: pointer;
}

/* Pannello dettaglio giorno */
.prog-cal-day-detail {
    background: #fff;
    border-radius: var(--prog-radius-md);
    box-shadow: var(--prog-shadow-sm);
    border: 1px solid var(--prog-gray-100);
    margin-top: 16px;
    overflow: hidden;
}

.prog-cal-day-detail__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--prog-gray-100);
    background: var(--prog-gray-50);
}

.prog-cal-day-detail__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--prog-gray-900);
}

/* Evento nella lista dettaglio */
.prog-cal-detail-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--prog-gray-100);
    transition: background 0.15s;
}

.prog-cal-detail-item:last-child {
    border-bottom: none;
}

.prog-cal-detail-item:hover {
    background: var(--prog-gray-50);
}

.prog-cal-detail-item__color {
    width: 4px;
    height: 36px;
    border-radius: 2px;
    flex-shrink: 0;
    margin-top: 2px;
}

.prog-cal-detail-item__content {
    flex: 1;
    min-width: 0;
}

.prog-cal-detail-item__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--prog-gray-800);
    margin-bottom: 2px;
}

.prog-cal-detail-item__meta {
    font-size: 12px;
    color: var(--prog-gray-500);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.prog-cal-detail-item__tag {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
}

/* Prossimi appuntamenti */
.prog-cal-upcoming-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--prog-gray-100);
}

.prog-cal-upcoming-item:last-child {
    border-bottom: none;
}

.prog-cal-upcoming-item__date {
    width: 48px;
    height: 48px;
    border-radius: var(--prog-radius-sm);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-weight: 700;
}

.prog-cal-upcoming-item__date-day {
    font-size: 18px;
    line-height: 1;
}

.prog-cal-upcoming-item__date-month {
    font-size: 10px;
    text-transform: uppercase;
    font-weight: 600;
    opacity: 0.8;
}

.prog-cal-upcoming-item__info {
    flex: 1;
    min-width: 0;
}

.prog-cal-upcoming-item__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--prog-gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.prog-cal-upcoming-item__sub {
    font-size: 12px;
    color: var(--prog-gray-500);
}

.prog-mt-24 { margin-top: 24px; }

/* ─── Responsive calendario ─── */
@media (max-width: 600px) {
    .prog-cal-cell {
        min-height: 56px;
        padding: 2px;
    }

    .prog-cal-cell__num {
        font-size: 11px;
    }

    .prog-cal-event {
        font-size: 0;
        padding: 0;
        width: 6px;
        height: 6px;
        border-radius: 50%;
        display: inline-block;
        margin: 0 1px 1px 0;
    }

    .prog-cal-cell__more {
        font-size: 9px;
    }

    .prog-cal-nav__title {
        font-size: 15px;
        min-width: 140px;
    }

    .prog-cal-grid__day-name {
        font-size: 10px;
        padding: 8px 2px;
    }

    .prog-cal-legend {
        gap: 8px;
        font-size: 11px;
    }
}

/* ═══════════════════════════════════════════════
   TIMELINE PERSONE (GANTT)
   ═══════════════════════════════════════════════ */

/* Navigazione */
.prog-tl-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 16px;
}

.prog-tl-nav__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--prog-gray-900);
    min-width: 220px;
    text-align: center;
}

/* Legenda */
.prog-tl-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-bottom: 16px;
    font-size: 12px;
    color: var(--prog-gray-500);
}

.prog-tl-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.prog-tl-legend__bar {
    width: 16px;
    height: 6px;
    border-radius: 3px;
    display: inline-block;
    flex-shrink: 0;
}

/* Wrapper timeline (con handle di ridimensionamento) */
.prog-tl-wrapper {
    position: relative;
    min-height: 120px;
}

/* Container principale */
.prog-tl-container {
    background: #fff;
    border-radius: var(--prog-radius-md) var(--prog-radius-md) 0 0;
    box-shadow: var(--prog-shadow-sm);
    border: 1px solid var(--prog-gray-100);
    border-bottom: none;
    overflow-x: auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    min-height: 120px;
}

/* Handle per ridimensionare verticalmente */
.prog-tl-resize-handle {
    height: 12px;
    min-height: 12px;
    background: var(--prog-gray-100);
    border: 1px solid var(--prog-gray-200);
    border-top: none;
    border-radius: 0 0 var(--prog-radius-md) var(--prog-radius-md);
    cursor: ns-resize;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
    flex-shrink: 0;
}

.prog-tl-resize-handle:hover,
.prog-tl-resize-handle:active {
    background: var(--prog-gray-200);
}

.prog-tl-resize-handle::after {
    content: '';
    width: 40px;
    height: 3px;
    background: var(--prog-gray-400);
    border-radius: 2px;
    opacity: 0.6;
}

.prog-tl-resize-handle:hover::after {
    opacity: 1;
}

/* Header giorni */
.prog-tl-header {
    display: flex;
    border-bottom: 2px solid var(--prog-gray-200);
    position: sticky;
    top: 0;
    z-index: 5;
    background: #fff;
}

.prog-tl-header__person {
    width: 200px;
    min-width: 200px;
    padding: 10px 16px;
    font-size: 12px;
    font-weight: 600;
    color: var(--prog-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: var(--prog-gray-50);
    border-right: 1px solid var(--prog-gray-200);
}

.prog-tl-header__days {
    display: flex;
    flex: 1;
}

.prog-tl-header__day {
    flex: 1;
    min-width: 36px;
    padding: 6px 2px;
    text-align: center;
    border-right: 1px solid var(--prog-gray-100);
    background: var(--prog-gray-50);
}

.prog-tl-header__day-name {
    font-size: 10px;
    font-weight: 600;
    color: var(--prog-gray-400);
    text-transform: uppercase;
}

.prog-tl-header__day-num {
    font-size: 13px;
    font-weight: 700;
    color: var(--prog-gray-700);
}

.prog-tl-header__day--weekend {
    background: var(--prog-gray-100);
}

.prog-tl-header__day--weekend .prog-tl-header__day-num {
    color: var(--prog-gray-400);
}

.prog-tl-header__day--today {
    background: rgba(79, 70, 229, 0.08);
}

.prog-tl-header__day--today .prog-tl-header__day-num {
    color: var(--prog-primary);
    font-weight: 800;
}

/* Riga persona */
.prog-tl-row {
    display: flex;
    border-bottom: 1px solid var(--prog-gray-100);
    min-height: 56px;
    transition: background 0.15s;
}

.prog-tl-row:hover {
    background: rgba(79, 70, 229, 0.02);
}

.prog-tl-row:last-child {
    border-bottom: none;
}

/* Colonna persona */
.prog-tl-row__person {
    width: 200px;
    min-width: 200px;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    border-right: 1px solid var(--prog-gray-200);
    background: #fff;
    position: sticky;
    left: 0;
    z-index: 2;
}

.prog-tl-row__avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.prog-tl-row__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.prog-tl-row__info {
    flex: 1;
    min-width: 0;
}

.prog-tl-row__name {
    font-size: 13px;
    font-weight: 600;
    color: var(--prog-gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.prog-tl-row__stats {
    font-size: 11px;
    color: var(--prog-gray-400);
}

/* Area barre Gantt */
.prog-tl-row__bars {
    flex: 1;
    display: flex;
    position: relative;
    min-height: 56px;
}

/* Colonne giorno per sfondo */
.prog-tl-row__day-col {
    flex: 1;
    min-width: 36px;
    border-right: 1px solid var(--prog-gray-100);
}

.prog-tl-row__day-col--weekend {
    background: rgba(0, 0, 0, 0.02);
}

.prog-tl-row__day-col--today {
    background: rgba(79, 70, 229, 0.04);
}

/* Barra Gantt */
.prog-tl-bar {
    position: absolute;
    height: 18px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
    color: #fff;
    padding: 0 6px;
    line-height: 18px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
    z-index: 1;
    transition: opacity 0.15s, transform 0.15s;
    box-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

.prog-tl-bar:hover {
    opacity: 0.9;
    transform: scaleY(1.15);
    z-index: 3;
}

.prog-tl-bar--progetto {
    height: 12px;
    line-height: 12px;
    border-radius: 3px;
    opacity: 0.5;
    font-size: 9px;
}

.prog-tl-bar--editable {
    cursor: pointer;
}

.prog-tl-bar__text {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.prog-tl-bar__resize {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 6px;
    cursor: col-resize;
    z-index: 2;
}

.prog-tl-bar__resize--left {
    left: 0;
    border-radius: 3px 0 0 3px;
}

.prog-tl-bar__resize--right {
    right: 0;
    border-radius: 0 3px 3px 0;
}

.prog-tl-bar__resize:hover {
    background: rgba(255,255,255,0.3);
}

/* Tooltip */
.prog-tl-tooltip {
    position: fixed;
    z-index: 100;
    background: var(--prog-gray-900);
    color: #fff;
    padding: 10px 14px;
    border-radius: var(--prog-radius-sm);
    font-size: 12px;
    line-height: 1.5;
    max-width: 260px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.25);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s;
}

.prog-tl-tooltip.visible {
    opacity: 1;
}

.prog-tl-tooltip__title {
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 4px;
}

.prog-tl-tooltip__row {
    display: flex;
    gap: 6px;
    color: rgba(255,255,255,0.7);
}

/* Stato vuoto persona */
.prog-tl-row__empty {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--prog-gray-300);
    font-size: 12px;
    font-style: italic;
}

/* Riepilogo carichi */
.prog-tl-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
}

.prog-tl-summary-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: var(--prog-radius-sm);
    border: 1px solid var(--prog-gray-100);
    transition: box-shadow 0.15s;
}

.prog-tl-summary-card:hover {
    box-shadow: var(--prog-shadow-sm);
}

.prog-tl-summary-card__avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.prog-tl-summary-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.prog-tl-summary-card__info {
    flex: 1;
    min-width: 0;
}

.prog-tl-summary-card__name {
    font-size: 14px;
    font-weight: 600;
    color: var(--prog-gray-800);
}

.prog-tl-summary-card__stats {
    display: flex;
    gap: 8px;
    margin-top: 4px;
}

.prog-tl-summary-card__stat {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 4px;
}

/* Indicatore carico */
.prog-tl-load {
    width: 100%;
    height: 4px;
    border-radius: 2px;
    background: var(--prog-gray-100);
    margin-top: 6px;
    overflow: hidden;
}

.prog-tl-load__fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s;
}

/* ─── Responsive Timeline ─── */
@media (max-width: 768px) {
    .prog-tl-header__person,
    .prog-tl-row__person {
        width: 120px;
        min-width: 120px;
        padding: 8px;
    }

    .prog-tl-row__avatar {
        width: 24px;
        height: 24px;
    }

    .prog-tl-row__name {
        font-size: 11px;
    }

    .prog-tl-row__stats {
        display: none;
    }

    .prog-tl-header__day {
        min-width: 28px;
    }

    .prog-tl-row__day-col {
        min-width: 28px;
    }

    .prog-tl-bar {
        height: 14px;
        line-height: 14px;
        font-size: 0; /* nascondi testo su mobile */
    }

    .prog-tl-nav__title {
        font-size: 13px;
        min-width: 160px;
    }
}

/* ═══════════════════════════════════════════════════
   Taccuino WEB – Bookmark Grid & Card
   ═══════════════════════════════════════════════════ */

.prog-bookmark-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}

.prog-bookmark-card {
    background: #fff;
    border: 1px solid var(--prog-gray-200);
    border-radius: var(--prog-radius);
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s;
}
.prog-bookmark-card:hover {
    box-shadow: var(--prog-shadow-md);
    border-color: var(--prog-primary);
    transform: translateY(-2px);
}

.prog-bookmark-card__img {
    height: 160px;
    overflow: hidden;
    background: var(--prog-gray-100);
}
.prog-bookmark-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.prog-bookmark-card__body {
    padding: 14px;
}

.prog-bookmark-card__head {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
}

.prog-bookmark-card__icon {
    display: flex;
    align-items: center;
}

.prog-bookmark-card__site {
    font-size: 11px;
    color: var(--prog-gray-400);
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.prog-bookmark-card__projects {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    font-size: 11px;
    color: var(--prog-primary);
    font-weight: 600;
    background: var(--prog-primary-light, #EEF2FF);
    padding: 2px 6px;
    border-radius: 10px;
}

.prog-bookmark-card__title {
    font-weight: 600;
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.prog-bookmark-card__desc {
    font-size: 12px;
    color: var(--prog-gray-500);
    line-height: 1.5;
    margin-bottom: 6px;
}

.prog-bookmark-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 6px;
}

.prog-bookmark-tag {
    display: inline-block;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 12px;
    background: var(--prog-gray-100);
    color: var(--prog-gray-600);
    font-weight: 500;
}

/* Preview nel modale */
.prog-bookmark-preview {
    border: 1px solid var(--prog-gray-200);
    border-radius: var(--prog-radius);
    overflow: hidden;
}

.prog-bookmark-preview__img {
    max-height: 160px;
    overflow: hidden;
    background: var(--prog-gray-100);
}

.prog-bookmark-preview__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.prog-bookmark-preview__info {
    padding: 10px 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.prog-bookmark-preview__badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    background: var(--prog-primary);
    color: #fff;
}

.prog-bookmark-preview__site {
    font-size: 12px;
    color: var(--prog-gray-500);
}

/* Ricerca */
.prog-search-wrap {
    position: relative;
}

@media (max-width: 600px) {
    .prog-bookmark-grid {
        grid-template-columns: 1fr;
    }
    .prog-bookmark-card__img {
        height: 120px;
    }
}

/* ═══ Partecipanti Evento (CRM) ═══ */
.prog-partecipanti-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}

.prog-partecipante-card {
    background: #fff;
    border: 1px solid var(--prog-gray-200);
    border-radius: var(--prog-radius);
    overflow: hidden;
    transition: box-shadow var(--prog-transition), border-color var(--prog-transition);
}

.prog-partecipante-card:hover {
    box-shadow: var(--prog-shadow-sm);
    border-color: var(--prog-gray-300);
}

.prog-partecipante-card__head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px;
    border-bottom: 1px solid var(--prog-gray-100);
}

.prog-partecipante-card__avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--prog-primary), #7C3AED);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    flex-shrink: 0;
}

.prog-partecipante-card__info {
    flex: 1;
    min-width: 0;
}

.prog-partecipante-card__nome {
    font-weight: 600;
    font-size: 14px;
    color: var(--prog-gray-800);
}

.prog-partecipante-card__azienda {
    font-size: 12px;
    color: var(--prog-gray-500);
    margin-top: 2px;
}

.prog-partecipante-card__actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

.prog-partecipante-card__actions .prog-btn {
    padding: 6px;
    min-width: 32px;
}

.prog-partecipante-card__body {
    padding: 12px 14px;
    font-size: 13px;
}

.prog-partecipante-card__row {
    margin-bottom: 4px;
}

.prog-partecipante-card__row a {
    color: var(--prog-primary);
    text-decoration: none;
}

.prog-partecipante-card__row a:hover {
    text-decoration: underline;
}

.prog-partecipante-card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.prog-partecipante-card__badge {
    display: inline-block;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 10px;
}

.prog-partecipante-card__badge--stato {
    background: var(--prog-primary-light);
    color: var(--prog-primary);
    font-weight: 600;
}

.prog-partecipante-card__badge--pagamento {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 10px;
    background: var(--prog-gray-100);
    color: var(--prog-gray-600);
    font-weight: 500;
}

.prog-partecipante-card__note {
    font-size: 12px;
    color: var(--prog-gray-500);
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--prog-gray-100);
    line-height: 1.4;
}

/* Template email */
.prog-templates-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.prog-template-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    border: 1px solid var(--prog-gray-200);
    border-radius: var(--prog-radius-sm);
    background: #fff;
}

.prog-template-card__info {
    flex: 1;
    min-width: 0;
}

.prog-template-card__nome {
    font-weight: 600;
    font-size: 14px;
    color: var(--prog-gray-800);
}

.prog-template-card__oggetto {
    font-size: 12px;
    color: var(--prog-gray-500);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.prog-template-card__actions {
    display: flex;
    gap: 4px;
}

/* ═══ Modale Dettaglio Idea ═══ */
/* Modal Bookmark (nuovo + dettaglio) - overlay centrato */
#modal-nuovo-bookmark,
#modal-dettaglio-bookmark {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
}

#modal-nuovo-bookmark .prog-modal__overlay,
#modal-dettaglio-bookmark .prog-modal__overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    cursor: pointer;
}

#modal-nuovo-bookmark .prog-modal__content,
#modal-dettaglio-bookmark .prog-modal__content {
    position: relative;
    z-index: 1;
    background: #fff;
    border-radius: var(--prog-radius, 12px);
    width: 100%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    animation: prog-modal-slide-up 0.3s ease;
}

#modal-nuovo-bookmark .prog-modal__header,
#modal-dettaglio-bookmark .prog-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--prog-gray-200);
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 2;
    border-radius: var(--prog-radius, 12px) var(--prog-radius, 12px) 0 0;
}

#modal-nuovo-bookmark .prog-modal__body,
#modal-dettaglio-bookmark .prog-modal__body {
    padding: 20px;
}

#modal-nuovo-bookmark .prog-modal__footer,
#modal-dettaglio-bookmark .prog-modal__footer {
    padding: 16px 20px;
    border-top: 1px solid var(--prog-gray-200);
    border-radius: 0 0 var(--prog-radius, 12px) var(--prog-radius, 12px);
}

#modal-dettaglio-bookmark .prog-modal__content { max-width: 600px; }

#modal-dettaglio-idea {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

#modal-dettaglio-idea .prog-modal__overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    cursor: pointer;
}

#modal-dettaglio-idea .prog-modal__content {
    position: relative;
    z-index: 1;
    background: #fff;
    border-radius: var(--prog-radius, 12px);
    width: 95%;
    max-width: 700px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    animation: prog-modal-slide-up 0.3s ease;
}

@keyframes prog-modal-slide-up {
    from { transform: translateY(30px); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}

#modal-dettaglio-idea .prog-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--prog-gray-200, #E5E7EB);
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 2;
    border-radius: var(--prog-radius, 12px) var(--prog-radius, 12px) 0 0;
}

#modal-dettaglio-idea .prog-modal__title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
}

#modal-dettaglio-idea .prog-modal__close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: var(--prog-gray-500, #6B7280);
    line-height: 1;
    padding: 4px;
}

#modal-dettaglio-idea .prog-modal__body {
    padding: 20px;
}

/* Toggle icon per sezione collassabile */
.prog-toggle-icon {
    transition: transform 0.2s ease;
    margin-left: auto;
}
.prog-toggle-icon.open {
    transform: rotate(180deg);
}

/* Utility */
.prog-mt-16 { margin-top: 16px; }

/* ═══════════════════════════════════════════════════════════
   AVVOCATO DEL DIAVOLO - Stile aggressivo/critico
   ═══════════════════════════════════════════════════════════ */
.prog-devil-report {
    margin-top: 24px;
    border: 2px solid #DC2626;
    border-radius: var(--prog-radius, 12px);
    overflow: hidden;
    background: linear-gradient(135deg, #FEF2F2 0%, #FFF5F5 50%, #FFFBEB 100%);
}

.prog-devil-report__header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: linear-gradient(135deg, #991B1B, #B91C1C, #7F1D1D);
    color: #fff;
}

.prog-devil-report__icon svg {
    width: 28px;
    height: 28px;
    stroke: #FCA5A5;
}

.prog-devil-report__title {
    font-size: 17px;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.prog-devil-report__subtitle {
    font-size: 12px;
    color: #FCA5A5;
    margin-top: 2px;
    font-weight: 500;
}

/* Probabilità di sopravvivenza */
.prog-devil-survival {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 20px;
    border-bottom: 1px solid rgba(220, 38, 38, 0.15);
    background: rgba(255, 255, 255, 0.6);
}

.prog-devil-survival__gauge {
    text-align: center;
    min-width: 100px;
    flex-shrink: 0;
}

.prog-devil-survival__value {
    font-size: 36px;
    font-weight: 900;
    line-height: 1;
}

.prog-devil-survival__label {
    font-size: 11px;
    color: var(--prog-gray-500, #6B7280);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 4px;
}

.prog-devil-survival__details {
    font-size: 13px;
    line-height: 1.6;
    color: var(--prog-gray-700, #374151);
}

.prog-devil-survival__action {
    margin-top: 8px;
    padding: 8px 12px;
    background: #FEF3C7;
    border-left: 3px solid #D97706;
    border-radius: 0 6px 6px 0;
    font-size: 13px;
}

/* Sezioni del report */
.prog-devil-section {
    padding: 16px 20px;
    border-bottom: 1px solid rgba(220, 38, 38, 0.1);
}

.prog-devil-section:last-child {
    border-bottom: none;
}

.prog-devil-section__title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 700;
    color: #991B1B;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 12px;
}

.prog-devil-section__icon {
    font-size: 18px;
}

/* Liste */
.prog-devil-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.prog-devil-list li {
    position: relative;
    padding: 8px 12px 8px 28px;
    margin-bottom: 6px;
    font-size: 13px;
    line-height: 1.6;
    color: var(--prog-gray-800, #1F2937);
    border-radius: 6px;
}

.prog-devil-list--danger li {
    background: rgba(220, 38, 38, 0.06);
    border-left: 3px solid #DC2626;
}

.prog-devil-list--danger li::before {
    content: "\2716";
    position: absolute;
    left: 8px;
    top: 8px;
    color: #DC2626;
    font-size: 12px;
    font-weight: 700;
}

.prog-devil-list--warning li {
    background: rgba(217, 119, 6, 0.06);
    border-left: 3px solid #D97706;
}

.prog-devil-list--warning li::before {
    content: "\26A0";
    position: absolute;
    left: 6px;
    top: 8px;
    color: #D97706;
    font-size: 12px;
}

/* Scenari di fallimento */
.prog-devil-scenarios {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.prog-devil-scenario {
    padding: 12px 16px;
    background: rgba(127, 29, 29, 0.04);
    border: 1px solid rgba(220, 38, 38, 0.15);
    border-radius: 8px;
}

.prog-devil-scenario__num {
    font-size: 11px;
    font-weight: 800;
    color: #DC2626;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 4px;
}

.prog-devil-scenario__text {
    font-size: 13px;
    line-height: 1.6;
    color: var(--prog-gray-700, #374151);
}

/* Domande scomode */
.prog-devil-questions {
    margin: 0;
    padding: 0 0 0 20px;
    counter-reset: devil-q;
}

.prog-devil-questions li {
    padding: 8px 12px;
    margin-bottom: 6px;
    font-size: 13px;
    line-height: 1.6;
    color: var(--prog-gray-800, #1F2937);
    background: rgba(109, 40, 217, 0.04);
    border-left: 3px solid #7C3AED;
    border-radius: 0 6px 6px 0;
    font-weight: 500;
}

/* Competitor killer */
.prog-devil-killer {
    padding: 12px 16px;
    background: linear-gradient(135deg, #FEE2E2, #FEF3C7);
    border: 1px solid #DC2626;
    border-radius: 8px;
    font-size: 14px;
    line-height: 1.7;
    color: #7F1D1D;
    font-weight: 600;
}

/* Verdetto brutale */
/* ═══ Seguito conversazionale analisi AI ═══ */
.prog-analisi-chat {
    margin-top: 24px;
    padding: 20px;
    background: #F8FAFC;
    border: 1px solid var(--prog-gray-200, #E5E7EB);
    border-radius: var(--prog-radius, 12px);
}

.prog-analisi-chat__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--prog-gray-800, #1F2937);
    margin-bottom: 4px;
}

.prog-analisi-chat__subtitle {
    font-size: 12px;
    color: var(--prog-gray-500, #6B7280);
    margin-bottom: 16px;
}

.prog-analisi-chat__thread {
    max-height: 200px;
    overflow-y: auto;
    margin-bottom: 16px;
}

.prog-analisi-chat__msg {
    padding: 10px 14px;
    margin-bottom: 8px;
    border-radius: 8px;
    font-size: 13px;
    line-height: 1.6;
}

.prog-analisi-chat__msg--user {
    background: #EEF2FF;
    border-left: 3px solid var(--prog-primary, #4F46E5);
}

.prog-analisi-chat__msg--assistant {
    background: #fff;
    border: 1px solid var(--prog-gray-200, #E5E7EB);
    border-left: 3px solid #10B981;
}

.prog-analisi-chat__form {
    display: flex;
    gap: 12px;
    align-items: flex-end;
}

.prog-analisi-chat__form textarea {
    flex: 1;
    min-height: 56px;
    padding: 10px 14px;
    border: 1px solid var(--prog-gray-300, #D1D5DB);
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    resize: vertical;
}

.prog-analisi-chat__form textarea:focus {
    outline: none;
    border-color: var(--prog-primary, #4F46E5);
    box-shadow: 0 0 0 2px rgba(79, 70, 229, 0.2);
}

@media (max-width: 600px) {
    .prog-analisi-chat__form {
        flex-direction: column;
        align-items: stretch;
    }
    .prog-analisi-chat__form button {
        align-self: flex-end;
    }
}

.prog-devil-verdict {
    margin: 0;
    padding: 16px 20px;
    background: linear-gradient(135deg, #7F1D1D, #991B1B);
    color: #FCA5A5;
    font-size: 14px;
    line-height: 1.7;
    font-weight: 600;
    font-style: italic;
    border-top: 2px solid #DC2626;
}

/* Responsive */
@media (max-width: 600px) {
    .prog-devil-survival {
        flex-direction: column;
        text-align: center;
    }
    .prog-devil-survival__gauge {
        min-width: auto;
    }
    .prog-devil-section {
        padding: 12px 14px;
    }
    .prog-devil-report__header {
        padding: 12px 14px;
    }
    .prog-devil-report__title {
        font-size: 15px;
    }
}

/* ─── Budget / Rendicontazione ─── */
.prog-table {
    border-collapse: collapse;
    font-size: 14px;
}
.prog-table th,
.prog-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--prog-gray-200, #E5E7EB);
}
.prog-table th {
    font-weight: 600;
    color: var(--prog-gray-600, #4B5563);
}
.prog-table--compact th,
.prog-table--compact td {
    padding: 8px 10px;
    font-size: 13px;
}
.prog-table tbody tr:hover {
    background: var(--prog-gray-50, #F9FAFB);
}
