/* 
   AutoSmart Layout Engine v1.0 
   Gestemas Standardized Responsive System
   Uses Container Queries (@container) for component-level adaptability.
*/

:root {
    --block-padding: 24px;
    --block-gap: 24px;
    --card-radius: 20px;
    /* Phase 2: semantic aliases with visual parity */
    --as-color-surface: var(--gestemas-bg, #f8fafc);
    --as-color-text-strong: var(--gestemas-gray-900, #1e293b);
    --as-color-text-muted: var(--gestemas-gray-600, #64748b);
    --as-color-primary: var(--gestemas-primary, #6366f1);
    --as-color-success: var(--gst-success, #10b981);
    --as-color-success-strong: #059669;
    --as-color-danger: var(--gst-danger, #ef4444);
    --as-color-danger-strong: #dc2626;
    --as-color-warning: #d97706;
    --as-color-info: #2563eb;
    --as-color-info-bright: var(--gst-info, #3b82f6);
    --as-color-info-soft: #eff6ff;
    --as-color-info-soft-alt: #e0f2fe;
    --as-color-info-strong: #0284c7;
    --as-color-neutral-strong: #1e293b;
    --as-color-danger-deep: #991b1b;
    --as-color-danger-soft-border: #fee2e2;
    --as-color-border-muted: #e2e8f0;
    --as-color-warning-deep: #92400e;
    --as-color-text-deep: #0f172a;
    --as-color-text-subtle: #94a3b8;
    --as-color-border-soft: #cbd5e1;
    --as-color-surface-soft: #f1f5f9;
    --as-color-merit-bg-start: #fffcf0;
    --as-color-merit-bg-end: #fff9db;
    --as-color-merit-border: #ffe066;
    --as-color-merit-text: #856404;
    --as-color-merit-points: #f08c00;
    --as-color-purple-vivid: #a855f7;
    --as-color-pink-vivid: #ec4899;
    --as-color-teal-deep: #0f766e;
    --as-color-success-soft-2: #dcfce7;
    --as-color-success-deep-2: #166534;
    --as-color-bg-cine: #020617;
    --as-color-skeleton-a: #f0f0f0;
    --as-color-skeleton-b: #f8f8f8;
    --as-color-danger-rgb: 239, 68, 68;
    --as-color-success-rgb: 16, 185, 129;
    --as-color-warning-rgb: 245, 158, 11;
    --as-color-info-rgb: 59, 130, 246;
    --as-color-neutral-rgb: 15, 23, 42;
    --as-color-primary-rgb: var(--gestemas-primary-rgb, 99, 102, 241);
    --as-color-success-soft: #ecfdf5;
    --as-color-danger-soft: #fef2f2;
    --as-color-glass-border-soft: var(--glass-border, rgba(0, 0, 0, 0.05));
    --as-color-purple-soft: #f5f3ff;
    --as-color-purple-strong: #7c3aed;
    --as-color-violet: #8b5cf6;
    --as-color-amber-soft: #fffbeb;
    --as-color-orange: #f97316;
    --as-color-rose: #f43f5e;
}

/* ═══════════════════════════════════════════════════════════
   1. AUTO-SMART CONTAINER CONTEXT
   ═══════════════════════════════════════════════════════════ */
.gestemas-module-root,
.premium-data-wrapper {
    container-type: inline-size;
    container-name: module;
    width: 100%;
}

/* ═══════════════════════════════════════════════════════════
   2. SMART GRID SYSTEM
   ═══════════════════════════════════════════════════════════ */
.smart-grid {
    display: grid;
    gap: var(--block-gap);
    transition: all 0.3s ease;
}

/* Default: Auto-fit (Best for cards) */
.smart-grid.auto-fit {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

/* Container Queries for Smart Adaptation */
@container module (max-width: 1100px) {
    .smart-grid.cols-4 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@container module (max-width: 850px) {

    .smart-grid.cols-4,
    .smart-grid.cols-3 {
        grid-template-columns: repeat(2, 1fr);
    }

    .smart-hide-desktop {
        display: flex !important;
    }

    .smart-hide-tablet {
        display: none !important;
    }
}

@container module (max-width: 500px) {
    .smart-grid {
        grid-template-columns: 1fr;
    }

    .smart-card,
    .premium-card {
        padding: 10px;
    }

    /* Header Stacking */
    .gestemas-premium-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .gestemas-page-header__right {
        width: 100%;
    }

    .gestemas-actions-group {
        width: 100%;
    }

    .gestemas-btn {
        flex: 1;
    }

    .smart-hide-mobile {
        display: none !important;
    }
}

/* ═══════════════════════════════════════════════════════════
   3. SMART COMPONENTS (Migrated from Inline Styles)
   ═══════════════════════════════════════════════════════════ */

/* Header Premium */
.gestemas-premium-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--block-padding, 24px) 0;
    margin-bottom: var(--block-gap, 24px);
    border-bottom: 1px solid var(--glass-border, rgba(255, 255, 255, 0.2));
    flex-wrap: wrap;
    gap: 16px;
}

.gestemas-page-header__left h1 {
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 800;
    margin: 0 0 4px;
    letter-spacing: -0.02em;
}

/* Control Bar */
.smart-control-bar,
.gestemas-control-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 16px 20px;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 20px;
    margin-bottom: var(--block-gap);
    align-items: center;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
    position: relative;
    z-index: 100;
    /* Ensure search bar is always on top */
}

/* Ensure search input doesn't get obscured */
.control-search {
    position: relative;
    z-index: 101;
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--as-color-surface);
    padding: 10px 16px;
    border-radius: 12px;
    border: 1px solid var(--as-color-glass-border-soft);
    flex: 1;
    min-width: 280px;
    transition: all 0.3s ease;
}

.control-search input {
    width: 100%;
    position: relative;
    z-index: 102;
}

/* Removed redundant .control-search definition */

.control-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.premium-select {
    padding: 10px 32px 10px 14px;
    background: var(--as-color-surface);
    border: 1px solid var(--as-color-glass-border-soft);
    border-radius: 12px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
}

/* ═══════════════════════════════════════════════════════════
   3.1 ADVANCED FILTERS & COLLAPSIBLE PANELS
   ═══════════════════════════════════════════════════════════ */

.advanced-filters-panel {
    width: 100%;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), 
                opacity 0.3s ease, 
                padding 0.3s ease,
                margin 0.3s ease,
                border-color 0.3s ease;
    opacity: 0;
    background: rgba(var(--gestemas-primary-rgb), 0.02);
    border-radius: 16px;
    border: 1px dashed transparent;
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.advanced-filters-panel.is-expanded {
    max-height: 500px;
    opacity: 1;
    visibility: visible;
    padding: 16px;
    margin-top: 12px;
    margin-bottom: 12px;
    border-color: rgba(var(--gestemas-primary-rgb), 0.15);
    pointer-events: all;
}

/* Fallback for older browsers or if max-height animation fails */
@supports not (max-height: 500px) {
    .advanced-filters-panel.is-expanded {
        display: flex;
        visibility: visible;
        opacity: 1;
    }
}

.filter-toggle-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--as-color-surface);
    border: 1px solid var(--as-color-glass-border-soft);
    border-radius: 12px;
    font-size: 13px;
    font-weight: 700;
    color: var(--gestemas-gray-600);
    cursor: pointer;
    transition: all 0.3s ease;
}

.filter-toggle-btn:hover {
    background: white;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    border-color: var(--as-color-primary);
    color: var(--as-color-primary);
}

.filter-toggle-btn.is-active {
    background: var(--as-color-primary);
    color: white;
    border-color: var(--as-color-primary);
}

.active-filters-indicator {
    display: none; /* Hidden by default, shown via JS when filters > 0 */
    align-items: center;
    gap: 12px;
    margin-left: 12px;
    padding: 6px 14px;
    border-radius: 20px;
    background: rgba(var(--gestemas-primary-rgb), 0.08);
    border: 1px solid rgba(var(--gestemas-primary-rgb), 0.15);
    flex-wrap: nowrap;
    width: auto;
    max-width: 100%;
    box-sizing: border-box;
}

.active-filters-badge {
    font-size: 11px;
    font-weight: 800;
    color: var(--as-color-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
    flex: 0 0 auto;
}

.btn-clear-filters {
    display: flex;
    align-items: center;
    gap: 6px;
    background: white;
    border: 1px solid rgba(var(--gestemas-primary-rgb), 0.2);
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 700;
    color: var(--as-color-danger);
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
    white-space: nowrap;
    flex: 0 0 auto;
}

.btn-clear-filters:hover {
    background: var(--as-color-danger-soft);
    border-color: var(--as-color-danger);
    transform: translateY(-1px);
}

@container module (max-width: 768px) {
    .gestemas-control-bar {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
    }
    
    .active-filters-indicator {
        margin-left: 0;
        justify-content: space-between;
        width: 100%;
        box-sizing: border-box;
    }

    .control-filters {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .active-filters-indicator {
        padding: 10px 12px;
        gap: 8px;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .active-filters-badge {
        font-size: 10px;
    }

    .btn-clear-filters {
        padding: 6px 10px;
        font-size: 10px;
    }
}

.active-filters-badge {
    font-size: 11px;
    font-weight: 800;
    color: var(--as-color-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.btn-clear-filters {
    display: flex;
    align-items: center;
    gap: 6px;
    background: white;
    border: 1px solid rgba(0,0,0,0.1);
    padding: 6px 12px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 700;
    color: var(--as-color-danger);
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.btn-clear-filters:hover {
    background: var(--as-color-danger-soft);
    border-color: var(--as-color-danger);
}

/* Final CSS Cleanup - Removed Redundant Properties */
.premium-card,
.smart-card {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 20px;
    padding: 20px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}

.premium-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(255, 255, 255, 0.2) inset, 0 0 80px -10px rgba(var(--gestemas-primary-rgb), 0.2);
}

/* ═══════════════════════════════════════════════════════════
   3.5 GLASSMORPHISM V3: PREMIUM ERROR HANDLING
   ═══════════════════════════════════════════════════════════ */
.glass-error-modal {
    position: relative;
    max-width: 480px;
    padding: 40px;
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(40px) saturate(200%);
    -webkit-backdrop-filter: blur(40px) saturate(200%);
    border-radius: 32px;
    border: 1px solid rgba(255, 255, 255, 0.5);
    box-shadow:
        0 25px 50px -12px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(255, 255, 255, 0.3) inset,
        0 0 40px -10px rgba(var(--gestemas-primary-rgb), 0.1);
    text-align: center;
    color: var(--as-color-text-strong);
    overflow: hidden;
    margin: 20px;
}

.error-visual-container {
    position: relative;
    width: 100px;
    height: 100px;
    margin: 0 auto 32px;
}

.error-glow-ring {
    position: absolute;
    inset: -10px;
    background: conic-gradient(from 0deg, var(--gestemas-primary), var(--gestemas-secondary), var(--gestemas-accent), var(--gestemas-primary));
    border-radius: 50%;
    filter: blur(20px);
    opacity: 0.3;
    animation: rotate 4s linear infinite;
}

.error-icon-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
    z-index: 2;
}

.error-icon-wrapper i {
    width: 48px;
    height: 48px;
    color: var(--gestemas-primary);
}

.error-title-v3 {
    font-size: 28px;
    font-weight: 850;
    margin-bottom: 20px;
    background: linear-gradient(135deg, var(--as-color-text-strong) 0%, var(--as-color-text-muted) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    letter-spacing: -0.03em;
}

.error-message-v3 {
    font-size: 16px;
    line-height: 1.6;
    color: var(--gestemas-gray-600);
    margin-bottom: 32px;
    font-weight: 500;
}

.btn-reload-pro {
    width: 100%;
    padding: 16px 32px;
    background: linear-gradient(135deg, var(--gestemas-primary) 0%, var(--as-color-primary) 100%);
    border: none;
    border-radius: 18px;
    color: white;
    font-size: 16px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 15px 30px -5px rgba(var(--gestemas-primary-rgb), 0.4);
}

.btn-reload-pro:hover {
    transform: scale(1.03) translateY(-2px);
    box-shadow: 0 20px 40px -5px rgba(var(--gestemas-primary-rgb), 0.5);
}

.btn-reload-pro:active {
    transform: scale(0.98);
}

.error-footer-v3 {
    margin-top: 16px;
    font-size: 13px;
    color: var(--as-color-text-subtle);
    font-weight: 600;
}

.error-close-btn {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.05);
    background: rgba(255, 255, 255, 0.5);
    color: var(--as-color-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.error-close-btn:not(.gestemas-btn):hover {
    background: var(--gst-white, white);
    color: var(--as-color-rose);
    transform: rotate(90deg);
}

.icon-spin-slow {
    animation: spin 3s linear infinite;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes rotate {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

/* ═══════════════════════════════════════════════════════════
   4. NEXUS LIST BLOCK
.nexus-list-block {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 16px;
    padding: 16px 20px;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 16px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.nexus-list-block:hover {
    transform: translateX(4px);
    border-color: var(--gestemas-primary);
    box-shadow: 0 8px 24px rgba(var(--gestemas-primary-rgb), 0.15);
}

/* ═══════════════════════════════════════════════════════════
   4. MOBILE ADAPTATIONS (Container Queries)
   ═══════════════════════════════════════════════════════════ */
@container module (max-width: 700px) {

    .smart-control-bar,
    .gestemas-control-bar {
        flex-direction: column;
        align-items: stretch;
        padding: 12px;
    }

    .control-filters {
        overflow-x: auto;
        padding-bottom: 4px;
        flex-wrap: nowrap;
        justify-content: flex-start;
        -webkit-overflow-scrolling: touch;
        gap: 8px;
        scrollbar-width: none;
    }

    .control-filters::-webkit-scrollbar {
        display: none;
    }

    .premium-select {
        flex-shrink: 0;
        min-height: 44px;
    }

    .control-search {
        width: 100%;
    }

    /* List Blocks Mobile */
    .nexus-list-block {
        flex-wrap: wrap;
        padding: 14px;
        gap: 12px;
    }

    .nexus-block-main {
        width: 100%;
        order: 2;
    }

    .nexus-block-actions {
        order: 3;
        width: 100%;
        display: flex;
        justify-content: flex-end;
        gap: 8px;
        margin-top: 8px;
        border-top: 1px solid rgba(0, 0, 0, 0.05);
        padding-top: 8px;
    }
}

/* ═══════════════════════════════════════════════════════════
   5. PRESET MODES (Applied to Body)
   ═══════════════════════════════════════════════════════════ */

/* Mode: Focus (Enfoque) */
body[data-autosmart="focus"] .sidebar-main,
body[data-autosmart="focus"] .gestemas-sidebar,
body[data-autosmart="focus"] .nexus-sidebar {
    display: none;
}

body[data-autosmart="focus"] .gestemas-main-content,
body[data-autosmart="focus"] .nexus-main {
    margin-left: 0;
    width: 100%;
}

body[data-autosmart="focus"] .gestemas-module-root,
body[data-autosmart="focus"] .nexus-content-body {
    max-width: 1100px;
    margin: 0 auto;
}

/* Mode: Cine (High Contrast / Dark) */
body[data-autosmart="cine"] {
    --gestemas-bg: var(--as-color-text-deep);
    --glass-bg: rgba(15, 23, 42, 0.8);
    --glass-border: rgba(255, 255, 255, 0.1);
    --text-primary: var(--gst-white);
    --text-muted: var(--as-color-text-subtle);
    background-color: var(--as-color-bg-cine);
    color: var(--gst-white);
}

body[data-autosmart="cine"] .premium-card,
body[data-autosmart="cine"] .smart-control-bar,
body[data-autosmart="cine"] .nexus-list-block,
body[data-autosmart="cine"] .nexus-sidebar,
body[data-autosmart="cine"] .nexus-header,
body[data-autosmart="cine"] .nexus-card {
    background: rgba(15, 23, 42, 0.6);
    color: white;
    border-color: rgba(255, 255, 255, 0.1);
}

body[data-autosmart="cine"] .nexus-nav-item {
    color: var(--as-color-text-subtle);
}

body[data-autosmart="cine"] .nexus-nav-item.is-active {
    color: white;
    background: rgba(255, 255, 255, 0.1);
}

/* Mode: Compact (More density) */
body[data-autosmart="compact"] {
    --block-gap: 12px;
    --block-padding: 16px;
    --card-radius: 12px;
}

body[data-autosmart="compact"] .nexus-nav-item {
    padding: 8px 12px;
}

body[data-autosmart="compact"] .nexus-header {
    padding: 16px 20px;
}

/* ═══════════════════════════════════════════════════════════
   6. UI UTILITIES (Migrated from Views)
   ═══════════════════════════════════════════════════════════ */

/* View Toggle */
.view-toggle {
    display: flex;
    background: var(--as-color-surface);
    border-radius: 12px;
    padding: 4px;
    gap: 4px;
    flex-shrink: 0;
    /* Prevent squashing on mobile */
}

/* Fix control actions alignment on mobile */
@container module (max-width: 700px) {
    .control-actions {
        width: 100%;
        justify-content: space-between;
        margin-left: 0;
        margin-top: 8px;
        flex-wrap: wrap;
    }

    .view-toggle {
        margin-left: auto;
        /* Push to right on mobile */
    }
}

.toggle-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    border: none;
    background: transparent;
    color: var(--gestemas-gray-500);
    cursor: pointer;
    transition: all 0.3s ease;
}

.toggle-btn:hover {
    background: rgba(var(--gestemas-primary-rgb), 0.1);
    color: var(--gestemas-primary);
}

.toggle-btn.active {
    background: var(--gestemas-primary);
    color: white;
    box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.3);
}

/* Priority Badges & Pills */
.priority-badge {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.priority-badge.red {
    background: rgba(var(--as-color-danger-rgb), 0.15);
    color: var(--as-color-danger-strong);
}

.priority-badge.yellow {
    background: rgba(var(--as-color-warning-rgb), 0.15);
    color: var(--as-color-warning);
}

.priority-badge.blue {
    background: rgba(var(--as-color-info-rgb), 0.15);
    color: var(--as-color-info);
}

.nexus-status-pill {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--gestemas-gray-100);
    color: var(--gestemas-gray-600);
}

.nexus-status-pill .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
}

.nexus-status-pill.status-completada {
    background: rgba(var(--as-color-success-rgb, 16, 185, 129), 0.15);
    color: var(--as-color-success-strong);
}

.nexus-status-pill.status-pendiente {
    background: rgba(var(--as-color-primary-rgb), 0.1);
    color: var(--as-color-primary);
}

.nexus-status-pill.status-vencida {
    background: rgba(var(--as-color-danger-rgb), 0.15);
    color: var(--as-color-danger-strong);
    border: 1px solid rgba(var(--as-color-danger-rgb), 0.1);
}

.nexus-status-pill.status-atrasada {
    background: rgba(var(--as-color-warning-rgb), 0.15);
    color: var(--as-color-warning);
}

.nexus-status-pill.status-cancelada {
    background: rgba(var(--as-color-neutral-rgb), 0.08);
    color: var(--as-color-neutral-strong);
    border: 1px dashed rgba(var(--as-color-neutral-rgb), 0.2);
    text-decoration: line-through;
    opacity: 0.8;
}

.nexus-status-pill.status-revisada {
    background: rgba(var(--as-color-primary-rgb), 0.15);
    color: var(--as-color-primary);
}

/* Date Stacked */
.date-stacked {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 60px;
    gap: 2px;
}

/* Avatars */
.avatar-mini {
    min-width: 40px;
    min-height: 40px;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
}

/* Horizontal Summary Card */
.horizontal-summary-card {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 16px;
    padding: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    transition: all 0.3s ease;
}

.horizontal-summary-card:hover {
    background: rgba(255, 255, 255, 0.95);
    transform: translateY(-2px);
    box-shadow: var(--gestemas-shadow);
}

@container module (max-width: 700px) {
    .horizontal-summary-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .summary-excerpt {
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        line-clamp: 2;
    }

    .summary-actions {
        width: 100%;
        justify-content: flex-end;
        display: flex;
        gap: 8px;
    }
}

/* Cross-module responsive hardening for summary/list blocks */
.nexus-summary-shell {
    display: flex;
    align-items: center;
    gap: 16px;
}

.nexus-summary-metrics {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

@media (max-width: 900px) {
    .nexus-summary-shell {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .nexus-summary-shell .summary-left {
        min-width: 0;
        width: 100%;
    }

    .nexus-summary-shell .summary-excerpt {
        width: 100%;
        max-width: 100%;
    }

    .nexus-summary-shell .summary-actions {
        margin-left: 0;
    }
}

@media (max-width: 768px) {
    .nexus-list-block .main-row,
    .nexus-list-block .sub-row {
        width: 100%;
    }

    .nexus-list-block .nexus-badge-soft,
    .nexus-list-block .nexus-status-pill {
        max-width: 100%;
    }

    .nexus-list-block .nexus-excerpt {
        max-width: 100%;
        white-space: normal;
    }

    .estudiantes-summary-view .student-summary-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding: 16px;
    }

    .estudiantes-summary-view .student-summary-card .summary-stats {
        width: 100%;
        border-left: 0;
        border-right: 0;
        border-top: 1px solid var(--gestemas-gray-100);
        border-bottom: 1px solid var(--gestemas-gray-100);
        padding: 10px 0;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px 14px;
    }

    .estudiantes-list-view .nexus-student-block {
        display: grid;
        grid-template-columns: auto 1fr auto;
        gap: 10px;
        align-items: start;
    }

    .estudiantes-list-view .nexus-student-block .nexus-info,
    .estudiantes-list-view .nexus-student-block .nexus-stats-strip {
        grid-column: 1 / -1;
        width: 100%;
    }

    .estudiantes-list-view .nexus-student-block .nexus-stats-strip {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
    }
}

/* ═══════════════════════════════════════════════════════════
   7. MODULE: PONE (Pentágono de Observación)
   ═══════════════════════════════════════════════════════════ */
:root {
    --pone-ic: var(--as-color-violet);
    --pone-sa: var(--as-color-info-bright);
    --pone-aa: var(--as-color-pink-vivid);
    --pone-ft: var(--gst-warning);
    --pone-icf: var(--as-color-success);
}

.pone-module {
    background: radial-gradient(circle at top right, rgba(var(--gestemas-primary-rgb), 0.05), transparent 400px);
}

/* Observer Card Refinement */
.pone-header-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 20px;
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 20px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: var(--gestemas-shadow);
    min-height: 54px;
    /* Ensure touch target size */
}

/* Mobile Overrides for PONE Form */
@container module (max-width: 768px) {

    /* Stack the identification fields */
    .gestemas-grid--3 {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    /* Adjust floating groups for mobile to prevent overlap */
    .gestemas-floating-group {
        margin-bottom: 8px;
    }

    .gestemas-floating-group select,
    .gestemas-floating-group input,
    .gestemas-floating-group textarea {
        min-height: 50px;
        /* Larger touch target */
        padding-top: 18px;
        /* Space for label */
    }

    .gestemas-floating-group label {
        z-index: 5;
        /* Ensure label is above background but below text if needed */
    }
}

.pone-header-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
    border-color: var(--gestemas-primary);
}

.phc-icon {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--gestemas-primary), var(--as-color-primary));
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(var(--gestemas-primary-rgb), 0.3);
}

.pone-header-card.pending .phc-icon {
    background: linear-gradient(135deg, var(--gst-warning), var(--as-color-warning));
    animation: gestemas-pulse 2s infinite;
}

.pone-header-card.calibrated .phc-icon {
    background: linear-gradient(135deg, var(--as-color-success), var(--as-color-success-strong));
}

.phc-info {
    display: flex;
    flex-direction: column;
}

.phc-label {
    font-size: 10px;
    text-transform: uppercase;
    font-weight: 800;
    color: var(--gestemas-gray-500);
    letter-spacing: 0.05em;
}

.phc-value {
    font-size: 14px;
    font-weight: 800;
    color: var(--gestemas-gray-900);
}

/* Dashboard Cards PONE */
.glass-card-v3 {
    position: relative;
    overflow: hidden;
}

.obs-excerpt {
    font-size: 13px;
    line-height: 1.6;
    color: var(--gestemas-gray-600);
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    line-clamp: 3;
    font-style: italic;
}

.gestemas-card__footer-v3 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
}

/* Nexus Utility Pills & Badges */
.nexus-badge-soft {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: 700;
}

/* Pagination & States */
.premium-pagination {
    margin-top: 40px;
    display: flex;
    justify-content: center;
}

.pagination-wrapper {
    display: flex;
    gap: 8px;
}

.page-btn {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: white;
    color: var(--gestemas-gray-600);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.page-btn.active {
    background: var(--gestemas-primary);
    color: white;
    border-color: var(--gestemas-primary);
    box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.3);
}

.gestemas-loading-state,
.gestemas-empty-state {
    padding: 60px 20px;
    text-align: center;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 24px;
    border: 1px dashed rgba(0, 0, 0, 0.1);
}

@keyframes gestemas-pulse {
    0% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(1.05);
        opacity: 0.8;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Close Button Hero Visibility */
.modal-close-premium-hero {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: var(--as-color-danger);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    z-index: 10;
}

.modal-close-premium-hero:hover {
    background: var(--as-color-danger);
    color: white;
    transform: rotate(90deg) scale(1.1);
    box-shadow: 0 4px 15px rgba(239, 68, 68, 0.4);
}

.modal-close-premium-hero i {
    width: 24px;
    height: 24px;
    stroke-width: 3px;
}

/* Section Glass Containers */
.gestemas-module-root, .intervenciones-module, .pone-module, .tareas-module {
    container-type: inline-size;
    container-name: module;
}

.pone-section-glass {
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 24px;
    padding: 20px;
    transition: all 0.3s ease;
}

.section-heading {
    font-size: 0.85rem;
    text-transform: uppercase;
    color: var(--gestemas-primary);
    letter-spacing: 0.05em;
    margin: 0;
}

/* Observer Grid Premium */
.pone-observer-grid-premium {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

/* [NEW] Mobile-First Stack for Observer Cards */
@media (max-width: 650px) {
    .pone-observer-grid-premium {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
        gap: 8px;
    }

    .pone-observer-card {
        padding: 16px;
        /* Larger for touch */
    }

    .card-label {
        font-size: 13px;
        /* More readable on mobile */
    }
}

.pone-observer-card {
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 16px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.pone-observer-card.active {
    border-color: var(--as-color-success);
    background: rgba(16, 185, 129, 0.05);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.1);
}

.pone-observer-card.inactive {
    border-color: var(--as-color-danger);
    background: rgba(239, 68, 68, 0.05);
    opacity: 0.8;
}

.card-emoji {
    font-size: 1.25rem;
}

.card-label {
    display: block;
    font-size: 11px;
    font-weight: 800;
    color: var(--gestemas-gray-900);
    text-transform: uppercase;
}

.card-desc {
    display: block;
    font-size: 10px;
    color: var(--gestemas-gray-500);
    font-weight: 600;
}

.card-check {
    margin-left: auto;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--as-color-success);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.3s ease;
}

.active .card-check {
    opacity: 1;
    transform: scale(1);
}

.pone-textarea-compact {
    width: 100%;
    height: 48px;
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: white;
    padding: 10px 16px;
    font-size: 13px;
    resize: none;
    transition: border-color 0.3s;
}

.pone-textarea-compact:focus {
    outline: none;
    border-color: var(--gestemas-primary);
}

/* Matrix Horizontal Design */
.pone-matrix-horizontal-container {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pone-matrix-item {
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 16px;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 16px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.item-visual {
    width: 60px;
    height: 60px;
    border-radius: 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--gestemas-bg);
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
}

.item-code {
    font-size: 14px;
    font-weight: 900;
    color: var(--gestemas-gray-700);
}

.item-indicator {
    font-size: 10px;
    color: var(--gestemas-gray-400);
}

.item-info {
    flex: 1;
}

.item-label {
    display: block;
    font-size: 13px;
    font-weight: 800;
    color: var(--gestemas-gray-900);
}

.item-desc {
    display: block;
    font-size: 11px;
    color: var(--gestemas-gray-500);
    font-weight: 600;
}

/* Matrix States */
.pone-matrix-item.active {
    border-color: var(--as-color-success);
    background: rgba(16, 185, 129, 0.05);
    transform: translateX(4px);
}

.active .item-visual {
    background: var(--as-color-success);
    border-color: var(--as-color-success);
    color: white;
}

.active .item-code {
    color: white;
}

.active .item-indicator {
    color: white;
}

.pone-matrix-item.inactive {
    border-color: var(--as-color-danger);
    background: rgba(239, 68, 68, 0.05);
    transform: translateX(4px);
}

.inactive .item-visual {
    background: var(--as-color-danger);
    border-color: var(--as-color-danger);
    color: white;
}

.inactive .item-code {
    color: white;
}

.inactive .item-indicator {
    color: white;
}

/* Results & Composite Card */
.composite-score-card {
    background: linear-gradient(135deg, var(--gestemas-primary), var(--gestemas-primary-dark));
    border-radius: 20px;
    padding: 20px;
    color: white;
    display: flex;
    flex-direction: column;
    gap: 16px;
    box-shadow: 0 10px 30px rgba(var(--gestemas-primary-rgb), 0.3);
}

.score-item {
    text-align: center;
}

.score-label {
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    opacity: 0.8;
    letter-spacing: 0.1em;
}

.score-value {
    font-size: 1.5rem;
    font-weight: 900;
    font-family: var(--font-outfit);
}

.score-divider {
    height: 1px;
    background: rgba(255, 255, 255, 0.2);
}

/* Alpha Banner */
.pone-alpha-banner-premium {
    background: linear-gradient(90deg, rgba(var(--gestemas-primary-rgb), 0.1), transparent);
    border-left: 4px solid var(--gestemas-primary);
    padding: 16px;
    border-radius: 12px;
    margin-top: 24px;
}

.alpha-badge {
    display: inline-block;
    background: var(--gestemas-primary);
    color: white;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: 800;
    margin-bottom: 8px;
}

.alpha-text {
    font-size: 13px;
    line-height: 1.5;
    color: var(--gestemas-gray-700);
    margin: 0;
}

.alpha-footer {
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    color: var(--gestemas-primary);
}

/* PONE Mobile Overrides */
@container module (max-width: 768px) {
    .pone-observer-grid-premium {
        grid-template-columns: repeat(3, 1fr);
        gap: 8px;
    }

    .pone-observer-card {
        padding: 10px 6px;
        flex-direction: column;
        text-align: center;
        gap: 6px;
    }

    .card-label {
        font-size: 10px;
        line-height: 1.2;
    }

    .card-desc {
        display: none;
        /* Hide description on mobile to save space */
    }

    .card-check {
        position: absolute;
        top: 4px;
        right: 4px;
        width: 18px;
        height: 18px;
    }

    .pone-matrix-horizontal-container {
        gap: 8px;
        display: grid;
        grid-template-columns: 1fr;
    }

    .pone-matrix-item {
        padding: 12px;
        gap: 12px;
    }

    .item-visual {
        width: 52px;
        height: 52px;
        border-radius: 12px;
    }

    .item-code {
        font-size: 13px;
    }

    .pone-results-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .composite-score-card {
        flex-direction: row;
        justify-content: space-around;
        padding: 16px;
        border-radius: 16px;
    }

    .score-divider {
        width: 1px;
        height: 40px;
        display: block;
    }

    .score-value {
        font-size: 1.25rem;
    }
}

@container module (max-width: 480px) {
    .pone-observer-grid-premium {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .composite-score-card {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }

    .score-divider {
        width: 100%;
        height: 1px;
    }
    
    .score-item {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    
    .score-value {
        font-size: 1.1rem;
    }
}

/* ═══════════════════════════════════════════════════════════
   8. MODULE: AGENDA
   ═══════════════════════════════════════════════════════════ */
.agenda-view {
    padding: 0;
    container-type: inline-size;
    container-name: agenda;
}

.agenda-header {
    margin-bottom: var(--block-gap-mobile, 16px);
}

@media (min-width: 1025px) {
    .agenda-header {
        margin-bottom: var(--block-gap, 12px);
        /* Reduced from 24px */
    }
}

/* Fix Annual View Super Whitespace */
.agenda-view .gestemas-page-header {
    padding-bottom: 0;
    margin-bottom: 16px;
}

.agenda-view .agenda-layout {
    margin-top: 0;
    padding-top: 0;
}

.page-icon-circle {
    width: 48px;
    height: 48px;
    background: rgba(var(--gestemas-primary-rgb), 0.1);
    color: var(--gestemas-primary);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.view-toggle-group {
    display: flex;
    background: var(--gestemas-gray-100);
    border-radius: 10px;
    padding: 4px;
    gap: 4px;
}

.view-btn {
    background: transparent;
    border: none;
    padding: 8px;
    border-radius: 8px;
    cursor: pointer;
    color: var(--gestemas-gray-500);
    transition: 0.2s;
}

.view-btn.is-active,
.view-btn:hover {
    background: white;
    color: var(--gestemas-gray-900);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Layout */
.agenda-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--grid-gap, 24px);
    min-height: 70vh;
}

@container agenda (max-width: 1024px) {
    .agenda-layout {
        gap: 12px;
        grid-template-columns: 1fr;
    }
}

/* Sidebar */
.agenda-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--block-gap, 24px);
}

@container agenda (max-width: 1024px) {
    .agenda-sidebar {
        gap: 16px;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }
}

.mini-calendar {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(12px);
    padding: 15px;
    border-radius: 16px;
    border: 1px solid var(--glass-border);
}

.mini-cal-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.mini-cal-title {
    font-size: 15px;
    font-weight: 700;
}

.btn-icon-sm {
    background: rgba(0, 0, 0, 0.05);
    border: none;
    padding: 4px;
    border-radius: 8px;
    cursor: pointer;
}

.mini-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    text-align: center;
    font-size: 11px;
}

.mini-cal-grid .day-header {
    font-weight: 700;
    color: var(--gestemas-gray-400);
    padding: 4px 0;
}

.mini-cal-grid .day-cell {
    padding: 8px 2px;
    border-radius: 8px;
    cursor: pointer;
    transition: 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
}

.mini-cal-grid .day-cell:hover {
    background: rgba(0, 0, 0, 0.05);
}

.mini-cal-grid .day-cell.is-today {
    background: var(--gestemas-primary);
    color: white;
    font-weight: 700;
}

.mini-cal-grid .day-cell.is-selected {
    background: var(--gestemas-secondary);
    color: white;
}

.sidebar-section-title {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gestemas-gray-400);
    margin-bottom: var(--block-gap);
}

.upcoming-events-panel,
.student-filter-panel {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(12px);
    padding: 20px;
    border-radius: 16px;
    border: 1px solid var(--glass-border);
}

.upcoming-list .event-item {
    display: flex;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    cursor: pointer;
    transition: all 0.2s;
}

.upcoming-list .event-item:hover {
    background: rgba(0, 0, 0, 0.02);
    border-radius: 8px;
    padding-left: 8px;
}

.event-item .event-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin-top: 4px;
}

.event-info .event-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--gestemas-gray-800);
}

.event-info .event-time {
    font-size: 11px;
    color: var(--gestemas-gray-400);
}

.student-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.chip {
    padding: 6px 12px;
    border-radius: 20px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: white;
    font-size: 12px;
    cursor: pointer;
    transition: 0.2s;
}

.chip.is-active {
    background: var(--gestemas-primary);
    color: white;
    border-color: var(--gestemas-primary);
}

/* Main Calendar Grid */
.agenda-main-grid {
    background: white;
    border-radius: 16px;
    border: 1px solid var(--glass-border);
    overflow: hidden;
}

.calendar-header-row {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    background: var(--gestemas-gray-50);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.calendar-header-row .header-cell {
    padding: 14px;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    color: var(--gestemas-gray-500);
    text-transform: uppercase;
}

.calendar-body-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    grid-auto-rows: minmax(100px, 1fr);
}

.calendar-cell {
    border: 1px solid rgba(0, 0, 0, 0.03);
    padding: 8px;
    min-height: 100px;
    position: relative;
    background: white;
}

.calendar-cell .day-number {
    font-size: 13px;
    font-weight: 600;
    color: var(--gestemas-gray-700);
}

.calendar-cell.is-today .day-number {
    background: var(--gestemas-primary);
    color: white;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}

.calendar-cell.other-month {
    background: var(--gestemas-gray-50);
}

.calendar-cell.other-month .day-number {
    color: var(--gestemas-gray-300);
}

.cell-events {
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.cell-event {
    font-size: 11px;
    padding: 3px 6px;
    border-radius: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
}

.cell-event.type-intervencion {
    background: rgba(var(--as-color-primary-rgb), 0.15);
    color: var(--gestemas-primary-dark);
}

.cell-event.type-tarea {
    background: rgba(var(--as-color-success-rgb), 0.15);
    color: var(--as-color-success-strong);
}

.cell-event.type-cita {
    background: rgba(var(--as-color-danger-rgb), 0.15);
    color: var(--as-color-danger-strong);
}

.cell-event.type-medicamento {
    background: rgba(var(--as-color-warning-rgb), 0.15);
    color: var(--as-color-warning);
}

/* Dot Indicators for Mobile */
.dot-indicators {
    display: flex;
    justify-content: center;
    gap: 3px;
    margin-top: 6px;
    flex-wrap: wrap;
}

.event-dot-sm {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.calendar-loading {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px;
    color: var(--gestemas-gray-400);
}

@container agenda (max-width: 768px) {
    .calendar-header-row .header-cell {
        padding: 8px 4px;
        font-size: 10px;
    }

    .calendar-body-grid {
        grid-auto-rows: minmax(70px, 1fr);
    }

    .calendar-cell {
        min-height: 70px;
        padding: 4px;
    }

    .cell-events {
        display: none;
    }

    .dot-indicators {
        display: flex;
    }
}

@container agenda (max-width: 480px) {
    .agenda-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .agenda-header .gestemas-page-header__actions {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 8px;
    }

    .calendar-body-grid {
        grid-auto-rows: minmax(50px, 1fr);
    }

    .calendar-cell {
        min-height: 50px;
        padding: 2px;
    }

    .day-number {
        font-size: 11px;
    }

    .mini-calendar {
        padding: 10px;
    }

    .mini-cal-grid {
        gap: 2px;
    }
    
    .mini-cal-grid .day-cell {
        min-height: 24px;
        font-size: 10px;
    }
}

/* ═══════════════════════════════════════════════════════════
   9. MODULE: REPORTES
   ═══════════════════════════════════════════════════════════ */
.reports-hub-page .kpi-row {
    margin-bottom: var(--block-gap, 24px);
}

/* Intelligent Grid for KPIs */
.kpi-row.gestemas-grid--4 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
}

@container module (max-width: 480px) {
    .kpi-row.gestemas-grid--4 {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .kpi-card {
        flex-direction: column;
        align-items: flex-start;
        padding: 16px;
        gap: 12px;
    }

    .kpi-icon {
        width: 40px;
        height: 40px;
        font-size: 18px;
        margin-bottom: 4px;
    }

    .kpi-value {
        font-size: 20px;
    }

    .kpi-label {
        font-size: 10px;
    }
}

.kpi-card {
    background: white;
    border-radius: 20px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    border: 1px solid var(--glass-border);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.kpi-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
    border-color: var(--gestemas-primary);
}

.kpi-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0) 100%);
    opacity: 0;
    transition: 0.3s;
    pointer-events: none;
}

.kpi-card:hover::after {
    opacity: 1;
}

.kpi-icon {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.icon-blue {
    background: var(--as-color-info-soft-alt);
    color: var(--as-color-info-strong);
}

.icon-purple {
    background: var(--as-color-purple-soft);
    color: var(--as-color-purple-strong);
}

.icon-amber {
    background: var(--as-color-amber-soft);
    color: var(--as-color-warning);
}

.icon-emerald {
    background: var(--as-color-success-soft);
    color: var(--as-color-success-strong);
}

.kpi-label {
    display: block;
    font-size: 11px;
    color: var(--gestemas-gray-500);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin-bottom: 4px;
}

.kpi-value {
    display: block;
    font-size: 28px;
    font-weight: 800;
    color: var(--gestemas-gray-900);
    line-height: 1.1;
    letter-spacing: -0.5px;
}

/* Generator Stepper */
.generator-stepper {
    display: flex;
    align-items: flex-start;
    gap: 24px;
    background: linear-gradient(to bottom, var(--gestemas-gray-50), white);
    padding: 32px;
    border-radius: 24px;
    margin-bottom: 32px;
    border: 1px solid var(--gestemas-gray-200);
}

.step-item {
    flex: 1;
    min-width: 200px;
    position: relative;
}

.step-separator {
    padding-top: 38px;
    color: var(--gestemas-gray-300);
    opacity: 0.5;
}

/* Sidebar Layout */
.gestemas-grid--sidebar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 32px;
}

@container module (max-width: 1024px) {
    .gestemas-grid--sidebar {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .side-column {
        order: 2;
    }
}

@container module (max-width: 768px) {
    .generator-stepper {
        flex-direction: column;
        gap: 24px;
        padding: 20px;
        background: var(--gestemas-gray-50);
    }

    .step-separator {
        display: none;
    }

    .step-item {
        width: 100%;
        border-left: 2px solid var(--gestemas-gray-200);
        padding-left: 16px;
    }

    .kpi-card {
        padding: 20px;
    }

    .kpi-icon {
        width: 44px;
        height: 44px;
        font-size: 20px;
    }

    .kpi-value {
        font-size: 24px;
    }
}

/* ═══════════════════════════════════════════════════════════
   10. MODULE: DASHBOARD
   ═══════════════════════════════════════════════════════════ */
.dashboard-header-smart {
    width: 100%;
    margin-bottom: var(--smart-v-padding, 24px);
    padding-top: 24px;
    padding-bottom: 24px;
    /* NO lateral padding: controlled by parent container */
}

.header-profile-smart {
    display: flex;
    gap: 20px;
    align-items: center;
}

.header-welcome-smart .user-name {
    margin: 0;
    font-size: clamp(1.5rem, 3vw, 2.5rem);
}

.header-welcome-smart .user-badges {
    margin-top: 8px;
}

.header-actions-smart {
    margin-left: auto;
}

/* Smart Metrics */
.smart-metric-card {
    padding: 24px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.metric-icon-box {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.metric-icon-box.blue {
    background: rgba(var(--as-color-info-rgb), 0.1);
    color: var(--as-color-info-bright);
}

.metric-icon-box.purple {
    background: rgba(139, 92, 246, 0.1);
    color: var(--as-color-violet);
}

.metric-icon-box.orange {
    background: rgba(249, 115, 22, 0.1);
    color: var(--as-color-orange);
}

.metric-icon-box.rose {
    background: rgba(244, 63, 94, 0.1);
    color: var(--as-color-rose);
}

.metric-label-smart {
    font-size: 0.9em;
    opacity: 0.7;
    display: block;
    margin-bottom: 4px;
}

.metric-value-smart {
    font-size: 2.5em;
    margin: 0;
    line-height: 1;
}

.trend-pill-smart {
    color: var(--as-color-success);
    font-size: 0.8em;
    margin-left: 8px;
    vertical-align: middle;
}

/* Panels */
.dashboard-panel-smart {
    min-height: 400px;
    display: flex;
    flex-direction: column;
}

.panel-header-smart {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

.chart-container-smart {
    flex: 1;
    position: relative;
    width: 100%;
    min-height: 250px;
}

/* Feed */
.feed-panel-smart {
    max-height: 500px;
    overflow-y: auto;
}

.feed-header-sticky {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    position: sticky;
    top: 0;
    background: inherit;
    z-index: 10;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.feed-item-smart {
    display: flex;
    gap: 16px;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

.feed-marker-smart {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-top: 6px;
}

.feed-content-smart {
    flex: 1;
}

.feed-top-smart {
    display: flex;
    justify-content: space-between;
    font-size: 0.85em;
    opacity: 0.7;
    margin-bottom: 4px;
}

.feed-title-smart {
    margin: 0 0 8px;
    font-size: 1em;
}

.feed-tag-smart {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.75em;
    background: rgba(0, 0, 0, 0.05);
    font-weight: 600;
}

/* Quick Actions */
.quick-actions-grid {
    --grid-gap: 12px;
}

/* Priority List */
.card-header-smart {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 16px;
}

.priority-list-smart {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.priority-item-smart {
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
}

/* AI Widget */
.ai-widget-smart {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.4));
}

.ai-header-smart {
    display: flex;
    gap: 8px;
    align-items: center;
    color: var(--gestemas-primary);
    font-weight: 700;
    margin-bottom: 12px;
}

@container module (max-width: 768px) {
    .dashboard-header-smart {
        padding-top: 16px;
        padding-bottom: 16px;
        /* Zero lateral padding on mobile: parent handles margins */
    }

    .header-profile-smart {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    /* ═══════════════════════════════════════════════════════════
   12. MODULE: STUDENT PROFILE 360 (Migrated)
   ═══════════════════════════════════════════════════════════ */

    .gestemas-profile-360 {
        --p-header-height: 80px;
        --p-subnav-height: 64px;
        --p-total-sticky: calc(var(--p-header-height) + var(--p-subnav-height));
        background: var(--gestemas-bg);
        min-height: 100vh;
        animation: slideUp 0.5s ease-out;
    }

    /* 1. MAIN HEADER (Glassmorphism V3) */
    .gestemas-profile-header-premium {
        position: sticky;
        top: 0;
        z-index: 100;
        height: var(--p-header-height);
        background: var(--glass-bg-heavy);
        backdrop-filter: blur(20px) saturate(160%);
        -webkit-backdrop-filter: blur(20px) saturate(160%);
        border-bottom: 1px solid var(--glass-border);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 40px;
        transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .header-left-group {
        display: flex;
        align-items: center;
        gap: 20px;
    }

    .student-info-mini {
        display: flex;
        align-items: center;
        gap: 16px;
    }

    .mini-avatar {
        width: 48px;
        height: 48px;
        background: var(--gestemas-primary);
        border-radius: 14px;
        color: white;
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 800;
        font-size: 18px;
        box-shadow: 0 8px 16px -4px rgba(var(--gestemas-primary-rgb), 0.3);
    }

    .mini-details h1 {
        font-size: 20px;
        font-weight: 800;
        margin: 0;
        color: var(--gestemas-gray-900);
        letter-spacing: -0.02em;
    }

    .mini-details p {
        font-size: 13px;
        color: var(--gestemas-gray-500);
        font-weight: 600;
        margin: 0;
    }

    /* 2. SUBMENU BAR (The "Franja") */
    .gestemas-profile-subnav-bar {
        position: sticky;
        top: var(--p-header-height);
        z-index: 90;
        height: var(--p-subnav-height);
        background: var(--glass-bg);
        backdrop-filter: blur(24px) saturate(180%);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        border-bottom: 1px solid var(--glass-border);
        display: flex;
        align-items: center;
        padding: 0 var(--page-padding-desktop, 40px);
        box-shadow: 0 4px 20px -10px rgba(0, 0, 0, 0.05);
    }

    .subnav-scroll-container {
        display: flex;
        gap: 12px;
        overflow-x: auto;
        width: 100%;
        scrollbar-width: none;
    }

    .subnav-item {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 20px;
        border-radius: 99px;
        border: 1px solid transparent;
        background: transparent;
        color: var(--gestemas-gray-500);
        font-size: 14px;
        font-weight: 800;
        white-space: nowrap;
        cursor: pointer;
        transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .subnav-item:hover {
        background: rgba(var(--gestemas-primary-rgb), 0.05);
        color: var(--gestemas-primary);
    }

    .subnav-item.is-active {
        background: var(--gestemas-primary);
        color: white;
        box-shadow: 0 8px 16px -4px rgba(var(--gestemas-primary-rgb), 0.3);
    }

    /* 3. GRID LAYOUT & SIDEBAR */
    .gestemas-profile-grid {
        display: grid;
        grid-template-columns: 320px 1fr;
        gap: 32px;
        padding: 32px 40px;
        max-width: 1600px;
        margin: 0 auto;
    }

    .gestemas-profile-sidebar {
        display: flex;
        flex-direction: column;
        gap: 24px;
    }

    /* Sidebar Cards Standardized */
    .gestemas-profile-sidebar .gestemas-card {
        background: var(--glass-card-bg, rgba(255, 255, 255, 0.7));
        backdrop-filter: blur(10px);
        border: 1px solid var(--glass-border);
        border-radius: 24px;
        overflow: hidden;
        transition: all 0.3s ease;
    }

    .gestemas-profile-sidebar .gestemas-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--gestemas-shadow-lg);
    }

    @media (max-width: 1100px) {
        .gestemas-profile-grid {
            grid-template-columns: 1fr;
        }
    }

    /* 4. GLASSMORPHISM V3.2 SUPER PRO - Card Glow Effect */
    .card-glass-glow {
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(24px) saturate(180%);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        border: 1px solid rgba(255, 255, 255, 0.4);
        border-radius: 20px;
        box-shadow:
            0 8px 32px rgba(0, 0, 0, 0.08),
            0 0 0 1px rgba(255, 255, 255, 0.1) inset,
            0 0 80px -20px rgba(var(--gestemas-primary-rgb), 0.15);
        transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
        position: relative;
        overflow: hidden;
    }

    .card-glass-glow::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);
    }

    .card-glass-glow:hover {
        transform: translateY(-4px);
        box-shadow:
            0 20px 40px rgba(0, 0, 0, 0.12),
            0 0 0 1px rgba(255, 255, 255, 0.2) inset,
            0 0 100px -10px rgba(var(--gestemas-primary-rgb), 0.25);
    }

    /* 5. HEADER ACTIONS (Glass Buttons) */
    .header-actions-group {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .action-btn-glass {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 16px;
        background: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(10px);
        border: 1px solid var(--glass-border);
        border-radius: 12px;
        color: var(--gestemas-gray-700);
        font-size: 13px;
        font-weight: 700;
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .action-btn-glass:hover {
        background: var(--gestemas-primary);
        color: white;
        border-color: var(--gestemas-primary);
        transform: translateY(-2px);
        box-shadow: 0 8px 20px -4px rgba(var(--gestemas-primary-rgb), 0.4);
    }

    .action-btn-glass i {
        width: 16px;
        height: 16px;
    }

    .back-btn-profile {
        width: 40px;
        height: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(255, 255, 255, 0.8);
        backdrop-filter: blur(10px);
        border: 1px solid var(--glass-border);
        border-radius: 12px;
        color: var(--gestemas-gray-600);
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .back-btn-profile:hover {
        background: var(--gestemas-primary);
        color: white;
        border-color: var(--gestemas-primary);
    }

    /* 6. MOBILE-FIRST RESPONSIVE (Glassmorphism V3.2 Super Pro) */
    @media (min-width: 481px) and (max-width: 768px) {

        /* Header Mobile Optimization */
        .gestemas-profile-header-premium {
            --p-header-height: 56px;
            height: var(--p-header-height);
            padding: 0 16px;
            gap: 12px;
        }

        .header-left-group {
            gap: 12px;
            flex: 1;
            min-width: 0;
            /* Prevent overflow */
        }

        .back-btn-profile {
            width: 36px;
            height: 36px;
            flex-shrink: 0;
        }

        .student-info-mini {
            gap: 10px;
            min-width: 0;
            flex: 1;
        }

        .mini-avatar {
            width: 36px;
            height: 36px;
            font-size: 14px;
            border-radius: 10px;
            flex-shrink: 0;
        }

        .mini-details {
            min-width: 0;
            flex: 1;
        }

        .mini-details h1 {
            font-size: 16px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 100%;
        }

        .mini-details p {
            display: none;
        }

        /* Header Actions - Icons Only on Mobile */
        .header-actions-group {
            gap: 6px;
            flex-shrink: 0;
        }

        .action-btn-glass {
            width: 36px;
            height: 36px;
            padding: 0;
            justify-content: center;
            border-radius: 10px;
        }

        .action-btn-glass span {
            display: none;
        }

        .action-btn-glass i {
            width: 18px;
            height: 18px;
        }

        /* Subnav 100% Fluid Mobile */
        .gestemas-profile-subnav-bar {
            top: 56px;
            height: 52px;
            padding: 0;
            width: 100vw;
            margin-left: calc(-1 * var(--page-padding-mobile, 10px));
            margin-right: calc(-1 * var(--page-padding-mobile, 10px));
            overflow: hidden;
        }

        .subnav-scroll-container {
            padding: 0 10px;
            gap: 8px;
            -webkit-overflow-scrolling: touch;
            scroll-snap-type: x mandatory;
        }

        .subnav-scroll-container::after {
            content: '';
            padding-right: 10px;
        }

        .subnav-item {
            padding: 8px 14px;
            font-size: 12px;
            gap: 6px;
            scroll-snap-align: start;
        }

        .subnav-item i {
            width: 14px;
            height: 14px;
        }

        /* Profile Grid Mobile */
        .gestemas-profile-grid {
            padding: var(--page-padding-mobile, 10px);
            gap: var(--block-gap-mobile, 12px);
        }

    }

    /* 7. PROFILE IDENTITY & COMPONENTS */
    .gestemas-identity-card {
        overflow: hidden;
        position: relative;
    }

    .gestemas-identity-banner {
        height: 80px;
        background: linear-gradient(135deg, var(--gestemas-primary) 0%, var(--gestemas-secondary) 100%);
        opacity: 0.8;
    }

    .gestemas-identity-avatar {
        width: 100px;
        height: 100px;
        background: white;
        border-radius: 24px;
        position: absolute;
        top: 30px;
        left: 50%;
        transform: translateX(-50%);
        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 32px;
        font-weight: 800;
        color: var(--gestemas-primary);
        font-family: 'Outfit', sans-serif;
        border: 4px solid white;
    }

    .gestemas-profile-role {
        font-size: 13px;
        font-weight: 600;
        color: var(--gestemas-gray-500);
        text-transform: uppercase;
        letter-spacing: 1px;
    }

    .gestemas-profile-stats-row {
        display: flex;
        justify-content: center;
        gap: var(--grid-gap, 24px);
        margin-top: var(--block-gap, 24px);
        padding-top: var(--block-gap, 24px);
        border-top: 1px solid var(--gestemas-gray-100);
    }

    .profile-stat-box {
        display: flex;
        flex-direction: column;
    }

    .profile-stat-box strong {
        font-size: 20px;
        color: var(--gestemas-gray-900);
    }

    .profile-stat-box span {
        font-size: 11px;
        text-transform: uppercase;
        color: var(--gestemas-gray-400);
        font-weight: 700;
    }

    /* Metadata NEE & Sidebar Cards */
    .gestemas-nee-summary {
        font-size: 14px;
        line-height: 1.6;
        color: var(--gestemas-gray-700);
    }

    .support-item {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 12px;
        padding: 10px;
        border-radius: 12px;
        background: var(--gestemas-gray-50);
    }

    .support-icon {
        width: 36px;
        height: 36px;
        background: white;
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 18px;
        box-shadow: var(--gestemas-shadow-sm);
    }

    .support-info strong {
        display: block;
        font-size: 14px;
        color: var(--gestemas-gray-800);
    }

    .support-info span {
        font-size: 11px;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
        font-weight: 700;
    }

    .support-contact {
        display: flex;
        align-items: center;
        gap: 10px;
        font-size: 13px;
        color: var(--gestemas-gray-600);
        margin-bottom: 8px;
    }

    .support-contact i {
        width: 14px;
        height: 14px;
        color: var(--gestemas-primary);
    }

    /* Health Tab Styles */
    .badge-atencion {
        display: inline-block;
        padding: 2px 8px;
        background: var(--gestemas-primary-light);
        color: var(--gestemas-primary);
        border-radius: 4px;
        font-size: 10px;
        font-weight: 700;
        text-transform: uppercase;
    }

    .meds-compact-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .med-compact-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
    }

    .med-bullet {
        width: 6px;
        height: 6px;
        background: var(--gestemas-error);
        border-radius: 50%;
        margin-top: 6px;
    }

    .med-details {
        display: flex;
        flex-direction: column;
    }

    .med-details strong {
        font-size: 13px;
        color: var(--gestemas-gray-800);
    }

    .med-details span {
        font-size: 11px;
        color: var(--gestemas-gray-500);
    }

    .gestemas-hover-card {
        transition: transform 0.2s, box-shadow 0.2s;
    }

    .gestemas-hover-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    }

    /* Timeline Modern View */
    .timeline-header-actions {
        margin-bottom: 24px;
        padding-bottom: 16px;
        border-bottom: 1px solid var(--gestemas-gray-100);
    }

    .timeline-month-divider {
        font-size: 14px;
        font-weight: 800;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
        letter-spacing: 2px;
        margin: 32px 0 16px;
        padding-left: 20px;
        border-left: 2px solid var(--gestemas-gray-200);
    }

    .timeline-card {
        display: flex;
        margin-bottom: 16px;
        cursor: pointer;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        border: 1px solid transparent;
    }

    .timeline-card:hover {
        transform: translateX(8px);
        border-color: var(--gestemas-primary-light);
        box-shadow: var(--gestemas-shadow-sm);
    }

    .timeline-card__indicator {
        width: 6px;
        border-radius: 10px 0 0 10px;
    }

    .timeline-card__content {
        flex: 1;
        padding: 20px;
    }

    .timeline-card__header {
        display: flex;
        justify-content: space-between;
        margin-bottom: 8px;
    }

    .timeline-type {
        font-size: 11px;
        font-weight: 800;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
    }

    .timeline-date {
        font-size: 12px;
        color: var(--gestemas-gray-400);
    }

    .timeline-title {
        margin: 0 0 8px;
        font-size: 17px;
        color: var(--gestemas-gray-900);
    }

    .timeline-excerpt {
        font-size: 14px;
        color: var(--gestemas-gray-600);
        line-height: 1.6;
        margin-bottom: 12px;
    }

    .timeline-topics {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin-bottom: 16px;
    }

    .topic-tag {
        font-size: 11px;
        font-weight: 600;
        padding: 4px 10px;
        background: var(--gestemas-gray-50);
        border-radius: 8px;
        color: var(--gestemas-gray-600);
    }

    .topic-tag--more {
        background: transparent;
        border: 1px dashed var(--gestemas-gray-200);
    }

    .timeline-footer {
        display: flex;
        align-items: center;
        gap: 20px;
    }

    .timeline-specialist,
    .timeline-duration {
        display: flex;
        align-items: center;
        gap: 6px;
        font-size: 12px;
        color: var(--gestemas-gray-500);
    }

    .timeline-specialist i,
    .timeline-duration i {
        width: 14px;
        height: 14px;
    }

    /* Tabs */
    .gestemas-profile-tabs {
        display: flex;
        gap: 8px;
        padding: 8px;
        border-radius: 20px;
        margin-bottom: 24px;
    }

    .tab-btn {
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 12px;
        border-radius: 14px;
        background: transparent;
        border: none;
        font-size: 14px;
        font-weight: 600;
        color: var(--gestemas-gray-500);
        cursor: pointer;
        transition: var(--gestemas-transition);
    }

    .tab-btn i {
        width: 18px;
        height: 18px;
    }

    .tab-btn.is-active {
        background: white;
        color: var(--gestemas-primary);
        box-shadow: var(--gestemas-shadow-sm);
    }

    /* Analytics & Dimensions */
    .gestemas-dimension-summary-list {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .gestemas-dimension-row {
        background: var(--gestemas-gray-50);
        padding: 16px;
        border-radius: 16px;
    }

    .gestemas-dimension-info {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 10px;
    }

    .dim-label {
        display: flex;
        align-items: center;
        gap: 10px;
    }

    .dim-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
    }

    .dim-value {
        font-size: 12px;
        font-weight: 700;
        color: var(--gestemas-primary);
    }

    .gestemas-dimension-progress__bar {
        height: 8px;
        background: var(--gestemas-gray-200);
        border-radius: 10px;
        overflow: hidden;
    }

    .gestemas-dimension-progress__fill {
        height: 100%;
        border-radius: 10px;
        transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
    }

    /* Tasks & Merits */
    .gestemas-tasks-logros-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 24px;
    }

    @media (min-width: 481px) and (max-width: 768px) {
        .gestemas-tasks-logros-grid {
            grid-template-columns: 1fr;
        }
    }

    .gestemas-task-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
        padding: 12px;
        border-radius: 12px;
        background: var(--gestemas-gray-50);
        margin-bottom: 10px;
        transition: all 0.2s;
    }

    .gestemas-task-item--done {
        opacity: 0.7;
    }

    .gestemas-task-item--done .gestemas-task-item__title {
        text-decoration: line-through;
    }

    .gestemas-suggestion-item {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
        padding: 12px;
        border-bottom: 1px solid rgba(139, 92, 246, 0.1);
        box-sizing: border-box;
    }

    .gestemas-suggestion-item__main {
        display: flex;
        align-items: flex-start;
        gap: 12px;
        min-width: 0;
        flex: 1 1 auto;
    }

    .gestemas-suggestion-item__icon {
        width: 32px;
        height: 32px;
        border-radius: 8px;
        background: rgba(245, 158, 11, 0.1);
        color: #f59e0b;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }

    .gestemas-suggestion-item__content {
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 4px;
        flex: 1 1 auto;
    }

    .gestemas-suggestion-item__title,
    .gestemas-smart-tip-card__title {
        min-width: 0;
        color: var(--gestemas-gray-900);
        font-weight: 750;
        line-height: 1.2;
        overflow-wrap: anywhere;
        word-break: normal;
    }

    .gestemas-suggestion-item__title {
        font-size: 14px;
    }

    .gestemas-suggestion-item__meta {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 6px;
        min-width: 0;
        font-size: 11px;
        color: var(--gestemas-gray-500);
    }

    .gestemas-suggestion-item__dimension {
        color: var(--gestemas-primary);
        font-weight: 700;
    }

    .gestemas-suggestion-item__action {
        flex-shrink: 0;
        align-self: center;
        white-space: nowrap;
    }

    .gestemas-smart-tips-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .gestemas-smart-tip-card {
        position: relative;
        background: rgba(255, 255, 255, 0.5);
        padding: 12px;
        border-radius: 12px;
        border: 1px solid rgba(255, 255, 255, 0.4);
        transition: transform 0.2s ease, box-shadow 0.2s ease;
        cursor: pointer;
        overflow: hidden;
        box-sizing: border-box;
    }

    .gestemas-smart-tip-card:hover {
        transform: translateY(-1px);
        box-shadow: 0 8px 20px rgba(99, 102, 241, 0.08);
    }

    .gestemas-smart-tip-card__head {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 8px;
        min-width: 0;
        margin-bottom: 6px;
    }

    .gestemas-smart-tip-card__title {
        font-size: 13px;
        flex: 1 1 auto;
    }

    .gestemas-smart-tip-card__type {
        flex-shrink: 0;
        max-width: 44%;
        white-space: nowrap;
    }

    .gestemas-smart-tip-card__content {
        font-size: 12px;
        color: var(--gestemas-gray-600);
        line-height: 1.5;
        overflow-wrap: anywhere;
    }

    .gestemas-smart-tip-card__dimension {
        margin-top: 8px;
        font-size: 10px;
        color: var(--gestemas-primary);
        font-weight: 700;
        overflow-wrap: anywhere;
    }

    .gestemas-smart-tip-card__actions {
        display: flex;
        justify-content: flex-end;
        gap: 6px;
        margin-top: 8px;
        flex-wrap: wrap;
    }

    .gestemas-smart-tip-card__new {
        position: absolute;
        top: -8px;
        right: -8px;
        background: var(--gestemas-primary);
        color: white;
        font-size: 9px;
        font-weight: 800;
        padding: 2px 6px;
        border-radius: 6px;
        box-shadow: 0 4px 8px rgba(99,102,241,0.3);
        z-index: 1;
    }

    /* Clinical & Evolution Styles */
    .clinical-tag {
        display: inline-block;
        padding: 6px 12px;
        background: rgba(var(--gestemas-accent-rgb), 0.1);
        color: var(--gestemas-accent);
        border-radius: 20px;
        font-size: 13px;
        font-weight: 800;
        text-transform: uppercase;
    }

    .gestemas-nee-tags-display {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }

    .nee-chip {
        padding: 4px 10px;
        background: var(--gestemas-gray-50);
        border: 1px solid var(--gestemas-gray-200);
        border-radius: 8px;
        font-size: 12px;
        font-weight: 600;
        color: var(--gestemas-gray-600);
    }

    .reference-box {
        background: var(--gestemas-gray-50);
        padding: 20px;
        border-radius: 16px;
        border-left: 4px solid var(--gestemas-primary);
    }

    .reference-box strong {
        display: block;
        font-size: 14px;
        margin-bottom: 5px;
        color: var(--gestemas-gray-800);
    }

    /* Dropdown Actions */
    .gestemas-dropdown {
        position: relative;
        display: inline-block;
    }

    .gestemas-dropdown-menu {
        position: absolute;
        top: 100%;
        right: 0;
        margin-top: 8px;
        background: white;
        min-width: 220px;
        border-radius: 12px;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
        border: 1px solid var(--gestemas-gray-100);
        padding: 8px;
        z-index: 1000;
        display: none;
        animation: fadeInScale 0.2s ease-out;
    }

    .gestemas-dropdown:hover .gestemas-dropdown-menu {
        display: block;
    }

    .dropdown-item {
        display: flex;
        align-items: center;
        padding: 10px 16px;
        color: var(--gestemas-gray-700);
        text-decoration: none;
        font-size: 14px;
        font-weight: 600;
        border-radius: 8px;
        transition: all 0.2s;
    }

    .dropdown-item:hover {
        background: var(--gestemas-gray-50);
        color: var(--gestemas-primary);
    }

    .dropdown-toggle {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    /* Form Elements */
    .gestemas-select {
        appearance: none;
        background-color: white;
        border: 1px solid var(--gestemas-gray-200);
        border-radius: 10px;
        padding: 8px 32px 8px 12px;
        font-size: 14px;
        font-weight: 500;
        color: var(--gestemas-gray-700);
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 10px center;
        background-size: 16px;
        cursor: pointer;
        transition: var(--gestemas-transition);
    }

    .gestemas-select:focus {
        outline: none;
        border-color: var(--gestemas-primary);
        box-shadow: 0 0 0 3px rgba(var(--gestemas-primary-rgb), 0.1);
    }

    .gestemas-select--sm {
        padding: 6px 28px 6px 10px;
        font-size: 13px;
        border-radius: 8px;
    }

    @keyframes fadeInScale {
        from {
            opacity: 0;
            transform: scale(0.95) translateY(-10px);
        }

        to {
            opacity: 1;
            transform: scale(1) translateY(0);
        }
    }

    @keyframes slideUp {
        from {
            opacity: 0;
            transform: translateY(20px);
        }

        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    /* Medications List */
    .gestemas-medication-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .medication-item {
        display: flex;
        align-items: flex-start;
        gap: 16px;
        background: var(--gestemas-gray-50);
        padding: 16px;
        border-radius: 12px;
        transition: all 0.2s;
    }

    .medication-item:hover {
        background: white;
        box-shadow: var(--gestemas-shadow-sm);
        transform: translateY(-2px);
    }

    .med-icon {
        width: 40px;
        height: 40px;
        background: var(--as-color-info-soft-alt);
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 20px;
    }

    .med-info {
        flex: 1;
    }

    .med-info strong {
        display: block;
        color: var(--gestemas-gray-900);
        font-size: 14px;
        margin-bottom: 4px;
    }

    .med-dose {
        display: block;
        font-size: 12px;
        font-weight: 600;
        color: var(--gestemas-primary);
        text-transform: uppercase;
        margin-bottom: 6px;
    }

    .med-notes {
        font-size: 13px;
        color: var(--gestemas-gray-600);
        line-height: 1.4;
        margin: 0;
    }

    .med-actions {
        display: flex;
        gap: 8px;
    }

    /* KPIs Grid */
    .gestemas-kpis-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
        gap: 16px;
    }

    .gestemas-kpi-card {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 20px;
        border-radius: 16px;
    }

    .kpi-icon {
        width: 48px;
        height: 48px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }

    .kpi-icon i {
        width: 24px;
        height: 24px;
    }

    .kpi-content {
        display: flex;
        flex-direction: column;
    }

    .kpi-value {
        font-size: 24px;
        font-weight: 800;
        color: var(--gestemas-gray-900);
        font-family: 'Outfit', sans-serif;
    }

    .kpi-label {
        font-size: 12px;
        color: var(--gestemas-gray-500);
        text-transform: uppercase;
        font-weight: 600;
    }

    /* Recent Activity List */
    .recent-activity-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .recent-activity-item {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px;
        background: var(--gestemas-gray-50);
        border-radius: 12px;
        transition: all 0.2s;
    }

    .recent-activity-item:hover {
        background: var(--gestemas-gray-100);
    }

    .activity-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        flex-shrink: 0;
    }

    .activity-content {
        flex: 1;
        display: flex;
        flex-direction: column;
    }

    .activity-content strong {
        font-size: 14px;
        color: var(--gestemas-gray-800);
    }

    .activity-content span {
        font-size: 12px;
        color: var(--gestemas-gray-500);
    }

    .activity-date {
        font-size: 12px;
        color: var(--gestemas-gray-400);
        font-weight: 600;
    }

    /* Pending Tasks Preview */
    .pending-badge {
        background: var(--gestemas-warning);
        color: white;
        font-size: 12px;
        font-weight: 700;
        padding: 2px 8px;
        border-radius: 10px;
        margin-left: auto;
    }

    .pending-task-preview {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px 0;
        border-bottom: 1px solid var(--gestemas-gray-100);
    }

    .pending-task-preview:last-child {
        border-bottom: none;
    }

    .pending-task-preview span {
        font-size: 14px;
        color: var(--gestemas-gray-700);
    }

    .task-due {
        margin-left: auto;
        font-size: 11px;
        color: var(--gestemas-warning);
        font-weight: 700;
    }

    /* Reports View */
    .report-quick-actions {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .quick-report-link {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 16px;
        border-radius: 12px;
        text-decoration: none;
        color: var(--gestemas-gray-700);
        transition: all 0.2s;
    }

    .quick-report-link:hover {
        background: var(--gestemas-gray-50);
        color: var(--gestemas-primary);
        transform: translateX(4px);
    }

    .quick-report-link i {
        width: 20px;
        height: 20px;
        color: var(--gestemas-primary);
    }

    .quick-report-link span {
        flex: 1;
        font-weight: 600;
    }

    /* Share View */
    .share-permissions {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

    .permission-check {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px;
        background: var(--gestemas-gray-50);
        border-radius: 10px;
        cursor: pointer;
        transition: all 0.2s;
    }

    .permission-check:hover {
        background: var(--gestemas-gray-100);
    }

    .permission-check input {
        width: 18px;
        height: 18px;
        accent-color: var(--gestemas-primary);
    }

    .permission-check span {
        font-size: 14px;
        font-weight: 500;
        color: var(--gestemas-gray-700);
    }

    .share-link-box {
        display: flex;
        gap: 8px;
    }

    .share-link-box input {
        flex: 1;
    }

    /* Active Tokens List */
    .token-item {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px;
        background: var(--gestemas-gray-50);
        border-radius: 12px;
        margin-bottom: 10px;
    }

    .token-info {
        flex: 1;
    }

    .token-info strong {
        display: block;
        font-size: 13px;
        color: var(--gestemas-gray-800);
    }

    .token-info span {
        font-size: 11px;
        color: var(--gestemas-gray-500);
    }

    /* Tabs Responsive */
    @media (max-width: 768px) {
        .gestemas-profile-tabs {
            padding: 6px;
            flex-wrap: wrap;
        }

        .tab-btn {
            padding: 10px;
            flex: 1 1 calc(50% - 8px);
            min-width: 0;
        }

        .tab-btn .tab-text {
            display: none;
        }

        .tab-btn i {
            width: 20px;
            height: 20px;
        }

        .gestemas-kpis-grid {
            grid-template-columns: repeat(2, 1fr);
        }

        .gestemas-kpi-card {
            flex-direction: column;
            text-align: center;
            padding: 16px;
        }

        .kpi-icon {
            margin-bottom: 8px;
        }
    }

    /* Loader Mini */
    .gestemas-loader-mini {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 20px;
        color: var(--gestemas-gray-500);
        font-size: 14px;
    }

    /* SUPER MODERN NEE & AI STYLES (Silicon Valley Standard) */
    .premium-ai-card {
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.9) 0%, rgba(240, 249, 255, 0.9) 100%);
        border: 1px solid rgba(14, 165, 233, 0.2);
        box-shadow: 0 20px 40px rgba(14, 165, 233, 0.1);
        position: relative;
        overflow: hidden;
    }

    .premium-ai-card::before {
        content: '';
        position: absolute;
        top: -50%;
        left: -50%;
        width: 200%;
        height: 200%;
        background: radial-gradient(circle, rgba(14, 165, 233, 0.05) 0%, transparent 70%);
        animation: rotateGradient 10s linear infinite;
        pointer-events: none;
    }

    @keyframes rotateGradient {
        from {
            transform: rotate(0deg);
        }

        to {
            transform: rotate(360deg);
        }
    }

    /* Icon Color Variants */
    .gestemas-icon-warning {
        color: var(--gestemas-warning);
    }

    .gestemas-icon-success {
        color: var(--gestemas-success);
    }

    .gestemas-icon-primary {
        color: var(--gestemas-primary);
    }

    .gestemas-icon-accent {
        color: var(--gestemas-accent);
    }

    /* Unified Input Styles */
    .gestemas-input-glass {
        background: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(8px);
        border: 1px solid rgba(0, 0, 0, 0.08);
        border-radius: 12px;
        padding: 12px 16px;
        transition: all 0.2s ease;
    }

    .gestemas-input-glass:focus {
        background: white;
        border-color: var(--gestemas-primary);
        box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.1);
        outline: none;
    }

    /* ═══════════════════════════════════════════════════════════
   11. MODULE: ADMIN DASHBOARD
   ═══════════════════════════════════════════════════════════ */
    .gestemas-admin-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 24px 0;
        margin-bottom: 24px;
        border-bottom: 1px solid var(--glass-border);
    }

    .gestemas-admin-header__brand h1 {
        margin: 0;
        font-size: 28px;
        font-family: var(--font-outfit, sans-serif);
        color: var(--gestemas-primary);
        font-weight: 800;
    }

    .gestemas-admin-tagline {
        margin: 4px 0 0;
        color: var(--gestemas-gray-500);
        font-size: 14px;
    }

    .gestemas-admin-claim {
        font-style: italic;
        color: var(--gestemas-secondary);
        font-size: 16px;
        font-weight: 500;
    }

    /* Admin Grid System Override */
    .gestemas-grid--4 {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
        gap: 24px;
    }

    .gestemas-grid--2 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 24px;
    }

    /* Admin Stat Cards */
    .gestemas-stat {
        background: white;
        padding: 24px;
        border-radius: 16px;
        border: 1px solid var(--glass-border);
        box-shadow: var(--gestemas-shadow);
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        transition: transform 0.3s ease;
    }

    .gestemas-stat:hover {
        transform: translateY(-4px);
        border-color: var(--gestemas-primary);
    }

    .gestemas-stat__label {
        font-size: 12px;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--gestemas-gray-500);
        font-weight: 700;
        margin-bottom: 8px;
    }

    .gestemas-stat__value {
        font-size: 32px;
        font-weight: 800;
        color: var(--gestemas-gray-900);
        line-height: 1;
    }

    /* Admin Cards */
    .gestemas-card {
        background: white;
        border-radius: 16px;
        border: 1px solid var(--glass-border);
        box-shadow: var(--gestemas-shadow);
        overflow: hidden;
    }

    .gestemas-card__header {
        padding: 20px 24px;
        border-bottom: 1px solid rgba(0, 0, 0, 0.05);
        background: rgba(0, 0, 0, 0.01);
    }

    .gestemas-card__title {
        margin: 0;
        font-size: 18px;
        font-weight: 700;
        color: var(--gestemas-gray-800);
    }

    .gestemas-card__body {
        padding: 24px;
    }

    /* Activity Feed Admin */
    .gestemas-activity-feed {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .gestemas-activity-item {
        display: flex;
        align-items: center;
        gap: 16px;
        padding-bottom: 16px;
        border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    }

    .gestemas-activity-item:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

    .activity-icon {
        width: 40px;
        height: 40px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 20px;
    }

    .activity-content {
        display: flex;
        flex-direction: column;
    }

    .activity-title {
        font-weight: 700;
        font-size: 14px;
        color: var(--gestemas-gray-800);
    }

    .activity-meta {
        font-size: 12px;
        color: var(--gestemas-gray-500);
    }

    /* Quick Actions Buttons */
    .gestemas-btn {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 12px 20px;
        border-radius: 12px;
        text-decoration: none;
        font-weight: 600;
        transition: all 0.2s;
        border: 1px solid transparent;
    }

    .gestemas-btn--primary {
        background: var(--gestemas-primary);
        color: white;
    }

    .gestemas-btn--primary:hover {
        background: var(--gestemas-primary-dark);
        color: white;
    }

    .gestemas-btn--secondary {
        background: var(--gestemas-secondary);
        color: white;
    }

    .gestemas-btn--secondary:hover {
        background: var(--as-color-teal-deep);
        /* Hardcoded teal dark for fallback */
        color: white;
    }

    .gestemas-btn--outline {
        background: white;
        border-color: var(--gestemas-gray-200);
        color: var(--gestemas-gray-700);
    }

    .gestemas-btn--outline:hover {
        border-color: var(--gestemas-gray-400);
        background: var(--gestemas-gray-50);
    }

    /* Responsive Admin */
    @container module (max-width: 1024px) {
        .gestemas-grid--2 {
            grid-template-columns: 1fr;
        }
    }

    /* ═══════════════════════════════════════════════════════════
   12. MODULE: STUDENT PROFILE 360 (Migrated)
   ═══════════════════════════════════════════════════════════ */

    .gestemas-profile-360 {
        --p-header-height: 80px;
        --p-subnav-height: 64px;
        --p-total-sticky: calc(var(--p-header-height) + var(--p-subnav-height));
        background: var(--gestemas-bg);
        min-height: 100vh;
        animation: slideUp 0.5s ease-out;
    }

    /* 1. MAIN HEADER (Glassmorphism V3) */
    .gestemas-profile-header-premium {
        position: sticky;
        top: 0;
        z-index: 100;
        height: var(--p-header-height);
        background: var(--glass-bg-heavy);
        backdrop-filter: blur(20px) saturate(160%);
        -webkit-backdrop-filter: blur(20px) saturate(160%);
        border-bottom: 1px solid var(--glass-border);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 40px;
        transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .header-left-group {
        display: flex;
        align-items: center;
        gap: 20px;
    }

    .student-info-mini {
        display: flex;
        align-items: center;
        gap: 16px;
    }

    .mini-avatar {
        width: 48px;
        height: 48px;
        background: var(--gestemas-primary);
        border-radius: 14px;
        color: white;
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 800;
        font-size: 18px;
        box-shadow: 0 8px 16px -4px rgba(var(--gestemas-primary-rgb), 0.3);
    }

    .mini-details h1 {
        font-size: 20px;
        font-weight: 800;
        margin: 0;
        color: var(--gestemas-gray-900);
        letter-spacing: -0.02em;
    }

    .mini-details p {
        font-size: 13px;
        color: var(--gestemas-gray-500);
        font-weight: 600;
        margin: 0;
    }

    /* 2. SUBMENU BAR (The "Franja") */
    .gestemas-profile-subnav-bar {
        position: sticky;
        top: var(--p-header-height);
        z-index: 90;
        height: var(--p-subnav-height);
        background: var(--glass-bg);
        backdrop-filter: blur(24px) saturate(180%);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        border-bottom: 1px solid var(--glass-border);
        display: flex;
        align-items: center;
        padding: 0 var(--page-padding-desktop, 40px);
        box-shadow: 0 4px 20px -10px rgba(0, 0, 0, 0.05);
    }

    .subnav-scroll-container {
        display: flex;
        gap: 12px;
        overflow-x: auto;
        width: 100%;
        scrollbar-width: none;
    }

    .subnav-item {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 20px;
        border-radius: 99px;
        border: 1px solid transparent;
        background: transparent;
        color: var(--gestemas-gray-500);
        font-size: 14px;
        font-weight: 800;
        white-space: nowrap;
        cursor: pointer;
        transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .subnav-item:hover {
        background: rgba(var(--gestemas-primary-rgb), 0.05);
        color: var(--gestemas-primary);
    }

    .subnav-item.is-active {
        background: var(--gestemas-primary);
        color: white;
        box-shadow: 0 8px 16px -4px rgba(var(--gestemas-primary-rgb), 0.3);
    }

    /* 3. GRID LAYOUT & SIDEBAR */
    .gestemas-profile-grid {
        display: grid;
        grid-template-columns: 320px 1fr;
        gap: 32px;
        padding: 32px 40px;
        max-width: 1600px;
        margin: 0 auto;
    }

    /* Desk Fluid Grids for Wide Tabs (No Sidebar) */
    .gestemas-layout-hero {
        display: grid;
        grid-template-columns: minmax(400px, 1fr) 2fr;
        gap: var(--profile-gap, 24px);
        width: 100%;
    }
    .gestemas-layout-auto-fit {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: var(--profile-gap, 16px);
        width: 100%;
    }
    .gestemas-layout-readability {
        max-width: 1100px;
        margin: 0 auto;
        width: 100%;
    }
    
    @media (max-width: 1024px) {
        .gestemas-layout-hero {
            grid-template-columns: 1fr;
        }
    }

    .gestemas-profile-sidebar {
        display: flex;
        flex-direction: column;
        gap: 24px;
    }

    /* Sidebar Cards Standardized */
    .gestemas-profile-sidebar .gestemas-card {
        background: var(--glass-card-bg, rgba(255, 255, 255, 0.7));
        backdrop-filter: blur(10px);
        border: 1px solid var(--glass-border);
        border-radius: 24px;
        overflow: hidden;
        transition: all 0.3s ease;
    }

    .gestemas-profile-sidebar .gestemas-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--gestemas-shadow-lg);
    }

    @media (max-width: 1100px) {
        .gestemas-profile-grid {
            grid-template-columns: 1fr;
        }
    }

    /* 4. GLASSMORPHISM V3.2 SUPER PRO - Card Glow Effect */
    .card-glass-glow {
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(24px) saturate(180%);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        border: 1px solid rgba(255, 255, 255, 0.4);
        border-radius: 20px;
        box-shadow:
            0 8px 32px rgba(0, 0, 0, 0.08),
            0 0 0 1px rgba(255, 255, 255, 0.1) inset,
            0 0 80px -20px rgba(var(--gestemas-primary-rgb), 0.15);
        transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
        position: relative;
        overflow: hidden;
    }

    .card-glass-glow::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);
    }

    .card-glass-glow:hover {
        transform: translateY(-4px);
        box-shadow:
            0 20px 40px rgba(0, 0, 0, 0.12),
            0 0 0 1px rgba(255, 255, 255, 0.2) inset,
            0 0 100px -10px rgba(var(--gestemas-primary-rgb), 0.25);
    }

    /* 5. HEADER ACTIONS (Glass Buttons) */
    .header-actions-group {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .action-btn-glass {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 16px;
        background: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(10px);
        border: 1px solid var(--glass-border);
        border-radius: 12px;
        color: var(--gestemas-gray-700);
        font-size: 13px;
        font-weight: 700;
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .action-btn-glass:hover {
        background: var(--gestemas-primary);
        color: white;
        border-color: var(--gestemas-primary);
        transform: translateY(-2px);
        box-shadow: 0 8px 20px -4px rgba(var(--gestemas-primary-rgb), 0.4);
    }

    .action-btn-glass i {
        width: 16px;
        height: 16px;
    }

    .back-btn-profile {
        width: 40px;
        height: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(255, 255, 255, 0.8);
        backdrop-filter: blur(10px);
        border: 1px solid var(--glass-border);
        border-radius: 12px;
        color: var(--gestemas-gray-600);
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .back-btn-profile:hover {
        background: var(--gestemas-primary);
        color: white;
        border-color: var(--gestemas-primary);
    }

    /* 6. MOBILE-FIRST RESPONSIVE (Glassmorphism V3.2 Super Pro) */
    @media (min-width: 481px) and (max-width: 768px) {

        /* Header Mobile Optimization */
        .gestemas-profile-header-premium {
            --p-header-height: 56px;
            min-height: var(--p-header-height);
            height: auto;
            padding: 0 16px;
            gap: 12px;
        }

        .header-left-group {
            gap: 12px;
            flex: 1;
            min-width: 0;
            /* Prevent overflow */
        }

        .back-btn-profile {
            width: 36px;
            height: 36px;
            flex-shrink: 0;
        }

        .student-info-mini {
            gap: 10px;
            min-width: 0;
            flex: 1;
        }

        .mini-avatar {
            width: 36px;
            height: 36px;
            font-size: 14px;
            border-radius: 10px;
            flex-shrink: 0;
        }

        .mini-details {
            min-width: 0;
            flex: 1;
        }

        .mini-details h1 {
            font-size: 16px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 100%;
        }

        .mini-details p {
            display: none;
        }

        /* Header Actions - Icons Only on Mobile */
        .header-actions-group {
            gap: 6px;
            flex-shrink: 0;
        }

        .action-btn-glass {
            width: 36px;
            height: 36px;
            padding: 0;
            justify-content: center;
            border-radius: 10px;
        }

        .action-btn-glass span {
            display: none;
        }

        .action-btn-glass i {
            width: 18px;
            height: 18px;
        }

        /* Subnav 100% Fluid Mobile */
        .gestemas-profile-subnav-bar {
            top: 56px;
            height: 52px;
            padding: 0;
            width: 100vw;
            margin-left: calc(-1 * var(--page-padding-mobile, 16px));
            margin-right: calc(-1 * var(--page-padding-mobile, 16px));
            overflow: hidden;
        }

        .subnav-scroll-container {
            padding: 0 16px;
            gap: 8px;
            -webkit-overflow-scrolling: touch;
            scroll-snap-type: x mandatory;
        }

        .subnav-scroll-container::after {
            content: '';
            padding-right: 16px;
        }

        .subnav-item {
            padding: 8px 14px;
            font-size: 12px;
            gap: 6px;
            scroll-snap-align: start;
        }

        .subnav-item i {
            width: 14px;
            height: 14px;
        }

        /* Profile Grid Mobile */
        .gestemas-profile-grid {
            padding: 10px;
            gap: 10px;
        }

        /* KPIs Grid 2x2 Mobile */
        .gestemas-kpis-grid {
            grid-template-columns: 1fr;
            gap: 10px;
            margin-bottom: 16px;
        }

        .gestemas-kpi-card {
            padding: 12px;
            gap: 10px;
            flex-direction: row;
            align-items: center;
            text-align: left;
        }

        .gestemas-kpi-card .kpi-icon {
            width: 36px;
            height: 36px;
            border-radius: 12px;
        }

        .gestemas-kpi-card .kpi-value {
            font-size: 19px;
        }

        .gestemas-kpi-card .kpi-label {
            font-size: 10px;
        }

        /* Cards Full Width */
        .gestemas-grid--2 {
            grid-template-columns: 1fr;
            gap: 10px;
        }
    }

    @media (max-width: 480px) {
        .gestemas-profile-header-premium {
            height: auto;
            min-height: 56px;
            padding: 8px 8px 10px;
            flex-wrap: wrap;
            align-items: center;
            gap: 8px;
        }

        .header-left-group {
            flex: 1 1 100%;
            min-width: 0;
            gap: 8px;
        }

        .header-identity-pill {
            width: 100%;
            min-width: 0;
            padding: 4px 10px 4px 6px;
            box-sizing: border-box;
        }

        .header-identity-pill > div:last-child {
            min-width: 0;
            flex: 1;
        }

        .header-student-name-v3 {
            max-width: 100%;
            font-size: 15px;
            line-height: 1.1;
        }

        .header-actions-group-v3 {
            width: 100%;
            flex: 1 1 100%;
            justify-content: space-between;
            gap: 6px;
            margin-top: 4px;
            padding-top: 10px;
            border-top: 1px solid rgba(255, 255, 255, 0.18);
        }

        .action-btn-glass-v3 {
            flex: 1 1 0;
            min-width: 0;
            height: 40px;
        }

        /* Profile Grid Mobile */
        .gestemas-profile-grid {
            padding: 8px;
            gap: 8px;
        }

        /* KPIs Grid 1 Column Mobile */
        .gestemas-kpis-grid {
            grid-template-columns: 1fr;
            gap: 8px;
            margin-bottom: 12px;
        }

        .gestemas-kpi-card {
            padding: 10px;
            gap: 8px;
            flex-direction: row;
            align-items: center;
            text-align: left;
        }

        .gestemas-kpi-card .kpi-icon {
            width: 34px;
            height: 34px;
            border-radius: 10px;
        }

        .gestemas-kpi-card .kpi-value {
            font-size: 17px;
        }

        .gestemas-kpi-card .kpi-label {
            font-size: 10px;
        }

        /* Cards Full Width */
        .gestemas-grid--2 {
            grid-template-columns: 1fr;
            gap: 8px;
        }
    }

    /* Extra Small Devices (iPhone SE, etc) */
    @media (max-width: 375px) {
        .gestemas-profile-header-premium {
            padding: 6px 8px 8px;
            gap: 6px;
        }

        .header-left-group {
            gap: 6px;
        }

        .header-identity-pill {
            padding: 4px 8px 4px 6px;
        }

        .header-student-name-v3 {
            font-size: 14px;
        }

        .header-actions-group-v3 {
            gap: 4px;
            padding-top: 8px;
        }

        .action-btn-glass-v3 {
            height: 34px;
            border-radius: 10px;
        }

        .mini-details h1 {
            font-size: 14px;
        }

        .action-btn-glass {
            width: 32px;
            height: 32px;
        }

        .subnav-item {
            padding: 6px 12px;
            font-size: 11px;
        }

        .gestemas-profile-grid {
            padding: 6px 8px;
            gap: 6px;
        }

        .gestemas-kpis-grid {
            gap: 6px;
        }

        .gestemas-kpi-card {
            padding: 10px;
            gap: 6px;
        }

        .gestemas-kpi-card .kpi-icon {
            width: 34px;
            height: 34px;
        }

        .gestemas-kpi-card .kpi-value {
            font-size: 17px;
        }

        .gestemas-grid--2 {
            gap: 6px;
        }
    }

    /* 7. PROFILE IDENTITY & COMPONENTS */
    .gestemas-identity-card {
        overflow: hidden;
        position: relative;
    }

    .gestemas-identity-banner {
        height: 80px;
        background: linear-gradient(135deg, var(--gestemas-primary) 0%, var(--gestemas-secondary) 100%);
        opacity: 0.8;
    }

    .gestemas-identity-avatar {
        width: 100px;
        height: 100px;
        background: white;
        border-radius: 24px;
        position: absolute;
        top: 30px;
        left: 50%;
        transform: translateX(-50%);
        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 32px;
        font-weight: 800;
        color: var(--gestemas-primary);
        font-family: 'Outfit', sans-serif;
        border: 4px solid white;
    }

    .gestemas-profile-role {
        font-size: 13px;
        font-weight: 600;
        color: var(--gestemas-gray-500);
        text-transform: uppercase;
        letter-spacing: 1px;
    }

    .gestemas-profile-stats-row {
        display: flex;
        justify-content: center;
        gap: var(--grid-gap, 24px);
        margin-top: var(--block-gap, 24px);
        padding-top: var(--block-gap, 24px);
        border-top: 1px solid var(--gestemas-gray-100);
    }

    .profile-stat-box {
        display: flex;
        flex-direction: column;
    }

    .profile-stat-box strong {
        font-size: 20px;
        color: var(--gestemas-gray-900);
    }

    .profile-stat-box span {
        font-size: 11px;
        text-transform: uppercase;
        color: var(--gestemas-gray-400);
        font-weight: 700;
    }

    /* Metadata NEE & Sidebar Cards */
    .gestemas-nee-summary {
        font-size: 14px;
        line-height: 1.6;
        color: var(--gestemas-gray-700);
    }

    .support-item {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 12px;
        padding: 10px;
        border-radius: 12px;
        background: var(--gestemas-gray-50);
    }

    .support-icon {
        width: 36px;
        height: 36px;
        background: white;
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 18px;
        box-shadow: var(--gestemas-shadow-sm);
    }

    .support-info strong {
        display: block;
        font-size: 14px;
        color: var(--gestemas-gray-800);
    }

    .support-info span {
        font-size: 11px;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
        font-weight: 700;
    }

    .support-contact {
        display: flex;
        align-items: center;
        gap: 10px;
        font-size: 13px;
        color: var(--gestemas-gray-600);
        margin-bottom: 8px;
    }

    .support-contact i {
        width: 14px;
        height: 14px;
        color: var(--gestemas-primary);
    }

    /* Health Tab Styles */
    .badge-atencion {
        display: inline-block;
        padding: 2px 8px;
        background: var(--gestemas-primary-light);
        color: var(--gestemas-primary);
        border-radius: 4px;
        font-size: 10px;
        font-weight: 700;
        text-transform: uppercase;
    }

    .meds-compact-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .med-compact-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
    }

    .med-bullet {
        width: 6px;
        height: 6px;
        background: var(--gestemas-error);
        border-radius: 50%;
        margin-top: 6px;
    }

    .med-details {
        display: flex;
        flex-direction: column;
    }

    .med-details strong {
        font-size: 13px;
        color: var(--gestemas-gray-800);
    }

    .med-details span {
        font-size: 11px;
        color: var(--gestemas-gray-500);
    }

    .gestemas-hover-card {
        transition: transform 0.2s, box-shadow 0.2s;
    }

    .gestemas-hover-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    }

    /* Timeline Modern View */
    .timeline-header-actions {
        margin-bottom: 24px;
        padding-bottom: 16px;
        border-bottom: 1px solid var(--gestemas-gray-100);
    }

    .timeline-month-divider {
        font-size: 14px;
        font-weight: 800;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
        letter-spacing: 2px;
        margin: 32px 0 16px;
        padding-left: 20px;
        border-left: 2px solid var(--gestemas-gray-200);
    }

    .timeline-card {
        display: flex;
        margin-bottom: 16px;
        cursor: pointer;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        border: 1px solid transparent;
    }

    .timeline-card:hover {
        transform: translateX(8px);
        border-color: var(--gestemas-primary-light);
        box-shadow: var(--gestemas-shadow-sm);
    }

    .timeline-card__indicator {
        width: 6px;
        border-radius: 10px 0 0 10px;
    }

    .timeline-card__content {
        flex: 1;
        padding: 20px;
    }

    .timeline-card__header {
        display: flex;
        justify-content: space-between;
        margin-bottom: 8px;
    }

    .timeline-type {
        font-size: 11px;
        font-weight: 800;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
    }

    .timeline-date {
        font-size: 12px;
        color: var(--gestemas-gray-400);
    }

    .timeline-title {
        margin: 0 0 8px;
        font-size: 17px;
        color: var(--gestemas-gray-900);
    }

    .timeline-excerpt {
        font-size: 14px;
        color: var(--gestemas-gray-600);
        line-height: 1.6;
        margin-bottom: 12px;
    }

    .timeline-topics {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin-bottom: 16px;
    }

    .topic-tag {
        font-size: 11px;
        font-weight: 600;
        padding: 4px 10px;
        background: var(--gestemas-gray-50);
        border-radius: 8px;
        color: var(--gestemas-gray-600);
    }

    .topic-tag--more {
        background: transparent;
        border: 1px dashed var(--gestemas-gray-200);
    }

    .timeline-footer {
        display: flex;
        align-items: center;
        gap: 20px;
    }

    .timeline-specialist,
    .timeline-duration {
        display: flex;
        align-items: center;
        gap: 6px;
        font-size: 12px;
        color: var(--gestemas-gray-500);
    }

    .timeline-specialist i,
    .timeline-duration i {
        width: 14px;
        height: 14px;
    }

    /* Tabs */
    .gestemas-profile-tabs {
        display: flex;
        gap: 8px;
        padding: 8px;
        border-radius: 20px;
        margin-bottom: 24px;
    }

    .tab-btn {
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 12px;
        border-radius: 14px;
        background: transparent;
        border: none;
        font-size: 14px;
        font-weight: 600;
        color: var(--gestemas-gray-500);
        cursor: pointer;
        transition: var(--gestemas-transition);
    }

    .tab-btn i {
        width: 18px;
        height: 18px;
    }

    .tab-btn.is-active {
        background: white;
        color: var(--gestemas-primary);
        box-shadow: var(--gestemas-shadow-sm);
    }

    /* Analytics & Dimensions */
    .gestemas-dimension-summary-list {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .gestemas-dimension-row {
        background: var(--gestemas-gray-50);
        padding: 16px;
        border-radius: 16px;
    }

    .gestemas-dimension-info {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 10px;
    }

    .dim-label {
        display: flex;
        align-items: center;
        gap: 10px;
    }

    .dim-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
    }

    .dim-value {
        font-size: 12px;
        font-weight: 700;
        color: var(--gestemas-primary);
    }

    .gestemas-dimension-progress__bar {
        height: 8px;
        background: var(--gestemas-gray-200);
        border-radius: 10px;
        overflow: hidden;
    }

    .gestemas-dimension-progress__fill {
        height: 100%;
        border-radius: 10px;
        transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
    }

    /* Tasks & Merits */
    .gestemas-tasks-logros-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 24px;
    }

    @media (max-width: 768px) {
        .gestemas-tasks-logros-grid {
            grid-template-columns: 1fr;
        }

        .gestemas-smart-tip-card__head {
            flex-direction: column;
            align-items: flex-start;
        }

        .gestemas-smart-tip-card__type {
            max-width: 100%;
        }

        .gestemas-suggestion-item {
            flex-direction: column;
            align-items: stretch;
        }

        .gestemas-suggestion-item__main {
            width: 100%;
        }

        .gestemas-suggestion-item__action {
            width: 100%;
        }
    }

    .gestemas-task-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
        padding: 12px;
        border-radius: 12px;
        background: var(--gestemas-gray-50);
        margin-bottom: 10px;
        transition: all 0.2s;
    }

    .gestemas-task-item--done {
        opacity: 0.7;
    }

    .gestemas-task-item--done .gestemas-task-item__title {
        text-decoration: line-through;
    }

    .gestemas-task-item__content {
        display: flex;
        flex-direction: column;
    }

    .gestemas-task-item__title {
        font-size: 14px;
        font-weight: 600;
        color: var(--gestemas-gray-800);
    }

    .gestemas-task-item__date {
        font-size: 11px;
        color: var(--gestemas-gray-400);
    }

    .gestemas-meritos-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
        gap: 12px;
    }

    .gestemas-merito-badge {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding: 16px;
        background: linear-gradient(135deg, var(--as-color-merit-bg-start) 0%, var(--as-color-merit-bg-end) 100%);
        border: 1px solid var(--as-color-merit-border);
        border-radius: 16px;
        text-align: center;
        transition: transform 0.2s;
    }

    .gestemas-merito-badge:hover {
        transform: translateY(-5px);
    }

    .merito-icon {
        font-size: 24px;
        margin-bottom: 8px;
    }

    .merito-name {
        font-size: 12px;
        font-weight: 700;
        color: var(--as-color-merit-text);
        margin-bottom: 4px;
    }

    .merito-points {
        font-size: 11px;
        font-weight: 800;
        color: var(--as-color-merit-points);
        padding: 2px 8px;
        background: white;
        border-radius: 10px;
    }

    /* Skeleton Loading */
    .gestemas-skeleton-loading {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .gestemas-skeleton {
        background: linear-gradient(90deg, var(--as-color-skeleton-a) 25%, var(--as-color-skeleton-b) 50%, var(--as-color-skeleton-a) 75%);
        background-size: 400% 100%;
        animation: skeleton-loading 1.4s ease infinite;
        border-radius: 4px;
    }

    .gestemas-skeleton--text {
        height: 12px;
    }

    @keyframes skeleton-loading {
        0% {
            background-position: 100% 50%;
        }

        100% {
            background-position: 0% 50%;
        }
    }

    @keyframes fadeInScale {
        from {
            opacity: 0;
            transform: scale(0.95) translateY(-10px);
        }

        to {
            opacity: 1;
            transform: scale(1) translateY(0);
        }
    }

    @keyframes slideUp {
        from {
            opacity: 0;
            transform: translateY(20px);
        }

        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    /* Medications List */
    .gestemas-medication-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .medication-item {
        display: flex;
        align-items: flex-start;
        gap: 16px;
        background: var(--gestemas-gray-50);
        padding: 16px;
        border-radius: 12px;
        transition: all 0.2s;
    }

    .medication-item:hover {
        background: white;
        box-shadow: var(--gestemas-shadow-sm);
        transform: translateY(-2px);
    }

    .med-icon {
        width: 40px;
        height: 40px;
        background: var(--as-color-info-soft-alt);
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 20px;
    }

    .med-info {
        flex: 1;
    }

    .med-info strong {
        display: block;
        color: var(--gestemas-gray-900);
        font-size: 14px;
        margin-bottom: 4px;
    }

    .med-dose {
        display: block;
        font-size: 12px;
        font-weight: 600;
        color: var(--gestemas-primary);
        text-transform: uppercase;
        margin-bottom: 6px;
    }

    .med-notes {
        font-size: 13px;
        color: var(--gestemas-gray-600);
        line-height: 1.4;
        margin: 0;
    }

    .med-actions {
        display: flex;
        gap: 8px;
    }

    /* KPIs Grid */
    .gestemas-kpis-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
        gap: 16px;
    }

    .gestemas-kpi-card {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 20px;
        border-radius: 16px;
    }

    .kpi-icon {
        width: 48px;
        height: 48px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }

    .kpi-icon i {
        width: 24px;
        height: 24px;
    }

    .kpi-content {
        display: flex;
        flex-direction: column;
    }

    .kpi-value {
        font-size: 24px;
        font-weight: 800;
        color: var(--gestemas-gray-900);
        font-family: 'Outfit', sans-serif;
    }

    .kpi-label {
        font-size: 12px;
        color: var(--gestemas-gray-500);
        text-transform: uppercase;
        font-weight: 600;
    }

    /* Recent Activity List */
    .recent-activity-list {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .recent-activity-item {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px;
        background: var(--gestemas-gray-50);
        border-radius: 12px;
        transition: all 0.2s;
    }

    .recent-activity-item:hover {
        background: var(--gestemas-gray-100);
    }

    .activity-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        flex-shrink: 0;
    }

    .activity-content {
        flex: 1;
        display: flex;
        flex-direction: column;
    }

    .activity-content strong {
        font-size: 14px;
        color: var(--gestemas-gray-800);
    }

    .activity-content span {
        font-size: 12px;
        color: var(--gestemas-gray-500);
    }

    .activity-date {
        font-size: 12px;
        color: var(--gestemas-gray-400);
        font-weight: 600;
    }

    /* Pending Tasks Preview */
    .pending-badge {
        background: var(--gestemas-warning);
        color: white;
        font-size: 12px;
        font-weight: 700;
        padding: 2px 8px;
        border-radius: 10px;
        margin-left: auto;
    }

    .pending-task-preview {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px 0;
        border-bottom: 1px solid var(--gestemas-gray-100);
    }

    .pending-task-preview:last-child {
        border-bottom: none;
    }

    .pending-task-preview span {
        font-size: 14px;
        color: var(--gestemas-gray-700);
    }

    .task-due {
        margin-left: auto;
        font-size: 11px;
        color: var(--gestemas-warning);
        font-weight: 700;
    }

    /* Reports View */
    .report-quick-actions {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .quick-report-link {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 16px;
        border-radius: 12px;
        text-decoration: none;
        color: var(--gestemas-gray-700);
        transition: all 0.2s;
    }

    .quick-report-link:hover {
        background: var(--gestemas-gray-50);
        color: var(--gestemas-primary);
        transform: translateX(4px);
    }

    .quick-report-link i {
        width: 20px;
        height: 20px;
        color: var(--gestemas-primary);
    }

    .quick-report-link span {
        flex: 1;
        font-weight: 600;
    }

    /* Share View */
    .share-permissions {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

    .permission-check {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px;
        background: var(--gestemas-gray-50);
        border-radius: 10px;
        cursor: pointer;
        transition: all 0.2s;
    }

    .permission-check:hover {
        background: var(--gestemas-gray-100);
    }

    .permission-check input {
        width: 18px;
        height: 18px;
        accent-color: var(--gestemas-primary);
    }

    .permission-check span {
        font-size: 14px;
        font-weight: 500;
        color: var(--gestemas-gray-700);
    }

    .share-link-box {
        display: flex;
        gap: 8px;
    }

    .share-link-box input {
        flex: 1;
    }

    /* Active Tokens List */
    .token-item {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px;
        background: var(--gestemas-gray-50);
        border-radius: 12px;
        margin-bottom: 10px;
    }

    .token-info {
        flex: 1;
    }

    .token-info strong {
        display: block;
        font-size: 13px;
        color: var(--gestemas-gray-800);
    }

    .token-info span {
        font-size: 11px;
        color: var(--gestemas-gray-500);
    }

    .token-status {
        padding: 4px 10px;
        border-radius: 20px;
        font-size: 11px;
        font-weight: 700;
    }

    .token-status--active {
        background: rgba(var(--as-color-success-rgb), 0.1);
        color: var(--gestemas-success);
    }

    .token-status--expired {
        background: rgba(var(--as-color-danger-rgb), 0.1);
        color: var(--gestemas-error);
    }

    /* Tabs Responsive */
    @media (max-width: 768px) {
        .gestemas-profile-tabs {
            padding: 6px;
        }

        .tab-btn {
            padding: 10px;
            flex: 0 0 auto;
        }

        .tab-btn .tab-text {
            display: none;
        }

        .tab-btn i {
            width: 20px;
            height: 20px;
        }

        .gestemas-kpis-grid {
            grid-template-columns: repeat(2, 1fr);
        }

        .gestemas-kpi-card {
            flex-direction: column;
            text-align: center;
            padding: 16px;
        }

        .kpi-icon {
            margin-bottom: 8px;
        }
    }

    /* Loader Mini */
    .gestemas-loader-mini {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 20px;
        color: var(--gestemas-gray-500);
        font-size: 14px;
    }

    /* SUPER MODERN NEE & AI STYLES (Silicon Valley Standard) */
    .premium-ai-card {
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.9) 0%, rgba(240, 249, 255, 0.9) 100%);
        border: 1px solid rgba(14, 165, 233, 0.2);
        box-shadow: 0 20px 40px rgba(14, 165, 233, 0.1);
        position: relative;
        overflow: hidden;
    }

    .premium-ai-card::before {
        content: '';
        position: absolute;
        top: -50%;
        left: -50%;
        width: 200%;
        height: 200%;
        background: radial-gradient(circle, rgba(14, 165, 233, 0.05) 0%, transparent 70%);
        animation: rotateGradient 10s linear infinite;
        pointer-events: none;
    }

    @keyframes rotateGradient {
        from {
            transform: rotate(0deg);
        }

        to {
            transform: rotate(360deg);
        }
    }

    .alert-critical-premium {
        background: var(--as-color-danger-soft);
        border: 1px solid var(--as-color-danger-soft-border);
        border-left: 6px solid var(--as-color-danger);
        padding: 16px 20px;
        border-radius: 12px;
        display: flex;
        gap: 16px;
        align-items: center;
        color: var(--as-color-danger-deep);
        animation: pulseAlert 2s infinite;
    }

    @keyframes pulseAlert {
        0% {
            box-shadow: 0 0 0 0 rgba(var(--as-color-danger-rgb), 0.4);
        }

        70% {
            box-shadow: 0 0 0 10px rgba(var(--as-color-danger-rgb), 0);
        }

        100% {
            box-shadow: 0 0 0 0 rgba(var(--as-color-danger-rgb), 0);
        }
    }

    /* Icon Color Variants */
    .gestemas-icon-warning {
        color: var(--gestemas-warning);
    }

    .gestemas-icon-success {
        color: var(--gestemas-success);
    }

    .gestemas-icon-primary {
        color: var(--gestemas-primary);
    }

    .gestemas-icon-accent {
        color: var(--gestemas-accent);
    }

    /* Unified Input Styles */
    .gestemas-input-glass {
        background: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(8px);
        border: 1px solid rgba(0, 0, 0, 0.08);
        border-radius: 12px;
        padding: 12px 16px;
        transition: all 0.2s ease;
    }

    .gestemas-input-glass:focus {
        background: white;
        border-color: var(--gestemas-primary);
        box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.1);
        outline: none;
    }

    /* ═══════════════════════════════════════════════════════════
   13. MODULE: HEALTH & MEDICAL (Migrated)
   ═══════════════════════════════════════════════════════════ */

    /* Header Premium Enhancement */
    .gestemas-premium-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--block-padding, 24px) 0;
        margin-bottom: var(--block-gap, 24px);
        border-bottom: 1px solid var(--glass-border, rgba(255, 255, 255, 0.2));
        flex-wrap: wrap;
        gap: 16px;
    }

    .gestemas-page-header__left h1 {
        font-size: clamp(1.5rem, 4vw, 2rem);
        font-weight: 800;
        margin: 0 0 4px;
        letter-spacing: -0.02em;
    }

    /* Control Bar Glass Enhancement */
    .gestemas-control-bar {
        display: flex;
        flex-wrap: wrap;
        gap: 12px;
        padding: 16px 20px;
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(24px) saturate(180%);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        border: 1px solid rgba(255, 255, 255, 0.4);
        border-radius: 20px;
        margin-bottom: var(--block-gap, 24px);
        box-shadow:
            0 8px 32px rgba(0, 0, 0, 0.08),
            0 0 0 1px rgba(255, 255, 255, 0.1) inset;
    }

    .control-search {
        display: flex;
        align-items: center;
        gap: 10px;
        background: var(--as-color-surface);
        padding: 10px 16px;
        border-radius: 12px;
    border: 1px solid var(--as-color-glass-border-soft);
        flex: 1;
        min-width: 200px;
        transition: all 0.3s ease;
    }

    .control-search:focus-within {
        border-color: var(--gestemas-primary);
        box-shadow: 0 0 0 3px rgba(var(--gestemas-primary-rgb), 0.1);
    }

    .control-search-input {
        border: none;
        background: transparent;
        flex: 1;
        font-size: 14px;
        font-weight: 600;
        outline: none;
    }

    .control-filters {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        align-items: center;
    }

    .premium-select {
        padding: 10px 32px 10px 14px;
        background: var(--as-color-surface);
        border: 1px solid var(--as-color-glass-border-soft);
        border-radius: 12px;
        font-size: 13px;
        font-weight: 700;
        cursor: pointer;
        transition: all 0.3s ease;
        appearance: none;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 12px center;
    }

    .premium-select:hover,
    .premium-select:focus {
        border-color: var(--gestemas-primary);
        box-shadow: 0 0 0 3px rgba(var(--gestemas-primary-rgb), 0.1);
        outline: none;
    }

    /* View Toggle */
    .view-toggle {
        display: flex;
        background: var(--as-color-surface);
        border-radius: 12px;
        padding: 4px;
        gap: 4px;
        flex-shrink: 0;
        /* Force no-shrink for mobile visibility */
    }

    .toggle-btn {
        width: 36px;
        height: 36px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 10px;
        border: none;
        background: transparent;
        color: var(--gestemas-gray-500);
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .toggle-btn:hover {
        background: rgba(var(--gestemas-primary-rgb), 0.1);
        color: var(--gestemas-primary);
    }

    .toggle-btn.active {
        background: var(--gestemas-primary);
        color: white;
        box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.3);
    }

    /* Premium Cards */
    .premium-card {
        background: rgba(255, 255, 255, 0.9);
        backdrop-filter: blur(24px) saturate(180%);
        border: 1px solid rgba(255, 255, 255, 0.4);
        border-radius: 20px;
        padding: 20px;
        box-shadow:
            0 8px 32px rgba(0, 0, 0, 0.08),
            0 0 0 1px rgba(255, 255, 255, 0.1) inset;
        transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
        position: relative;
        overflow: hidden;
    }

    .premium-card::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);
    }

    .premium-card:hover {
        transform: translateY(-4px);
        box-shadow:
            0 20px 40px rgba(0, 0, 0, 0.12),
            0 0 0 1px rgba(255, 255, 255, 0.2) inset,
            0 0 80px -10px rgba(var(--gestemas-primary-rgb), 0.2);
    }

    /* Nexus List Block */
    .nexus-list-block {
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(16px);
        border: 1px solid rgba(255, 255, 255, 0.3);
        border-radius: 16px;
        padding: 16px 20px;
        margin-bottom: 12px;
        display: flex;
        align-items: center;
        gap: 16px;
        cursor: pointer;
        transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .nexus-list-block:hover {
        transform: translateX(4px);
        border-color: var(--gestemas-primary);
        box-shadow: 0 8px 24px rgba(var(--gestemas-primary-rgb), 0.15);
    }

    /* ═══════════════════════════════════════════════════════════
   MOBILE-FIRST RESPONSIVE - SUPER PRO UX (MODULE 13)
   ═══════════════════════════════════════════════════════════ */

    /* Tablet Breakpoint */
    @media (max-width: 1024px) {
        .gestemas-premium-header {
            padding: 20px 0;
        }

        .control-filters {
            flex-wrap: wrap;
        }
    }

    /* Mobile Breakpoint */
    @media (min-width: 481px) and (max-width: 768px) {
        .gestemas-page-premium {
            padding: 12px;
            max-width: 100vw;
            overflow-x: hidden;
        }

        .gestemas-premium-header {
            flex-direction: column;
            align-items: stretch;
            padding: 12px 0;
            margin-bottom: 12px;
            gap: 12px;
        }

        .gestemas-page-header__left {
            text-align: center;
        }

        .gestemas-page-header__left h1 {
            font-size: 1.4rem;
            line-height: 1.2;
        }

        .gestemas-page-header__right {
            width: 100%;
        }

        .gestemas-actions-group {
            width: 100%;
        }

        .gestemas-actions-group .gestemas-btn {
            flex: 1;
            justify-content: center;
            padding: 14px 16px;
            font-size: 14px;
            border-radius: 14px;
            min-height: 48px;
        }

        /* Control Bar Mobile */
        .gestemas-control-bar {
            flex-direction: column;
            padding: 12px;
            border-radius: 16px;
            gap: 10px;
            background: rgba(255, 255, 255, 0.95);
        }

        .control-search {
            width: 100%;
            min-width: unset;
            padding: 12px 14px;
            border-radius: 12px;
        }

        .control-search-input {
            font-size: 16px;
            /* Prevents iOS zoom */
        }

        /* Filtros Touch-Friendly */
        .control-filters {
            width: 100%;
            display: flex;
            gap: 8px;
            overflow-x: auto;
            overflow-y: hidden;
            flex-wrap: nowrap;
            padding: 4px 0;
            -webkit-overflow-scrolling: touch;
            scroll-snap-type: x mandatory;
            scrollbar-width: none;
        }

        .control-filters::-webkit-scrollbar {
            display: none;
        }

        .premium-select {
            flex-shrink: 0;
            scroll-snap-align: start;
            font-size: 12px;
            padding: 10px 32px 10px 14px;
            border-radius: 10px;
            min-height: 44px;
            touch-action: manipulation;
        }

        .control-actions {
            width: 100%;
            justify-content: space-between;
            gap: 8px;
        }

        .toggle-btn {
            width: 44px;
            height: 44px;
            min-width: 44px;
        }

        .desktop-only {
            display: none;
        }

        /* Grid Responsive */
        .view-mode-grid {
            display: grid;
            /* Priority flag removed to allow JS toggling */
            grid-template-columns: 1fr;
            gap: 12px;
        }

        /* Cards Touch-Friendly */
        .premium-card {
            padding: 16px;
            border-radius: 16px;
            touch-action: manipulation;
            -webkit-tap-highlight-color: transparent;
        }

        .premium-card:active {
            transform: scale(0.98);
        }

        /* List Blocks */
        .nexus-list-block {
            flex-wrap: wrap;
            padding: 14px;
            gap: 12px;
            min-height: 70px;
            touch-action: manipulation;
        }

        .nexus-list-block:active {
            background: rgba(var(--gestemas-primary-rgb), 0.05);
        }

        .nexus-block-main {
            width: 100%;
            order: 2;
        }

        .nexus-block-actions {
            order: 3;
            width: 100%;
            display: flex;
            justify-content: flex-end;
            gap: 8px;
            margin-top: 8px;
            padding-top: 8px;
            border-top: 1px solid var(--theme-border, rgba(0, 0, 0, 0.05));
        }

        .nexus-block-actions .view-btn {
            min-width: 44px;
            min-height: 44px;
        }

        /* Avatar Size */
        .avatar-mini {
            min-width: 40px;
            min-height: 40px;
            width: 40px;
            height: 40px;
        }

        /* Status Pill */
        .nexus-status-pill {
            padding: 6px 12px;
            font-size: 10px;
        }

        /* Date Stacked */
        .date-stacked {
            min-width: 50px;
        }
    }

    /* Small Mobile */
    @media (max-width: 375px) {
        .gestemas-page-premium {
            padding: 8px;
        }

        .gestemas-page-header__left h1 {
            font-size: 1.2rem;
        }

        .gestemas-control-bar {
            padding: 10px;
            gap: 8px;
        }

        .premium-select {
            font-size: 11px;
            padding: 8px 26px 8px 10px;
            min-height: 40px;
        }

        .premium-card {
            padding: 12px;
            border-radius: 14px;
        }
    }

    /* Extra Small */
    @media (max-width: 320px) {
        .gestemas-page-premium {
            padding: 6px;
        }

        .gestemas-page-header__left h1 {
            font-size: 1.1rem;
        }

        .premium-select {
            font-size: 10px;
            padding: 6px 22px 6px 8px;
        }
    }

    /* ═══════════════════════════════════════════════════════════
   14. MODULE: RESOURCES & LIBRARY (Migrated)
   ═══════════════════════════════════════════════════════════ */

    .gestemas-marketplace-hero {
        background: linear-gradient(135deg, var(--as-color-primary) 0%, var(--as-color-purple-vivid) 100%);
        padding: var(--block-padding-lg, 40px);
        border-radius: 24px;
        color: white;
        margin-bottom: var(--block-gap, 30px);
        position: relative;
        overflow: hidden;
    }

    .resource-filters {
        display: flex;
        gap: var(--grid-gap, 15px);
        margin-bottom: var(--block-gap, 30px);
        overflow-x: auto;
        padding-bottom: 10px;
    }

    .filter-chip {
        padding: 8px 20px;
        background: white;
        border: 1px solid var(--gestemas-gray-200);
        border-radius: 100px;
        font-size: 14px;
        font-weight: 600;
        color: var(--gestemas-gray-500);
        cursor: pointer;
        transition: all 0.2s;
        white-space: nowrap;
    }

    .filter-chip:hover {
        background: var(--gestemas-gray-50);
        color: var(--gestemas-primary);
    }

    .filter-chip.active {
        background: var(--gestemas-primary);
        color: white;
        border-color: var(--gestemas-primary);
    }

    .resource-card {
        background: white;
        border-radius: 20px;
        overflow: hidden;
        border: 1px solid var(--gestemas-gray-100);
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .resource-card:hover {
        transform: translateY(-8px);
        box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.05);
    }

    .resource-thumbnail {
        height: 160px;
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative;
    }

    .resource-thumbnail i {
        width: 48px;
        height: 48px;
        color: var(--gestemas-primary);
        opacity: 0.5;
    }

    .resource-body {
        padding: 20px;
    }

    .resource-tag {
        font-size: 10px;
        text-transform: uppercase;
        font-weight: 800;
        letter-spacing: 1px;
        color: var(--gestemas-primary);
        margin-bottom: 8px;
        display: block;
    }

    .resource-body h3 {
        margin: 0 0 10px;
        font-size: 18px;
        font-family: 'Outfit', sans-serif;
        font-weight: 700;
    }

    .resource-body p {
        font-size: 14px;
        color: var(--gestemas-gray-500);
        line-height: 1.5;
        margin-bottom: 20px;
    }

    .resource-footer {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding-top: 15px;
        border-top: 1px solid var(--gestemas-gray-100);
    }

    .resource-price {
        font-weight: 700;
        font-size: 14px;
        color: var(--gestemas-gray-900);
    }

    /* Premium Badge */
    .resource-premium-badge {
        position: absolute;
        top: 10px;
        right: 10px;
        background: rgba(0, 0, 0, 0.6);
        color: white;
        border-radius: 8px;
        padding: 4px 8px;
        font-size: 10px;
        display: flex;
        align-items: center;
        gap: 4px;
        backdrop-filter: blur(4px);
    }

    /* ═══════════════════════════════════════════════════════════
   15. MODULE: SETTINGS & CONFIG (Migrated)
   ═══════════════════════════════════════════════════════════ */

    /* Page Layout */
    .gestemas-page-no-padding {
        padding: 0;
    }

    .premium-profile-bg {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 500px;
        background: linear-gradient(180deg, rgba(var(--gestemas-primary-rgb), 0.08) 0%, rgba(255, 255, 255, 0) 100%);
        z-index: 0;
        pointer-events: none;
    }

    .nexus-container {
        position: relative;
        z-index: 1;
        max-width: var(--page-max-width, 1400px);
        margin: 0 auto;
        padding: var(--page-padding, 24px);
    }

    @media (max-width: 768px) {
        .nexus-container {
            padding-left: var(--page-padding-mobile, 8px);
            padding-right: var(--page-padding-mobile, 8px);
        }
    }

    .g-glass-panel {
        background: rgba(255, 255, 255, 0.75);
        backdrop-filter: blur(24px) saturate(180%);
        border: 1px solid rgba(255, 255, 255, 0.4);
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.04);
        border-radius: var(--block-radius, 24px);
    }

    /* Hero */
    .profile-hero-card {
        border: none;
        margin-bottom: 24px;
        position: relative;
    }

    .profile-hero-content {
        padding: 40px;
        display: flex;
        align-items: center;
        gap: 40px;
    }

    .avatar-initials-ring {
        width: 160px;
        height: 160px;
        border-radius: 50%;
        border: 6px solid white;
        background: linear-gradient(135deg, var(--gestemas-primary), var(--gestemas-secondary));
        color: white;
        overflow: hidden;
        box-shadow: 0 15px 35px rgba(var(--gestemas-primary-rgb), 0.2);
        position: relative;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 56px;
        font-weight: 800;
        font-family: 'Outfit';
        letter-spacing: -2px;
    }

    .avatar-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .profile-identity {
        flex: 1;
    }

    .identity-header {
        display: flex;
        align-items: center;
        gap: 16px;
        margin-bottom: 12px;
        flex-wrap: wrap;
    }

    .user-name {
        font-size: 36px;
        font-weight: 800;
        color: var(--as-color-text-deep);
        margin: 0;
        letter-spacing: -1px;
    }

    .user-role-badge {
        background: rgba(var(--gestemas-primary-rgb), 0.1);
        color: var(--gestemas-primary);
        padding: 6px 14px;
        border-radius: 50px;
        font-size: 12px;
        font-weight: 800;
        text-transform: uppercase;
        display: inline-flex;
        align-items: center;
        gap: 6px;
    }

