/* ====================================================================
   PROMPTLAB — DESIGN SYSTEM
   Fichero: /Content/css/promptlab.css
   Compartido por TODAS las vistas. Cero CSS inline en .vbhtml.
   ==================================================================== */

/* ================================================================
   VARIABLES
   ================================================================ */
:root {
    --pl-amber: #FFB539;
    --pl-amber-dark: #E5A030;
    --pl-amber-light: #FFF3DC;
    --pl-amber-rgb: 255, 181, 57;
    --pl-navy: #141D38;
    --pl-navy-medium: #1E2A4A;
    --pl-navy-light: #2A3A5C;
    --pl-navy-rgb: 20, 29, 56;
    --pl-bg: #F4F6FA;
    --pl-card-bg: #FFFFFF;
    --pl-border: #E2E6EF;
    --pl-text: #1A1A2E;
    --pl-text-secondary: #6B7280;
    --pl-text-muted: #9CA3AF;
    --pl-success: #22C55E;
    --pl-success-bg: #DCFCE7;
    --pl-error: #EF4444;
    --pl-error-bg: #FEE2E2;
    --pl-warning: #F59E0B;
    --pl-info: #3B82F6;
    --pl-info-bg: #DBEAFE;
    --pl-shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
    --pl-shadow-md: 0 4px 12px rgba(0,0,0,0.08);
    --pl-shadow-lg: 0 8px 24px rgba(0,0,0,0.10);
    --pl-radius-sm: 8px;
    --pl-radius-md: 12px;
    --pl-radius-lg: 16px;
    --pl-radius-xl: 20px;
    --pl-transition: all 0.2s ease;
    --sidebar-width: 260px;
    --sidebar-collapsed: 70px;
    --header-height: 60px;
}

/* ================================================================
   RESET & BASE
   ================================================================ */