.user-info-row {
    display: flex;
    gap: 24px;
    color: var(--as-color-text-muted);
    font-size: 14px;
    flex-wrap: wrap;
}

    .user-info-row .info-item {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .user-info-row .info-item i {
        width: 16px;
        color: var(--as-color-text-subtle);
    }

    /* Grid */
    .profile-layout-grid {
        display: grid;
        grid-template-columns: 1fr 340px;
        gap: 24px;
    }

    .section-card {
        padding: 32px;
        border-radius: var(--block-radius, 20px);
    }

.card-title-row h3 {
    font-size: 18px;
    color: var(--as-color-text-strong);
    margin: 0 0 24px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    }

    .card-title-row h3 i {
        color: var(--gestemas-primary);
    }

    .info-grid-display {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }

    .info-box label {
        display: block;
        font-size: 11px;
        text-transform: uppercase;
        color: var(--as-color-text-subtle);
        font-weight: 800;
        margin-bottom: 8px;
        letter-spacing: 0.5px;
    }

    .info-box .val {
        font-size: 16px;
        color: var(--as-color-text-deep);
        font-weight: 600;
    }

    .bio-text {
        line-height: 1.6;
        color: var(--gestemas-gray-600);
    }

    .badge-status {
        padding: 4px 10px;
        border-radius: 6px;
        font-size: 11px;
        font-weight: 800;
        text-transform: uppercase;
    }

    .badge-status.online {
        background: var(--as-color-success-soft-2);
        color: var(--as-color-success-deep-2);
    }

    @media (max-width: 992px) {
        .profile-hero-content {
            padding: 30px;
            gap: 24px;
            flex-direction: column;
            text-align: center;
        }

        .identity-header {
            justify-content: center;
        }

        .user-info-row {
            justify-content: center;
            gap: 16px;
        }

        .profile-layout-grid {
            grid-template-columns: 1fr;
        }

        .profile-hero-card {
            margin-top: 40px;
        }

        .avatar-initials-ring {
            margin-top: -60px;
            box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
        }

        .info-grid-display {
            grid-template-columns: 1fr;
            gap: 24px;
        }
    }

    /* Side Column */
    .plan-mini-card {
        background: linear-gradient(135deg, var(--as-color-text-deep) 0%, var(--gestemas-gray-700) 100%);
        border-radius: var(--block-radius, 20px);
        padding: 30px;
        color: white;
        position: relative;
        overflow: hidden;
        margin-bottom: 24px;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    }

    .plan-name {
        font-size: 28px;
        margin: 0 0 15px;
        font-family: 'Outfit';
        font-weight: 800;
    }

    .plan-stat {
        margin-top: 20px;
    }

    .plan-stat .big-num {
        font-size: 42px;
        font-weight: 800;
        color: white;
    }

    .btn-upgrade {
        width: 100%;
        background: white;
        color: var(--as-color-text-deep);
        border: none;
        padding: 12px;
        border-radius: 12px;
        font-weight: 800;
        cursor: pointer;
        margin-top: 24px;
        transition: transform 0.2s;
    }

    .btn-upgrade:hover {
        transform: translateY(-2px);
    }

    .mini-settings-menu {
        padding: 24px;
    }

    .mini-settings-menu h3 {
        font-size: 12px;
        font-weight: 800;
        color: var(--as-color-text-subtle);
        text-transform: uppercase;
        margin-bottom: 20px;
    }

    .admin-link-row {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px;
        color: var(--gestemas-gray-600);
        font-weight: 700;
        font-size: 14px;
        border-radius: 12px;
        transition: 0.2s;
        text-decoration: none;
    }

    .admin-link-row i {
        color: var(--gestemas-primary);
        width: 18px;
    }

    .admin-link-row:hover {
        background: rgba(var(--gestemas-primary-rgb), 0.05);
        color: var(--gestemas-primary);
    }

    .admin-link-row:hover {
        background: var(--as-color-info-soft);
    }

    /* System Settings View */
    .settings-header-nav {
        display: flex;
        align-items: center;
        gap: 20px;
        margin-bottom: 30px;
    }

    .btn-back-profile {
        background: white;
        border: 1px solid var(--as-color-border-soft);
        padding: 8px 16px;
        border-radius: 50px;
        cursor: pointer;
        display: flex;
        align-items: center;
        gap: 8px;
        font-weight: 600;
        color: var(--gestemas-gray-600);
    }

    .logo-preview-container {
        background: var(--as-color-surface-soft);
        padding: 15px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        gap: 15px;
    }

    @media(max-width: 900px) {
        .profile-hero-content {
            flex-direction: column;
            align-items: center;
            text-align: center;
            margin-top: -80px;
        }

        .profile-layout-grid {
            grid-template-columns: 1fr;
        }

        .identity-row {
            justify-content: center;
        }

        .user-bio-short {
            justify-content: center;
        }

        .gestemas-form-grid {
            grid-template-columns: 1fr;
        }
    }

    /* UI FIXES */
    .gestemas-btn--primary-premium {
        background: linear-gradient(135deg, var(--gestemas-primary, var(--as-color-primary)) 0%, var(--gestemas-secondary, var(--as-color-purple-vivid)) 100%);
        color: white;
        border: none;
        padding: 10px 20px;
        border-radius: 12px;
        font-weight: 700;
        transition: all 0.2s ease;
        cursor: pointer;
        box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.3);
    }

    .gestemas-btn--primary-premium:hover {
        transform: translateY(-2px);
        box-shadow: 0 6px 16px rgba(var(--gestemas-primary-rgb), 0.4);
    }

    .gestemas-btn--ghost {
        background: transparent;
        border: 1px solid var(--as-color-border-soft);
        color: var(--as-color-text-muted);
        padding: 10px 20px;
        border-radius: 12px;
        font-weight: 600;
        margin-right: 10px;
    }

    .gestemas-btn--ghost:hover {
        background: var(--as-color-surface-soft);
        color: var(--gestemas-gray-700);
    }

    /* Floating Labels Fix */
    .gestemas-floating-group {
        position: relative;
        margin-bottom: 20px;
    }

    .gestemas-floating-group input,
    .gestemas-floating-group select {
        width: 100%;
        padding: 12px 16px;
        padding-top: 20px;
        /* Space for label */
        padding-bottom: 8px;
        border: 1px solid rgba(0, 0, 0, 0.1);
        background: rgba(255, 255, 255, 0.8);
        border-radius: 12px;
        font-size: 15px;
        color: var(--as-color-text-strong);
        outline: none;
        transition: all 0.2s;
        height: 54px;
    }

    .gestemas-floating-group textarea {
        padding-top: 26px;
        min-height: 100px;
    }

    .gestemas-floating-group input:focus,
    .gestemas-floating-group select:focus {
        background: white;
        border-color: var(--gestemas-primary);
        box-shadow: 0 0 0 3px rgba(var(--gestemas-primary-rgb), 0.1);
    }

    .gestemas-floating-group label {
        position: absolute;
        top: 18px;
        left: 16px;
        font-size: 14px;
        color: var(--gestemas-gray-600); /* Gray 600 for better contrast */
        pointer-events: none;
        transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
        transform-origin: left top;
    }

    /* Move label up on focus or when value exists */
    .gestemas-floating-group input:focus ~ label,
    .gestemas-floating-group input:not(:placeholder-shown) ~ label,
    .gestemas-floating-group textarea:focus ~ label,
    .gestemas-floating-group textarea:not(:placeholder-shown) ~ label,
    .gestemas-floating-group select:focus ~ label,
    .gestemas-floating-group select:valid ~ label {
        transform: translateY(-12px) scale(0.8);
        color: var(--gestemas-primary, var(--as-color-primary));
        font-weight: 800;
        background: white;
        padding: 0 4px;
        border-radius: 4px;
        z-index: 10;
    }

    /* Fix Disabled Inputs - Email */
    input:disabled {
        background-color: rgba(0, 0, 0, 0.05) !important;
        color: var(--gestemas-gray-700) !important;
        -webkit-text-fill-color: var(--gestemas-gray-700) !important;
        /* Webkit override */
        border-color: transparent !important;
        cursor: not-allowed;
        opacity: 1;
        /* iOS fix */
    }

    .full-width {
        grid-column: 1 / -1;
    }


    .gestemas-form-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }

    /* ═══════════════════════════════════════════════════════════
   16. SMART COMPONENT LIBRARY (Standardized)
   ═══════════════════════════════════════════════════════════ */

    /* 16.1 Smart Table (Mobile Card View) */
    .gestemas-smart-table {
        width: 100%;
        border-collapse: separate;
        border-spacing: 0 8px;
        /* Spacing between rows */
    }

    .gestemas-smart-table thead th {
        font-size: 11px;
        text-transform: uppercase;
        color: var(--gestemas-gray-500);
        letter-spacing: 0.05em;
        padding: 12px 20px;
        font-weight: 700;
        text-align: left;
    }

    .gestemas-smart-table tbody tr {
        background: white;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.02);
        border-radius: 12px;
        transition: all 0.2s;
    }

    .gestemas-smart-table tbody tr:hover {
        transform: translateY(-2px);
        box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
    }

    .gestemas-smart-table td {
        padding: 16px 20px;
        vertical-align: middle;
        font-size: 14px;
        color: var(--gestemas-gray-700);
        border-top: 1px solid rgba(0, 0, 0, 0.02);
        border-bottom: 1px solid rgba(0, 0, 0, 0.02);
    }

    .gestemas-smart-table td:first-child {
        border-left: 1px solid rgba(0, 0, 0, 0.02);
        border-radius: 12px 0 0 12px;
    }

    .gestemas-smart-table td:last-child {
        border-right: 1px solid rgba(0, 0, 0, 0.02);
        border-radius: 0 12px 12px 0;
    }

    /* Smart Table Mobile Card Transformation */
    @media (max-width: 768px) {
        .gestemas-smart-table {
            display: block;
        }

        .gestemas-smart-table thead {
            display: none;
        }

        .gestemas-smart-table tbody,
        .gestemas-smart-table tr,
        .gestemas-smart-table td {
            display: block;
            width: 100%;
        }

        .gestemas-smart-table tr {
            margin-bottom: 16px;
            border: 1px solid var(--gestemas-gray-200);
            border-radius: 16px;
            /* Card look */
            overflow: hidden;
        }

        .gestemas-smart-table td {
            display: flex;
            justify-content: space-between;
            align-items: center;
            text-align: right;
            padding: 12px 16px;
            border: none;
            border-bottom: 1px solid var(--gestemas-gray-100);
            min-height: 48px;
        }

        .gestemas-smart-table td:last-child {
            border-bottom: none;
            border-radius: 0 0 16px 16px;
            padding-top: 16px;
            justify-content: flex-end;
            /* Actions usually at end */
            background: var(--gestemas-gray-50);
        }

        .gestemas-smart-table td:first-child {
            border-radius: 16px 16px 0 0;
            background: linear-gradient(to right, var(--gestemas-gray-50), white);
            font-weight: 700;
            border-bottom: 2px solid var(--gestemas-primary);
            /* Accent line */
        }

        /* Magic: Use data-label attribute to show header */
        .gestemas-smart-table td::before {
            content: attr(data-label);
            float: left;
            font-weight: 800;
            text-transform: uppercase;
            font-size: 10px;
            color: var(--gestemas-gray-400);
            margin-right: auto;
            display: flex;
            align-items: center;
        }
    }

    /* 16.2 Smart Modal (Bottom Sheet Logic) */
    .gestemas-smart-modal {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(15, 23, 42, 0.6);
        /* Dark dim */
        backdrop-filter: blur(8px);
        z-index: 9999;
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.3s ease;
    }

    .gestemas-smart-modal.active {
        opacity: 1;
        pointer-events: all;
    }

    .gestemas-modal-content {
        background: rgba(255, 255, 255, 0.95);
        width: 90%;
        max-width: 600px;
        border-radius: 24px;
        border: 1px solid rgba(255, 255, 255, 0.5);
        box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
        transform: scale(0.95) translateY(10px);
        transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
        display: flex;
        flex-direction: column;
        max-height: 90vh;
        animation: modalScaleUp 0.3s forwards;
    }

    @keyframes modalScaleUp {
        to {
            transform: scale(1) translateY(0);
        }
    }

    .gestemas-modal-header {
        padding: 20px 24px;
        border-bottom: 1px solid rgba(0, 0, 0, 0.05);
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .gestemas-modal-title {
        font-size: 18px;
        font-weight: 700;
        font-family: 'Outfit', sans-serif;
        color: var(--gestemas-gray-900);
        margin: 0;
    }

    .gestemas-modal-body {
        padding: 24px;
        overflow-y: auto;
        overscroll-behavior: contain;
    }

    .gestemas-modal-footer {
        padding: 20px 24px;
        border-top: 1px solid rgba(0, 0, 0, 0.05);
        display: flex;
        justify-content: flex-end;
        gap: 12px;
        background: rgba(255, 255, 255, 0.5);
        border-radius: 0 0 24px 24px;
    }

    .close-modal-btn {
        background: transparent;
        border: none;
        cursor: pointer;
        color: var(--gestemas-gray-400);
        transition: color 0.2s;
    }

    .close-modal-btn:hover {
        color: var(--gestemas-primary);
    }

    /* Mobile Bottom Sheet Transformation */
    @media (max-width: 768px) {
        .gestemas-smart-modal {
            align-items: flex-end;
            /* Align to bottom */
            padding: 0;
        }

        .gestemas-modal-content {
            width: 100%;
            max-width: 100%;
            border-radius: 24px 24px 0 0;
            margin: 0;
            transform: translateY(100%);
            /* Start off-screen bottom */
            max-height: 85vh;
            /* Safe area */
            animation: none;
            /* Disable desktop animation */
            transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
        }

        .gestemas-smart-modal.active .gestemas-modal-content {
            transform: translateY(0);
        }

        /* Handle bar for bottom sheet indication */
        .gestemas-modal-header::before {
            content: '';
            display: block;
            width: 40px;
            height: 4px;
            background: var(--gestemas-gray-300);
            border-radius: 2px;
            position: absolute;
            top: 8px;
            left: 50%;
            transform: translateX(-50%);
        }

        .gestemas-modal-header {
            position: relative;
            padding-top: 30px;
            /* Space for handle */
        }
    }

    /* ═══════════════════════════════════════════════════════════
   17. AUTOSMART FLOATING WIDGET
   ═══════════════════════════════════════════════════════════ */
    .autosmart-floating-widget {
        position: fixed;
        bottom: 24px;
        right: 24px;
        z-index: 99999;
        font-family: 'Inter', sans-serif;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
    }

    .autosmart-toggle-main {
        width: 48px;
        height: 48px;
        border-radius: 50%;
        background: white;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
        border: 1px solid rgba(0, 0, 0, 0.05);
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        color: var(--gestemas-primary);
        transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .autosmart-toggle-main:hover {
        transform: scale(1.1);
        box-shadow: 0 12px 32px rgba(var(--gestemas-primary-rgb), 0.25);
    }

    .autosmart-widget-content {
        background: rgba(255, 255, 255, 0.9);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        padding: 8px;
        border-radius: 16px;
        box-shadow: 0 16px 40px -10px rgba(0, 0, 0, 0.2);
        border: 1px solid rgba(255, 255, 255, 0.5);
        display: flex;
        flex-direction: column;
        gap: 4px;
        position: absolute;
        bottom: 60px;
        right: 0;
        width: 200px;
        opacity: 0;
        pointer-events: none;
        transform: translateY(10px) scale(0.95);
        transform-origin: bottom right;
        transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .autosmart-floating-widget.active .autosmart-widget-content {
        opacity: 1;
        pointer-events: all;
        transform: translateY(0) scale(1);
    }

    .autosmart-widget-header {
        padding: 8px 12px;
        font-size: 11px;
        font-weight: 800;
        color: var(--gestemas-gray-400);
        text-transform: uppercase;
        letter-spacing: 0.05em;
        border-bottom: 1px solid rgba(0, 0, 0, 0.05);
        margin-bottom: 4px;
    }

    .autosmart-preset-btn {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 10px 12px;
        border: none;
        background: transparent;
        border-radius: 10px;
        cursor: pointer;
        font-size: 13px;
        font-weight: 600;
        color: var(--gestemas-gray-700);
        transition: all 0.2s;
        width: 100%;
        text-align: left;
    }

    .autosmart-preset-btn:hover {
        background: rgba(0, 0, 0, 0.04);
        color: var(--gestemas-primary);
    }

    .autosmart-preset-btn.active {
        background: var(--gestemas-primary);
        color: white;
        box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.2);
    }

    .autosmart-preset-btn i {
        width: 16px;
        height: 16px;

    }

    /* Chart Containers */
    .chart-container,
    .gestemas-card__body canvas {
        position: relative !important;
        width: 100% !important;
        /* Height handled by parent or JS */
    }
}


/* ═══════════════════════════════════════════════════════════
   6. NEXUS STATUS SELECTOR (Glassmorphism V3 Pro)
   ═══════════════════════════════════════════════════════════ */
.nexus-status-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(8px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.nexus-status-overlay.is-active {
    opacity: 1;
    visibility: visible;
}

.nexus-status-modal {
    width: 90%;
    max-width: 450px;
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.6);
    border-radius: 28px;
    padding: 30px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.4) inset;
    transform: scale(0.9) translateY(20px);
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    text-align: center;
}

.nexus-status-overlay.is-active .nexus-status-modal {
    transform: scale(1) translateY(0);
}

.nexus-status-header h2 {
    font-family: var(--font-outfit, 'Outfit', sans-serif);
    font-weight: 800;
    font-size: 22px;
    color: var(--as-color-text-strong);
    margin-bottom: 8px;
}

.nexus-status-header p {
    font-size: 14px;
    color: var(--as-color-text-muted);
    margin-bottom: 24px;
}

.nexus-status-options {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.status-option-card {
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 18px;
    padding: 16px;
    gap: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: left;
}

.status-option-card:hover {
    background: white;
    transform: translateX(6px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
}

.status-icon-wrapper {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}

/* Status Variants */
.status-option-card[data-status="realizada"] .status-icon-wrapper {
    background: var(--as-color-success-soft);
    color: var(--as-color-success);
}

.status-option-card[data-status="realizada"]:hover {
    border-color: var(--as-color-success);
}

.status-option-card[data-status="pendiente"] .status-icon-wrapper {
    background: var(--as-color-info-soft);
    color: var(--as-color-info-bright);
}

.status-option-card[data-status="pendiente"]:hover {
    border-color: var(--as-color-info-bright);
}

.status-option-card[data-status="no_realizada"] .status-icon-wrapper {
    background: var(--as-color-danger-soft);
    color: var(--as-color-danger);
}

.status-option-card[data-status="no_realizada"]:hover {
    border-color: var(--as-color-danger);
}

.option-content b {
    display: block;
    font-size: 15px;
    color: var(--as-color-text-strong);
}

.option-content span {
    font-size: 12px;
    color: var(--as-color-text-muted);
}

.nexus-status-footer {
    margin-top: 24px;
}

.nexus-btn-cancel {
    background: transparent;
    border: none;
    color: var(--as-color-text-subtle);
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    padding: 10px 20px;
    transition: color 0.3s;
}

.nexus-btn-cancel:hover {
    color: var(--gestemas-gray-600);
}

@media (max-width: 500px) {
    .nexus-status-modal {
        padding: 24px 20px;
    }
}

/* ═══════════════════════════════════════════════════════════
   7. GLASSMORPISM V3 PRO - ADVANCED COMPONENTS
   ═══════════════════════════════════════════════════════════ */

/* Professional State Selector */
.glass-v3-pro-selector {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(10px);
    padding: 10px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.5);
}

.glass-v3-btn-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 8px;
    border-radius: 16px;
    border: 1px solid transparent;
    background: transparent;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    color: var(--as-color-text-muted);
}