*, *::before, *::after { box-sizing: border-box; }
body {
    font-family: 'Roboto', sans-serif;
    font-size: 14px; color: var(--pl-text);
    background: var(--pl-bg); margin: 0;
    line-height: 1.5; -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 { font-family: 'Barlow', sans-serif; font-weight: 600; color: var(--pl-navy); margin: 0; }
h1 { font-size: 28px; font-weight: 700; }
h2 { font-size: 22px; }
h3 { font-size: 18px; }
h4 { font-size: 16px; }
a { color: var(--pl-amber); text-decoration: none; }
a:hover { color: var(--pl-amber-dark); }

/* ================================================================
   SIDEBAR
   ================================================================ */
.pl-sidebar { position: fixed; top: 0; left: 0; width: var(--sidebar-width); height: 100vh; background: var(--pl-navy); z-index: 1000; display: flex; flex-direction: column; transition: width 0.3s ease; overflow: hidden; }
.pl-sidebar-brand { padding: 16px 20px; display: flex; align-items: center; gap: 12px; border-bottom: 1px solid rgba(255,255,255,0.06); min-height: 60px; }
.pl-sidebar-brand .brand-icon { width: 36px; height: 36px; background: var(--pl-amber); border-radius: var(--pl-radius-sm); display: flex; align-items: center; justify-content: center; font-size: 18px; color: var(--pl-navy); flex-shrink: 0; }
.pl-sidebar-brand .brand-text { font-family: 'Barlow', sans-serif; font-weight: 700; font-size: 20px; color: #fff; white-space: nowrap; }
.pl-sidebar-brand .brand-text span { color: var(--pl-amber); }
.pl-sidebar-nav { flex: 1; padding: 12px 0; overflow-y: auto; overflow-x: hidden; }
.pl-sidebar-nav::-webkit-scrollbar { width: 4px; }
.pl-sidebar-nav::-webkit-scrollbar-track { background: transparent; }
.pl-sidebar-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }
.pl-nav-section { padding: 16px 20px 6px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.8px; color: rgba(255,255,255,0.35); white-space: nowrap; }
.pl-nav-item { display: flex; align-items: center; gap: 12px; padding: 10px 20px; margin: 2px 8px; color: rgba(255,255,255,0.7); font-size: 14px; font-weight: 500; border-radius: var(--pl-radius-sm); border-left: 3px solid transparent; transition: var(--pl-transition); text-decoration: none; cursor: pointer; white-space: nowrap; }
.pl-nav-item:hover { background: rgba(255,255,255,0.06); color: #fff; }
.pl-nav-item.active { background: rgba(var(--pl-amber-rgb), 0.12); color: var(--pl-amber); border-left-color: var(--pl-amber); }
.pl-nav-item i { width: 20px; text-align: center; font-size: 15px; flex-shrink: 0; }
.pl-nav-badge { margin-left: auto; background: var(--pl-amber); color: var(--pl-navy); font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 20px; min-width: 20px; text-align: center; display: none; }
.pl-nav-badge.visible { display: inline-block; }
.pl-sidebar-footer { padding: 16px; border-top: 1px solid rgba(255,255,255,0.06); }
.pl-sidebar-user { display: flex; align-items: center; gap: 12px; }
.pl-user-avatar { width: 36px; height: 36px; background: var(--pl-amber); color: var(--pl-navy); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; flex-shrink: 0; }
.pl-user-info { overflow: hidden; }
.pl-user-name { color: #fff; font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pl-user-plan { color: rgba(255,255,255,0.45); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ================================================================
   HEADER
   ================================================================ */
.pl-header { position: fixed; top: 0; left: var(--sidebar-width); right: 0; height: var(--header-height); background: var(--pl-card-bg); border-bottom: 1px solid var(--pl-border); display: flex; align-items: center; padding: 0 24px; gap: 16px; z-index: 999; transition: left 0.3s ease; }
.pl-header-toggle { display: none; background: none; border: none; font-size: 18px; color: var(--pl-text-secondary); cursor: pointer; padding: 8px; }
.pl-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--pl-text-secondary); }
.pl-breadcrumb a { color: var(--pl-amber); text-decoration: none; }
.pl-breadcrumb .separator { font-size: 10px; color: var(--pl-text-muted); }
.pl-breadcrumb .current { color: var(--pl-text); font-weight: 600; }
.pl-header-actions { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.pl-header-btn { background: none; border: none; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: var(--pl-radius-sm); color: var(--pl-text-secondary); cursor: pointer; font-size: 16px; transition: var(--pl-transition); position: relative; }
.pl-header-btn:hover { background: var(--pl-bg); color: var(--pl-text); }
.pl-header-btn .notification-dot { position: absolute; top: 6px; right: 6px; width: 8px; height: 8px; background: var(--pl-error); border-radius: 50%; border: 2px solid var(--pl-card-bg); display: none; }
.pl-header-btn .notification-dot.visible { display: block; }

/* ================================================================
   CONTENT AREA
   ================================================================ */
.pl-content { margin-left: var(--sidebar-width); padding-top: var(--header-height); min-height: 100vh; transition: margin-left 0.3s ease; }

/* ================================================================
   PAGE CONTAINER
   ================================================================ */
.pl-page { max-width: 1400px; margin: 0 auto; padding: 28px 24px 40px; }

/* ================================================================
   BUTTONS — .btn-pl
   ================================================================ */
.btn-pl { display: inline-flex; align-items: center; gap: 6px; padding: 8px 18px; border-radius: var(--pl-radius-sm); font-size: 13px; font-weight: 600; border: none; cursor: pointer; transition: var(--pl-transition); text-decoration: none; line-height: 1.4; }
.btn-pl-primary { background: var(--pl-amber); color: var(--pl-navy); }
.btn-pl-primary:hover { background: var(--pl-amber-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(var(--pl-amber-rgb), 0.3); }
.btn-pl-secondary { background: #e5e7eb; color: var(--pl-navy); }
.btn-pl-secondary:hover { background: #d1d5db; }
.btn-pl-ghost { background: transparent; color: var(--pl-text-secondary); border: 1px solid var(--pl-border); }
.btn-pl-ghost:hover { background: var(--pl-bg); }
.btn-pl-danger { color: var(--pl-error); border: 1px solid #fecaca; background: #fff; }
.btn-pl-danger:hover { background: var(--pl-error-bg); }
.btn-pl-sm { padding: 5px 12px; font-size: 12px; }
.btn-pl-lg { padding: 10px 24px; font-size: 15px; }
.btn-pl-full { width: 100%; justify-content: center; }

/* Botón gradiente auth */
.pl-btn-primary { width: 100%; padding: 12px; border: none; border-radius: var(--pl-radius-sm); background: linear-gradient(135deg, var(--pl-amber), var(--pl-amber-dark)); color: var(--pl-navy); font-family: 'Barlow', sans-serif; font-size: 15px; font-weight: 700; cursor: pointer; transition: var(--pl-transition); }
.pl-btn-primary:hover { box-shadow: 0 4px 16px rgba(var(--pl-amber-rgb), 0.4); transform: translateY(-1px); }
.pl-btn-primary:disabled { opacity: 0.6; cursor: not-allowed; transform: none; box-shadow: none; }

/* ================================================================
   TABS
   ================================================================ */
.pl-tabs { display: flex; gap: 0; border-bottom: 2px solid var(--pl-border); margin-bottom: 24px; }
.pl-tab { padding: 10px 20px; font-size: 14px; font-weight: 600; cursor: pointer; border: none; background: none; position: relative; bottom: -2px; border-bottom: 2px solid transparent; transition: var(--pl-transition); color: var(--pl-text-muted); display: inline-flex; align-items: center; gap: 6px; }
.pl-tab:hover { color: var(--pl-navy); }
.pl-tab.active { color: var(--pl-navy); border-bottom-color: var(--pl-amber); }
.pl-tab-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 20px; height: 20px; border-radius: 10px; font-size: 11px; font-weight: 700; background: var(--pl-amber); color: #fff; padding: 0 6px; }

/* ================================================================
   BADGES
   ================================================================ */
.pl-badge { display: inline-block; padding: 3px 10px; border-radius: 12px; font-size: 12px; font-weight: 600; }
.pl-badge-primary { background: rgba(var(--pl-amber-rgb), 0.15); color: #b8884a; }
.pl-badge-info { background: rgba(var(--pl-navy-rgb), 0.08); color: var(--pl-navy); }
.pl-badge-shared { background: rgba(59,130,246,0.1); color: #3b82f6; }
.pl-badge-model { background: #EEF2FF; color: #4338CA; border: 1px solid #C7D2FE; }
.pl-badge-count { background: #f3f4f6; color: var(--pl-text-secondary); }

/* ================================================================
   EMPTY STATE
   ================================================================ */
.pl-empty { text-align: center; padding: 60px 20px; color: var(--pl-text-muted); }
.pl-empty i { font-size: 48px; margin-bottom: 15px; color: #d1d5db; display: block; }
.pl-empty h3 { color: var(--pl-navy); margin-bottom: 8px; }

/* ================================================================
   PROJECT CARDS (Index)
   ================================================================ */
.pl-projects-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 20px; }
.pl-project-card { background: var(--pl-card-bg); border-radius: var(--pl-radius-md); padding: 24px; border: 1px solid var(--pl-border); cursor: pointer; transition: var(--pl-transition); }
.pl-project-card:hover { box-shadow: var(--pl-shadow-md); transform: translateY(-2px); }
.pl-project-card h3 { color: var(--pl-navy); font-size: 18px; font-weight: 700; margin: 10px 0 8px; }
.pl-project-card p { color: var(--pl-text-secondary); font-size: 14px; line-height: 1.5; margin-bottom: 15px; }
.pl-project-meta { font-size: 13px; color: var(--pl-text-muted); }
.pl-project-meta i { color: var(--pl-amber); margin-right: 4px; }

/* Page header (titulo + boton) */
.pl-page-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; flex-wrap: wrap; gap: 15px; }
.pl-page-header h1 { display: flex; align-items: center; gap: 10px; }
.pl-page-header h1 i { color: var(--pl-amber); }

/* ================================================================
   PROJECT DETAIL (Ver.vbhtml)
   ================================================================ */
.pl-detail-card { background: var(--pl-card-bg); border-radius: var(--pl-radius-xl); padding: 32px; box-shadow: var(--pl-shadow-sm); }
.pl-detail-header { margin-bottom: 30px; padding-bottom: 24px; border-bottom: 1px solid var(--pl-border); }
.pl-detail-header h1 { margin: 0 0 10px; }
.pl-detail-meta { color: var(--pl-text-secondary); font-size: 13px; display: flex; gap: 16px; align-items: center; }
.pl-detail-meta i { color: var(--pl-amber); margin-right: 4px; }
.pl-detail-desc { margin-top: 12px; color: var(--pl-text-secondary); font-size: 14px; margin-bottom: 0; }
.pl-readonly-alert { background: var(--pl-amber-light); border: 1px solid var(--pl-amber); border-radius: var(--pl-radius-sm); padding: 12px 18px; margin-bottom: 20px; font-size: 14px; color: #92400e; }
.pl-readonly-alert i { color: var(--pl-amber); }
.pl-section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.pl-section-header h2 { display: flex; align-items: center; gap: 8px; margin: 0; }
.pl-section-header h2 i { color: var(--pl-amber); }

/* ================================================================
   AGENT CARDS (Ver.vbhtml)
   ================================================================ */
.pl-agent-card { background: var(--pl-card-bg); border-radius: var(--pl-radius-md); margin-bottom: 16px; box-shadow: var(--pl-shadow-sm); border: 1px solid var(--pl-border); overflow: hidden; }
.pl-agent-header { padding: 20px 24px; display: flex; justify-content: space-between; align-items: flex-start; cursor: pointer; transition: background 0.2s; }
.pl-agent-header:hover { background: var(--pl-bg); }
.pl-agent-info h3 { margin: 0 0 4px; font-size: 17px; font-weight: 700; color: var(--pl-navy); display: flex; align-items: center; gap: 8px; }
.pl-agent-desc { color: var(--pl-text-secondary); font-size: 13px; margin: 0; }
.pl-agent-meta { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }
.pl-agent-body { display: none; border-top: 1px solid var(--pl-border); }
.pl-agent-body.open { display: block; }
.pl-prompt-tabs { display: flex; border-bottom: 1px solid var(--pl-border); background: var(--pl-bg); }
.pl-prompt-tab { padding: 12px 24px; font-size: 13px; font-weight: 600; color: var(--pl-text-secondary); cursor: pointer; border: none; background: none; border-bottom: 2px solid transparent; transition: var(--pl-transition); }
.pl-prompt-tab:hover { color: var(--pl-navy); }
.pl-prompt-tab.active { color: var(--pl-amber); border-bottom-color: var(--pl-amber); }

/* ================================================================
   VERSION ITEMS
   ================================================================ */
.pl-versions-container { padding: 20px 24px; min-height: 80px; }
.pl-version-item { padding: 16px; border: 1px solid var(--pl-border); border-radius: var(--pl-radius-sm); margin-bottom: 10px; transition: border-color 0.2s; }
.pl-version-item:hover { border-color: var(--pl-amber); }
.pl-version-item.destacada { border-left: 3px solid var(--pl-amber); }
.pl-version-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.pl-version-badge { background: var(--pl-amber); color: var(--pl-navy); padding: 3px 10px; border-radius: 14px; font-weight: 700; font-size: 12px; }
.pl-version-date { color: var(--pl-text-muted); font-size: 12px; }
.pl-version-preview { color: #4b5563; font-size: 13px; line-height: 1.6; font-family: 'Consolas', 'Monaco', monospace; background: var(--pl-bg); padding: 10px 12px; border-radius: 6px; white-space: pre-wrap; word-break: break-word; max-height: 120px; overflow: hidden; }
.pl-version-actions { display: flex; gap: 6px; margin-top: 10px; }
.pl-version-actions button { padding: 5px 12px; border-radius: 6px; font-size: 12px; border: 1px solid var(--pl-border); background: #fff; cursor: pointer; color: #374151; display: flex; align-items: center; gap: 4px; transition: var(--pl-transition); }
.pl-version-actions button:hover { background: var(--pl-bg); }
.pl-version-actions button.btn-star { color: var(--pl-amber); border-color: var(--pl-amber); }
.pl-version-actions button.btn-danger { color: var(--pl-error); border-color: #fecaca; }

/* ================================================================
   MODAL — .modal-prompt (unificado para toda la app)
   ================================================================ */
.modal-prompt { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); z-index: 2000; align-items: center; justify-content: center; }
.modal-prompt.active { display: flex; }
.modal-prompt-content { background: #fff; border-radius: var(--pl-radius-lg); padding: 28px; width: 90%; max-width: 540px; max-height: 85vh; overflow-y: auto; box-shadow: var(--pl-shadow-lg); animation: plModalIn 0.25s ease; }
.modal-prompt-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.modal-prompt-header h3 { font-size: 18px; font-weight: 700; margin: 0; display: flex; align-items: center; gap: 8px; }
.modal-prompt-header h3 i { color: var(--pl-amber); }
.btn-close-prompt { background: none; border: none; font-size: 24px; color: var(--pl-text-muted); cursor: pointer; line-height: 1; }
.btn-close-prompt:hover { color: var(--pl-text); }

/* ================================================================
   FORMS — .pl-form-* (auth + modales app)
   ================================================================ */
.pl-form-group { margin-bottom: 16px; }
.pl-form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--pl-text-secondary); margin-bottom: 6px; }
.pl-form-input,
.pl-form-group input,
.pl-form-group select,
.pl-form-group textarea { width: 100%; padding: 10px 14px; border: 1px solid var(--pl-border); border-radius: var(--pl-radius-sm); font-family: 'Roboto', sans-serif; font-size: 14px; color: var(--pl-text); background: #fff; transition: var(--pl-transition); box-sizing: border-box; }
.pl-form-input:focus,
.pl-form-group input:focus,
.pl-form-group select:focus,
.pl-form-group textarea:focus { outline: none; border-color: var(--pl-amber); box-shadow: 0 0 0 3px rgba(var(--pl-amber-rgb), 0.15); }
.pl-form-input::placeholder,
.pl-form-group input::placeholder,
.pl-form-group textarea::placeholder { color: var(--pl-text-muted); }
.pl-form-group textarea { min-height: 120px; resize: vertical; font-family: 'Consolas', 'Monaco', monospace; }
.pl-checkbox-group { display: flex; align-items: center; gap: 8px; margin-bottom: 20px; }
.pl-checkbox-group input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--pl-amber); cursor: pointer; }
.pl-checkbox-group label { font-size: 13px; color: var(--pl-text-secondary); cursor: pointer; margin: 0; }
.pl-modal-actions { display: flex; gap: 10px; margin-top: 20px; }
.pl-modal-actions .btn-pl { flex: 1; justify-content: center; }

/* ================================================================
   TOAST SYSTEM
   ================================================================ */
.pl-toast-container { position: fixed; top: 76px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; }
.pl-toast { padding: 12px 20px; border-radius: var(--pl-radius-sm); font-size: 13px; font-weight: 500; box-shadow: var(--pl-shadow-md); display: flex; align-items: center; gap: 10px; animation: plToastIn 0.3s ease; max-width: 380px; }
.pl-toast.success { background: var(--pl-success-bg); color: #065f46; border: 1px solid #a7f3d0; }
.pl-toast.error { background: var(--pl-error-bg); color: #991b1b; border: 1px solid #fca5a5; }
.pl-toast.warning { background: var(--pl-amber-light); color: #92400e; border: 1px solid #fcd34d; }
.pl-toast.info { background: var(--pl-info-bg); color: #1e40af; border: 1px solid #93c5fd; }
.pl-toast.fadeout { animation: plToastOut 0.3s ease forwards; }

/* ================================================================
   AUTH LAYOUT
   ================================================================ */
body.pl-auth-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: linear-gradient(135deg, var(--pl-navy) 0%, var(--pl-navy-medium) 50%, var(--pl-navy-light) 100%); }
.pl-auth-wrapper { width: 100%; max-width: 440px; padding: 20px; }
.pl-auth-card { background: #fff; border-radius: var(--pl-radius-lg); box-shadow: var(--pl-shadow-lg), 0 0 60px rgba(var(--pl-amber-rgb), 0.08); overflow: hidden; }
.pl-auth-brand { text-align: center; padding: 32px 24px 24px; border-bottom: 1px solid var(--pl-border); }
.pl-auth-brand .brand-icon { width: 56px; height: 56px; background: var(--pl-amber); border-radius: var(--pl-radius-md); display: inline-flex; align-items: center; justify-content: center; font-size: 28px; color: var(--pl-navy); margin-bottom: 12px; }
.pl-auth-brand h1 { font-size: 26px; font-weight: 700; color: var(--pl-navy); }
.pl-auth-brand h1 span { color: var(--pl-amber); }
.pl-auth-brand p { color: var(--pl-text-muted); font-size: 14px; margin: 6px 0 0; }
.pl-auth-body-inner { padding: 28px 32px 32px; }
.pl-auth-error { background: var(--pl-error-bg); color: #991b1b; border: 1px solid #fca5a5; border-radius: var(--pl-radius-sm); padding: 10px 14px; font-size: 13px; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.pl-auth-success { background: #dcfce7; color: #065f46; border: 1px solid #a7f3d0; border-radius: var(--pl-radius-sm); padding: 10px 14px; font-size: 13px; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.pl-auth-footer { text-align: center; padding: 16px; color: rgba(255,255,255,0.35); font-size: 12px; }

/* ================================================================
   ADMIN — Status & icon buttons
   ================================================================ */
.pl-status { display: inline-flex; align-items: center; gap: 5px; padding: 3px 10px; border-radius: 12px; font-size: 12px; font-weight: 600; }
.pl-status-active { background: var(--pl-success-bg); color: #065f46; }
.pl-status-inactive { background: #f3f4f6; color: var(--pl-text-muted); }
.pl-icon-btn { padding: 5px 8px; border-radius: 6px; font-size: 12px; border: 1px solid var(--pl-border); background: #fff; cursor: pointer; color: #374151; transition: var(--pl-transition); }
.pl-icon-btn:hover { background: var(--pl-bg); }
.pl-icon-btn-edit { color: var(--pl-amber); border-color: #fde68a; }
.pl-icon-btn-success { color: var(--pl-success); border-color: #bbf7d0; }
.pl-icon-btn-danger { color: var(--pl-error); border-color: #fecaca; }
.pl-icon-btn-danger:hover { background: var(--pl-error-bg); }
.pl-card-actions { display: flex; gap: 4px; opacity: 0; transition: opacity 0.2s; }
.pl-project-card:hover .pl-card-actions { opacity: 1; }
.pl-actions-group { display: flex; gap: 4px; }

/* ── Contactos (sección completa) ── */
.pl-contacts-list { background: #fff; border-radius: var(--pl-radius); border: 1px solid var(--pl-border); overflow: hidden; }
.pl-contact-row { display: flex; justify-content: space-between; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--pl-border); transition: background var(--pl-transition); }
.pl-contact-row:last-child { border-bottom: none; }
.pl-contact-row:hover { background: var(--pl-bg); }

/* ── Admin: Stats ── */
.pl-admin-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 30px; }
.pl-stat-card { background: #fff; border-radius: var(--pl-radius); padding: 20px; text-align: center; box-shadow: 0 2px 8px rgba(0,0,0,0.06); border: 1px solid var(--pl-border); }
.pl-stat-number { font-size: 32px; font-weight: 700; color: var(--pl-amber); display: block; }
.pl-stat-label { font-size: 13px; color: var(--pl-text-muted); margin-top: 4px; }

/* ── Admin: Tabla ── */
.pl-table-container { background: #fff; border-radius: var(--pl-radius); border: 1px solid var(--pl-border); overflow-x: auto; }
.pl-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.pl-table thead { background: var(--pl-navy); color: #fff; }
.pl-table th { padding: 12px 16px; font-weight: 600; font-size: 13px; text-align: left; white-space: nowrap; }
.pl-table td { padding: 12px 16px; border-bottom: 1px solid var(--pl-border); color: var(--pl-text); }
.pl-table tr:last-child td { border-bottom: none; }
.pl-table tr:hover td { background: var(--pl-bg); }
.pl-table-empty { text-align: center; padding: 40px 16px !important; color: var(--pl-text-muted); }

/* ── Admin: Status badges ── */
.pl-status { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 12px; font-size: 12px; font-weight: 600; }
.pl-status-active { background: #d1fae5; color: #065f46; }
.pl-status-inactive { background: #fee2e2; color: #991b1b; }

/* ── Admin: Plan cards ── */
.pl-plan-card { flex: 1; min-width: 300px; max-width: 440px; border: 2px solid var(--pl-border); border-radius: var(--pl-radius); overflow: hidden; background: #fff; box-shadow: 0 4px 16px rgba(0,0,0,0.06); transition: transform var(--pl-transition); }
.pl-plan-card:hover { transform: translateY(-4px); }
.pl-plan-header { padding: 28px 24px; text-align: center; }

/* ── Auth card (cambiar password, etc.) ── */
.pl-auth-wrapper { max-width: 480px; margin: 40px auto; padding: 0 16px; }
.pl-auth-card { background: var(--pl-card-bg); border-radius: var(--pl-radius-lg); overflow: hidden; box-shadow: var(--pl-shadow-md); border: 1px solid var(--pl-border); }
.pl-auth-header { background: linear-gradient(135deg, var(--pl-amber) 0%, var(--pl-amber-dark) 100%); padding: 24px 30px; text-align: center; }
.pl-auth-header h1 { color: var(--pl-navy); font-size: 22px; font-weight: 700; margin: 0 0 4px; }
.pl-auth-header p { color: var(--pl-navy); opacity: 0.75; font-size: 14px; margin: 0; }
.pl-auth-body { padding: 30px; }
.pl-auth-body .btn-pl { margin-top: 8px; }
.pl-alert { padding: 12px 16px; border-radius: var(--pl-radius-sm); margin-bottom: 20px; font-size: 14px; display: flex; align-items: center; gap: 8px; }
.pl-alert-warning { background: #fffbeb; border: 1px solid #fcd34d; color: #92400e; }
.pl-alert-danger { background: var(--pl-error-bg); border: 1px solid #fecaca; color: var(--pl-error); }
.pl-alert-success { background: var(--pl-success-bg); border: 1px solid #bbf7d0; color: #16a34a; }
.pl-alert-hidden { display: none; }
.pl-help-text { font-size: 12px; color: var(--pl-text-muted); margin-top: 4px; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 1199px) {
    .pl-sidebar { width: var(--sidebar-collapsed); }
    .pl-sidebar .brand-text, .pl-sidebar .pl-nav-section, .pl-sidebar .pl-nav-item span, .pl-sidebar .pl-nav-badge, .pl-sidebar .pl-user-info { display: none; }
    .pl-sidebar .pl-nav-item { justify-content: center; padding: 12px; border-left-width: 0; }
    .pl-sidebar .pl-sidebar-user { justify-content: center; }
    .pl-header { left: var(--sidebar-collapsed); }
    .pl-content { margin-left: var(--sidebar-collapsed); }
}
@media (max-width: 991px) {
    .pl-sidebar { transform: translateX(-100%); width: var(--sidebar-width); z-index: 1100; }
    .pl-sidebar.mobile-open { transform: translateX(0); }
    .pl-sidebar .brand-text, .pl-sidebar .pl-nav-section, .pl-sidebar .pl-nav-item span, .pl-sidebar .pl-nav-badge, .pl-sidebar .pl-user-info { display: unset; }
    .pl-sidebar .pl-nav-item { justify-content: flex-start; padding: 10px 20px; border-left-width: 3px; }
    .pl-sidebar .pl-sidebar-user { justify-content: flex-start; }
    .pl-header { left: 0; }
    .pl-header-toggle { display: block; }
    .pl-content { margin-left: 0; }
    .pl-sidebar-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.4); z-index: 1050; }
    .pl-sidebar-overlay.active { display: block; }
    .pl-projects-grid { grid-template-columns: 1fr; }
    .pl-detail-card { padding: 20px; }
}
@media (max-width: 480px) {
    .pl-auth-wrapper { padding: 12px; }
    .pl-auth-body-inner { padding: 24px 20px 28px; }
}

/* ================================================================
   ANIMATIONS
   ================================================================ */
@keyframes plToastIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
@keyframes plToastOut { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(40px); } }
@keyframes plModalIn { from { opacity: 0; transform: scale(0.95) translateY(-10px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.pl-animate-in { animation: fadeIn 0.3s ease; }