.glass-v3-btn-state i {
    width: 20px;
    height: 20px;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.glass-v3-btn-state span {
    font-size: 11px;
    font-weight: 800;
    font-family: var(--font-outfit, sans-serif);
}

.glass-v3-btn-state:hover {
    background: rgba(255, 255, 255, 0.6);
    color: var(--as-color-text-strong);
}

.glass-v3-btn-state:hover i {
    transform: translateY(-2px);
}

/* Active States */
.glass-v3-btn-state.active[data-target="pendiente"],
.glass-v3-btn-state.active[data-state="pendiente"] {
    background: white;
    box-shadow: 0 10px 20px rgba(var(--as-color-info-rgb), 0.15);
    border-color: var(--as-color-info-bright);
    color: var(--as-color-info-bright);
}

.glass-v3-btn-state.active[data-target="realizada"],
.glass-v3-btn-state.active[data-state="realizada"] {
    background: white;
    box-shadow: 0 10px 20px rgba(var(--as-color-success-rgb), 0.15);
    border-color: var(--as-color-success);
    color: var(--as-color-success);
}

.glass-v3-btn-state.active[data-target="no_realizada"],
.glass-v3-btn-state.active[data-state="no_realizada"] {
    background: white;
    box-shadow: 0 10px 20px rgba(var(--as-color-danger-rgb), 0.15);
    border-color: var(--as-color-danger);
    color: var(--as-color-danger);
}

/* Glass V3 Pro Panel */
.glass-v3-holographic-panel {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.4));
    backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.6);
    border-radius: 24px;
    padding: 24px;
    box-shadow:
        0 8px 32px rgba(0, 0, 0, 0.05),
        0 0 0 1px rgba(255, 255, 255, 0.2) inset,
        0 1px 2px rgba(255, 255, 255, 0.5) inset;
    position: relative;
    overflow: hidden;
}

.glass-v3-stat-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: 12px;
    font-size: 11px;
    font-weight: 700;
    color: var(--gestemas-gray-600);
}

.glass-v3-divider {
    height: 1px;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0.05), transparent);
    margin: 20px 0;
}

.glass-v3-icon-blob {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: rgba(var(--gestemas-primary-rgb), 0.1);
    color: var(--gestemas-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.1);
}

@media (max-width: 500px) {
    .glass-v3-pro-selector {
        grid-template-columns: 1fr;
    }

    .glass-v3-btn-state {
        flex-direction: row;
        justify-content: flex-start;
        padding: 12px 20px;
    }
}

/* Filter Pill Premium */
.nexus-filter-pill {
    position: relative;
    gap: 8px;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    border-radius: 12px;
}

.nexus-filter-pill.is-filtering {
    background: rgba(var(--gestemas-primary-rgb), 0.1);
    color: var(--gestemas-primary);
    border-color: rgba(var(--gestemas-primary-rgb), 0.3);
    box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.1);
}

.nexus-filter-pill.is-filtering::after {
    content: '';
    position: absolute;
    top: 6px;
    right: 6px;
    width: 6px;
    height: 6px;
    background: var(--gestemas-primary);
    border-radius: 50%;
    border: 2px solid white;
}

/* List Block Status Refinement */
.nexus-list-block.is-completed {
    background: rgba(248, 250, 252, 0.5);
    border-color: rgba(0, 0, 0, 0.03);
}

.nexus-list-block.is-completed .nexus-outfit {
    opacity: 0.5;
}

/* Animations & Special States */
.premium-card.is-completed {
    opacity: 0.8;
}

.premium-card.is-overdue,
.nexus-list-block.is-overdue {
    border-color: rgba(var(--as-color-danger-rgb), 0.3);
    background: linear-gradient(to right, rgba(var(--as-color-danger-rgb), 0.05), white);
}

.premium-card.is-overdue::before {
    content: 'VENCIDA';
    position: absolute;
    top: 12px;
    right: -25px;
    background: var(--as-color-danger);
    color: white;
    font-size: 8px;
    font-weight: 900;
    padding: 2px 25px;
    transform: rotate(45deg);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    z-index: 1;
}

.is-late .nexus-outfit,
.is-late .summary-title {
    color: var(--as-color-warning-deep);
}

.is-late {
    border-left: 3px solid var(--gst-warning);
}

/* 
   Auto-Fix: Standardize Main Container Margins to 10px on Mobile 
   Requested by user for 'pone', 'intervenciones' standard
*/
@media (max-width: 768px) {

    .gestemas-module-root,
    .pone-module,
    .gestemas-profile-360,
    .gestemas-smart-container:not(.gestemas-dashboard--expanded) {
        padding-left: 10px;
        padding-right: 10px;
        margin-left: 0;
        margin-right: 0;
        width: 100%;
        box-sizing: border-box;
    }
}

/* ═══════════════════════════════════════════════════════════
   8. UNIVERSAL MODAL/FLOATER STANDARD (AUTO-SMART)
   "Garantía de visibilidad y centrado inteligente en cualquier pantalla"
   ═══════════════════════════════════════════════════════════ */

/* Modal Backdrop & Wrapper guarantees */
.gestemas-modal,
.gestemas-modal-backdrop,
.pone-modal-premium {
    display: flex;
    align-items: center;
    /* Vertical center by default */
    justify-content: center;
    /* Horizontal center by default */
    padding: var(--page-padding-mobile, 16px);
    box-sizing: border-box;
    /* Ensure no overflow of the backdrop itself */
    overflow: hidden !important;
    height: 100dvh;
    /* Use dynamic viewport height if possible */
}

/* Base Modal Container Fixes */
.gestemas-modal-premium,
.gestemas-modal-content,
.nexus-modal,
.glass-error-modal {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: var(--modal-max-w, 850px);
    max-height: calc(100vh - 32px);
    /* Never exceed screen minus padding */
    max-height: calc(100dvh - 32px);
    /* Mobile-friendly safe area */
    margin: 0 auto;
    /* Force horizontal centering */
    overflow: hidden !important;
    /* Force clip for border-radius */
    box-sizing: border-box;
    position: relative;
    /* Standardized Container Context for Adaptive Components */
    container-type: inline-size;
    container-name: module;
}

/* Modal Body Strict Flex-Shrink Rule */
.gestemas-modal-body-premium,
.gestemas-modal-body,
.nexus-modal-body {
    flex: 1 1 auto;
    overflow-y: auto;
    min-height: 0;
    /* CRITICAL for flex child scroll */
    padding: var(--block-padding, 32px);
    /* Improve mobile scroll physics */
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
}

/* Intelligent Mobile Adjustment (Responsive) */
@media (max-width: 768px) {

    .gestemas-modal,
    .gestemas-modal-backdrop,
    .pone-modal-premium {
        padding: 0;
        /* Remove outer pad to use full width */
        align-items: flex-end;
        /* Bottom sheet aesthetic */
    }

    .gestemas-modal-premium,
    .gestemas-modal-content,
    .nexus-modal {
        max-width: 100%;
        max-height: 95dvh;
        /* Leave top space for closing context */
        margin: 0;
        /* Remove auto-margin */
        border-bottom-left-radius: 0 !important;
        border-bottom-right-radius: 0 !important;
        /* Add safe area bottom padding */
        padding-bottom: env(safe-area-inset-bottom, 20px);
    }

    /* Keep error modals and small alerts centered even on mobile */
    .glass-error-modal {
        align-self: center;
        border-radius: 32px !important;
        max-height: 90vh;
        margin: 16px;
    }
}

/* ═══════════════════════════════════════════════════════════
   8. CAPACITY ADVISOR (Asesor de Alcance e Impacto)
   ═══════════════════════════════════════════════════════════ */

.gestemas-advisor-link {
    font-size: 11px;
    font-weight: 850;
    color: var(--gestemas-primary-dark, var(--as-color-primary));
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 4px;
    padding: 2px 8px;
    background: rgba(var(--gestemas-primary-rgb), 0.08);
    border-radius: 6px;
    transition: all 0.3s ease;
    cursor: pointer;
    text-transform: uppercase;
}

.gestemas-advisor-link:hover {
    background: var(--gestemas-primary-dark);
    color: white;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(var(--gestemas-primary-rgb), 0.2);
}

.gestemas-advisor-link i {
    width: 12px;
    height: 12px;
}

/* Advisor Empty State Card */
.gestemas-advisor-card {
    background: white;
    border-radius: 32px;
    padding: 60px 40px;
    text-align: center;
    max-width: 600px;
    margin: 40px auto;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.05);
    border: 1px solid var(--gestemas-border-color, var(--as-color-border-muted));
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    position: relative;
    overflow: hidden;
    animation: g-fade-up 0.6s ease-out;
}

.advisor-visual {
    position: relative;
    width: 120px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.advisor-glow {
    position: absolute;
    inset: -10px;
    background: conic-gradient(from 0deg, var(--as-color-primary), var(--as-color-purple-vivid), var(--as-color-pink-vivid), var(--as-color-primary));
    border-radius: 50%;
    filter: blur(25px);
    opacity: 0.15;
    animation: rotate 6s linear infinite;
}

.advisor-icon-wrapper {
    position: relative;
    z-index: 2;
    width: 80px;
    height: 80px;
    background: white;
    border-radius: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
    color: var(--gestemas-primary);
}

.advisor-content h2 {
    font-size: 2rem;
    font-weight: 850;
    color: var(--as-color-text-strong);
    margin-bottom: 12px;
    letter-spacing: -0.02em;
}

.advisor-content p {
    font-size: 1.1rem;
    color: var(--as-color-text-muted);
    line-height: 1.6;
    margin-bottom: 0;
}

.advisor-cta-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
    max-width: 320px;
}

.btn-advisor-primary {
    padding: 16px 24px;
    background: linear-gradient(135deg, var(--gestemas-primary) 0%, var(--as-color-primary) 100%);
    color: white;
    border-radius: 18px;
    font-weight: 800;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 10px 25px -5px rgba(var(--gestemas-primary-rgb), 0.4);
    border: none;
    cursor: pointer;
}

.btn-advisor-primary:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 15px 35px -5px rgba(var(--gestemas-primary-rgb), 0.5);
}

.advisor-benefit-tag {
    font-size: 11px;
    font-weight: 800;
    color: var(--as-color-success-strong);
    background: rgba(16, 185, 129, 0.1);
    padding: 4px 12px;
    border-radius: 99px;
    text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════
   11. MODULE: TAREAS (PREMIUM LIST & GRID) REDESIGN
   ═══════════════════════════════════════════════════════════ */

.premium-list-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.nexus-list-block {
    background: white;
    border-radius: 16px;
    padding: 16px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 20px;
    border: 1px solid var(--glass-border, rgba(0,0,0,0.05));
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.nexus-list-block:hover {
    transform: translateX(4px);
    border-color: var(--gestemas-primary);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
}

.nexus-list-block.is-completed {
    background: var(--as-color-surface);
    border-color: var(--as-color-border-muted);
    opacity: 0.8;
}

.nexus-check-wrapper .status-toggle-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--as-color-border-muted);
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
}

.status-toggle-btn.completed, 
.status-toggle-btn.completed_late {
    background: var(--as-color-success);
    border-color: var(--as-color-success);
    color: white;
}

.nexus-block-main {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.main-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.task-title {
    font-weight: 800;
    font-size: 15px;
    color: var(--as-color-text-strong);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 450px;
}

.sub-row {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.meta-item {
    font-size: 12px;
    color: var(--as-color-text-muted);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.text-danger { color: var(--as-color-danger); font-weight: 800; }

.feedback-quick-group {
    display: flex;
    gap: 4px;
    padding: 6px;
    background: var(--as-color-surface-soft);
    border-radius: 12px;
}

/* Premium Card Layout (Grid) */
.smart-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
}

.premium-card {
    background: white;
    border-radius: 20px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    height: 100%;
    border: 1px solid var(--glass-border);
    transition: all 0.3s ease;
}

.premium-card:hover { transform: translateY(-6px); border-color: var(--gestemas-primary); }

@container module (max-width: 550px) {
    .nexus-list-block { grid-template-columns: auto 1fr; gap: 12px; }
    .nexus-block-actions { grid-column: 1 / -1; justify-content: flex-end; padding-top: 12px; border-top: 1px solid var(--as-color-surface-soft); }
    .task-title { max-width: 100%; white-space: normal; }
}

/* ==========================================================================
   MODULE HERO + COMMANDBAR STANDARD (ESTUDIANTES / INTERVENCIONES / TAREAS / PONE / SALUD)
   ========================================================================== */

.gestemas-module-hero {
    border-radius: 22px;
    padding: clamp(16px, 2vw, 26px);
    gap: 14px;
}

.gestemas-module-hero .gestemas-page-header__left .gestemas-heading-xl {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}

.gestemas-module-hero .gestemas-page-header__left .gestemas-heading-xl i {
    width: 22px;
    height: 22px;
    color: var(--gestemas-primary);
}

.gestemas-module-guide {
    margin: 6px 0 0;
    font-size: 12px;
    line-height: 1.45;
    color: var(--gestemas-gray-500);
    font-weight: 600;
}

.gestemas-module-commandbar {
    padding: 12px 14px;
    border-radius: 18px;
    margin-top: 12px;
}

.gestemas-module-commandbar .control-search {
    min-height: 52px;
}

.gestemas-module-commandbar .control-search-input {
    min-height: 46px;
}

.gestemas-module-commandbar .control-actions {
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
}

.action-label-compact {
    display: inline-block;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
}

.gestemas-module-commandbar .view-toggle {
    padding: 4px;
}

.gestemas-module-commandbar .toggle-btn {
    min-width: 42px;
    min-height: 42px;
}

@media (max-width: 1024px) {
    .gestemas-module-hero .gestemas-actions-group {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .gestemas-module-hero {
        border-radius: 18px;
        padding: 14px;
    }

    .gestemas-module-hero .gestemas-page-header__left {
        width: 100%;
    }

    .gestemas-module-hero .gestemas-page-header__left .gestemas-heading-xl {
        font-size: clamp(1.7rem, 6vw, 2rem);
        line-height: 1.15;
    }

    .gestemas-module-hero .gestemas-text-muted {
        margin-bottom: 0;
        font-size: 15px;
        line-height: 1.45;
    }

    .gestemas-module-guide {
        font-size: 12px;
    }

    .gestemas-module-hero .gestemas-consumption-indicator {
        padding: 6px 10px;
        border-radius: 999px;
        background: rgba(79, 70, 229, 0.08);
        margin: 0;
    }

    .gestemas-module-hero .gestemas-consumption-indicator .consumption-bar,
    .gestemas-module-hero .gestemas-consumption-indicator > div[title],
    .gestemas-module-hero .gestemas-consumption-indicator .gestemas-advisor-link {
        display: none;
    }

    .gestemas-module-hero .gestemas-actions-group .gestemas-btn--primary-premium,
    .gestemas-module-hero .gestemas-actions-group #btn-add-estudiante {
        width: 100%;
        justify-content: center;
        min-height: 48px;
    }

    .gestemas-module-commandbar {
        padding: 10px;
        gap: 8px;
        border-radius: 16px;
    }

    .gestemas-module-commandbar .control-search {
        width: 100%;
        margin-bottom: 0;
    }

    .gestemas-module-commandbar .active-filters-indicator {
        width: 100%;
        justify-content: space-between;
        margin-top: 2px;
    }

    .gestemas-module-commandbar .control-filters {
        margin-top: 2px;
    }

    .gestemas-module-commandbar .control-actions {
        width: 100%;
        justify-content: space-between;
        gap: 6px;
    }

    .gestemas-module-commandbar .view-toggle {
        margin-left: auto;
    }

    .gestemas-module-commandbar .control-actions .gestemas-btn {
        min-height: 40px;
        padding-left: 10px;
        padding-right: 10px;
        gap: 6px;
    }

    .action-label-compact {
        font-size: 11px;
    }
}

@media (max-width: 480px) {
    .gestemas-module-hero {
        padding: 12px;
    }

    .gestemas-module-hero .gestemas-page-header__left .gestemas-heading-xl i {
        width: 20px;
        height: 20px;
    }

    .gestemas-module-commandbar .toggle-btn {
        min-width: 40px;
        min-height: 40px;
    }
}

/* ==========================================================================
   FEEDBACK CHARTS + KPI SPACING STANDARD
   ========================================================================== */

.gestemas-indicators-section {
    margin-bottom: clamp(14px, 2.2vw, 22px);
}

.gestemas-module-metrics-row {
    margin-bottom: clamp(10px, 1.8vw, 16px);
}

.feedback-indicators-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: clamp(10px, 1.8vw, 16px);
    margin-top: 10px;
}

.feedback-combined-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(10px, 1.8vw, 16px);
}

.feedback-col-title {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--as-color-text-muted);
    margin-bottom: 8px;
}

.feedback-chart-card {
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.72);
    padding: 10px;
}

.feedback-chart-canvas-wrap {
    position: relative;
    height: clamp(150px, 24vw, 190px);
}

.feedback-chart-canvas-wrap--wide {
    height: clamp(160px, 28vw, 220px);
}

.feedback-chart-canvas-wrap canvas {
    width: 100% !important;
    height: 100% !important;
    max-height: none !important;
    padding: 0 !important;
    background: transparent !important;
}

.feedback-metrics-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 8px;
}

.feedback-metric-item {
    border-radius: 10px;
    padding: 6px 8px;
    text-align: center;
    border: 1px solid transparent;
    background: var(--as-color-surface);
}

.feedback-metric-item.useful {
    border-color: rgba(var(--as-color-success-rgb), 0.25);
    background: rgba(var(--as-color-success-rgb), 0.09);
}

.feedback-metric-item.not-useful {
    border-color: rgba(var(--as-color-danger-rgb), 0.25);
    background: rgba(var(--as-color-danger-rgb), 0.09);
}

.feedback-metric-item.no-response {
    border-color: rgba(var(--as-color-warning-rgb), 0.25);
    background: rgba(var(--as-color-warning-rgb), 0.09);
}

.feedback-metric-label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    color: var(--as-color-text-muted);
}

.feedback-metric-value {
    display: block;
    font-size: 16px;
    line-height: 1.1;
    font-weight: 800;
    color: var(--gestemas-gray-900);
}

.feedback-metric-pct {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: var(--gestemas-gray-700);
}

.profile-insight-actions {
    flex-wrap: wrap;
    align-items: center;
}

.insight-icon-action {
    width: 42px;
    height: 42px;
    min-width: 42px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    border: 1px solid rgba(99, 102, 241, 0.18);
    background: rgba(255, 255, 255, 0.9);
    color: var(--gestemas-primary);
    box-shadow: 0 6px 14px rgba(99, 102, 241, 0.08);
}

.insight-icon-action:hover {
    transform: translateY(-1px);
    border-color: rgba(99, 102, 241, 0.3);
}

.insight-icon-action.is-active-like {
    background: var(--gestemas-primary);
    border-color: transparent;
    color: #fff;
}

.insight-icon-action.is-active-dislike {
    background: #ef4444;
    border-color: transparent;
    color: #fff;
}

.insight-icon-action--comment {
    margin-left: auto;
}

@media (max-width: 768px) {
    .feedback-combined-grid {
        grid-template-columns: 1fr;
    }

    .feedback-chart-canvas-wrap {
        height: 160px;
    }

    .feedback-metric-value {
        font-size: 15px;
    }

    .profile-insight-actions {
        gap: 8px;
    }

    .insight-icon-action,
    .insight-icon-action--comment {
        width: 40px;
        height: 40px;
        min-width: 40px;
        margin-left: 0;
    }
}
