/* =============================================
   GRADUAPP — CSS SISTEMA COMPLETO
   v3.0 — Tabla, Badges, Modales, Wizard
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

/* =============================================
   VARIABLES GLOBALES
   ============================================= */
:root {
    --ga-gold:           #c6922d;
    --ga-gold-light:     #d9b35b;
    --ga-gold-pale:      rgba(198, 146, 45, 0.10);
    --ga-gold-pale2:     rgba(198, 146, 45, 0.18);
    --ga-gold-shadow:    rgba(198, 146, 45, 0.28);
    --ga-gold-border:    rgba(198, 146, 45, 0.30);
    --ga-dark:           #1a1d23;
    --ga-dark-2:         #2a2f38;
    --ga-dark-border:    #2e323b;
    --ga-surface:        #f4f4f2;
    --ga-surface-card:   #ffffff;
    --ga-surface-subtle: #fafaf8;
    --ga-border:         rgba(0, 0, 0, 0.07);
    --ga-border-md:      rgba(0, 0, 0, 0.13);
    --ga-text-primary:   #1a1d23;
    --ga-text-secondary: #6b7280;
    --ga-text-muted:     #9aa3af;
    --ga-green:          #3b6d11;
    --ga-green-mid:      #5a9e20;
    --ga-green-pale:     #eaf3de;
    --ga-green-border:   #b8d990;
    --ga-red:            #8b2f36;
    --ga-red-pale:       #fde8ea;
    --ga-red-border:     #f0bfc4;
    --ga-radius-xs:      4px;
    --ga-radius-sm:      7px;
    --ga-radius-md:      11px;
    --ga-radius-lg:      15px;
    --ga-transition:     all 0.17s ease;
}

/* =============================================
   TIPOGRAFIA BASE
   ============================================= */
body,
.page-container,
.content-wrapper,
.panel,
table,
.btn,
.modal,
input,
select,
textarea {
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
}

/* =============================================
   FONDO GENERAL
   ============================================= */
body {
    background-color: var(--ga-surface) !important;
}

.page-content {
    background-color: var(--ga-surface) !important;
}

.content-wrapper {
    padding: 20px 24px !important;
}

/* =============================================
   LOGIN
   ============================================= */
body.login-cover    { overflow: hidden; }
.login-cover        { background: none !important; }

body.login-container {
    background: linear-gradient(rgba(255,255,255,0.75), rgba(255,255,255,0.75)),
                url(../images/6942219.jpg) no-repeat center center;
    background-size: cover;
    min-height: 100vh;
}

.login-form { width: 100%; max-width: 430px; }

.login-form .card {
    border: 0;
    border-radius: 22px;
    background: rgba(255,255,255,0.93);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 18px 45px rgba(31,41,55,0.14);
    overflow: hidden;
}

.login-form .card-body  { padding: 38px 34px 32px; }
.login-form h3          { color: #22313f; font-weight: 600; }

.login-form .btn-primary {
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-gold-light));
    border: none;
    color: #fff;
    font-weight: 600;
    border-radius: 10px;
    padding: 12px 16px;
}
.login-form .btn-primary:hover { opacity: .95; }
.login-form .btn-light  { border-radius: 10px; padding: 12px 16px; }

.graduapp-logo          { max-width: 115px; height: auto; margin-bottom: 14px; }
.graduapp-title         { color: #223246; font-weight: 700; font-size: 34px; letter-spacing: -0.5px; }
.graduapp-subtitle      { color: #6b7280; font-size: 15px; line-height: 1.4; }

.login-form .form-group-feedback {
    position: relative;
}

.login-form .form-control {
    height: 52px;
    border-radius: 14px;
    border: 1px solid #d9e1ea;
    background: #fff;
    color: #223246;
    padding-left: 58px !important;
    padding-right: 16px !important;
    font-size: 15px;
    box-shadow: none;
    transition: var(--ga-transition);
}

.login-form .form-control-feedback {
    position: absolute;
    left: 18px;
    top: 0;
    height: 52px;
    width: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #94a3b8;
    z-index: 2;
    pointer-events: none;
}

.login-form .form-control-feedback i {
    font-size: 18px;
}

.login-form .form-control:focus {
    border-color: var(--ga-gold);
    box-shadow: 0 0 0 4px rgba(200,154,61,.13);
}

.login-form .form-control::placeholder { color: #9aa5b1; }
.form-control-feedback { left: 14px; color: #94a3b8; }

.login-links a,
.login-links button,
.login-form a   { font-size: 14px; color: #8a6b2f; }
.login-form a:hover { color: #6f5218; text-decoration: underline; }

.btn-graduapp-light {
    background: #fff;
    border: 1px solid #e2e8f0;
    color: #374151;
    font-weight: 600;
}
.btn-graduapp-light:hover {
    border-color: var(--ga-gold);
    color: #1f2937;
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}

/* =============================================
   NAVBAR
   ============================================= */
.navbar-brand > img     { margin-top: -6px; height: 32px; }

.navbar-inverse {
    background-color: var(--ga-dark) !important;
    border-bottom: 2px solid var(--ga-gold) !important;
}

.navbar-graduapp {
    background: var(--ga-dark);
    border-bottom: 2px solid var(--ga-gold);
}

.navbar-inverse .navbar-nav > li > a {
    color: rgba(255,255,255,0.72) !important;
    font-size: 13px;
    font-weight: 500;
    transition: color 0.15s;
}

.navbar-inverse .navbar-nav > li > a:hover,
.navbar-inverse .navbar-nav > .active > a {
    color: #fff !important;
    background: transparent !important;
}

/* =============================================
   BOTONES GLOBALES
   ============================================= */
.btn-graduapp {
    height: 52px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    color: #fff;
    font-weight: 700;
    font-size: 15px;
    letter-spacing: .2px;
    box-shadow: 0 8px 22px var(--ga-gold-shadow);
    transition: var(--ga-transition);
}

.btn-graduapp:hover,
.btn-graduapp:focus {
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 12px 26px rgba(198,146,45,.38);
}

.btn-graduapp-option {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    border: none;
    color: #fff !important;
    font-weight: 600;
    border-radius: var(--ga-radius-sm);
    padding: 6px 13px;
    font-size: 12px;
    letter-spacing: 0.2px;
    box-shadow: 0 2px 8px var(--ga-gold-shadow);
    transition: var(--ga-transition);
}

.btn-graduapp-option:hover {
    transform: translateY(-1px);
    box-shadow: 0 5px 14px rgba(198,146,45,.40);
    color: #fff !important;
    opacity: 0.94;
}

/* =============================================
   BREADCRUMB
   ============================================= */
.breadcrumb {
    background: transparent;
    padding: 8px 0;
    margin-bottom: 0;
    font-size: 13px;
}

.breadcrumb > li + li::before {
    color: var(--ga-text-muted);
    content: "›";
    font-size: 15px;
    padding: 0 6px;
}

.breadcrumb > .active { color: var(--ga-text-primary); font-weight: 500; }
.breadcrumb a          { color: var(--ga-text-secondary); text-decoration: none; }
.breadcrumb a:hover    { color: var(--ga-gold); }

/* =============================================
   PAGE HEADER
   ============================================= */
.page-header { border-bottom: none; padding: 10px 0; margin: 0; }

.page-header-default {
    background: transparent !important;
    border-bottom: none !important;
    padding: 0 !important;
    margin-bottom: 20px !important;
}

.page-header-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.page-title-qualia h4 {
    font-size: 17px !important;
    font-weight: 600 !important;
    color: var(--ga-text-primary) !important;
    margin: 0 !important;
    display: flex;
    align-items: center;
    gap: 10px;
}

.page-title-qualia h4 i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: var(--ga-radius-md);
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 15px;
}

.heading-btn-group {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.heading-btn-group .btn-default {
    background: #fff;
    border: 1px solid var(--ga-border-md);
    color: var(--ga-text-primary);
    border-radius: var(--ga-radius-sm);
    font-size: 12px;
    font-weight: 500;
    height: 31px;
    padding: 0 12px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    transition: var(--ga-transition);
}

.heading-btn-group .btn-default:hover {
    background: #f5f5f3;
    border-color: #bbb;
}

/* =============================================
   PANELS
   ============================================= */
.panel {
    border: none !important;
    border-radius: var(--ga-radius-lg) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 0 0 1px var(--ga-border) !important;
    background: var(--ga-surface-card) !important;
    margin-bottom: 18px !important;
}

.panel-flat {
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 0 0 1px var(--ga-border) !important;
}

.panel:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.08), 0 0 0 1px var(--ga-border) !important;
    transition: box-shadow 0.2s ease;
}

.panel-heading {
    background: transparent !important;
    border-bottom: 1px solid var(--ga-border) !important;
    padding: 14px 20px !important;
    border-radius: var(--ga-radius-lg) var(--ga-radius-lg) 0 0 !important;
}

.panel-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ga-text-primary) !important;
    margin: 0 !important;
}

.panel-body { padding: 20px !important; }

/* =============================================
   METADATA PROYECTO
   ============================================= */
.panel-body label.text-semibold {
    font-size: 10.5px !important;
    font-weight: 600 !important;
    letter-spacing: 0.7px !important;
    text-transform: uppercase !important;
    color: var(--ga-text-muted) !important;
    display: block;
    margin-bottom: 5px;
}

.panel-body [class*="proyecto-"],
.panel-body .text-size-large {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--ga-text-primary) !important;
}

.panel-body .text-size-large.proyecto-nombre_proyecto {
    font-size: 16px !important;
    font-weight: 600 !important;
}

.panel-body hr {
    border-color: var(--ga-border);
    margin: 18px 0;
}

/* =============================================
   PANEL IMAGENES
   ============================================= */
.graduapp-paneles-imagenes {
    display: flex;
    align-items: stretch;
    gap: 14px;
}

.graduapp-paneles-imagenes > [class*="col-"] {
    display: flex;
    padding-left: 7px;
    padding-right: 7px;
}

.graduapp-paneles-imagenes > [class*="col-"]:first-child { padding-left: 0; }
.graduapp-paneles-imagenes > [class*="col-"]:last-child  { padding-right: 0; }

.graduapp-paneles-imagenes .panel {
    width: 100%;
    min-height: 165px;
    background: var(--ga-surface-subtle) !important;
    border: 1px solid var(--ga-border) !important;
    box-shadow: none !important;
}

.graduapp-paneles-imagenes .panel .panel-body { padding: 16px !important; }

.graduapp-paneles-imagenes h6 {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--ga-text-primary) !important;
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 0 !important;
    margin-bottom: 10px !important;
}

.graduapp-paneles-imagenes h6 i { font-size: 15px; color: var(--ga-gold); }

.imagen-proyecto-estado {
    font-size: 12px;
    color: var(--ga-text-muted) !important;
    margin-bottom: 10px;
}

.imagen-proyecto-estado .label,
.imagen-proyecto-estado span.label {
    background: var(--ga-green-pale) !important;
    color: var(--ga-green) !important;
    border: 1px solid var(--ga-green-border);
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    border-radius: var(--ga-radius-xs) !important;
    padding: 2px 7px !important;
    text-transform: uppercase;
    vertical-align: middle;
}

.proyecto-cuadros_completos {
    font-size: 42px !important;
    font-weight: 700 !important;
    color: var(--ga-text-primary) !important;
    line-height: 1 !important;
    letter-spacing: -1.5px;
}

#optimizar_logo, #optimizar_logo_masivo, #incluir_cuadro_alumno, #profesora_mostrar_etiqueta_id { accent-color: var(--ga-gold);  }

.panel-body .checkbox label {
    font-size: 12px;
    color: var(--ga-text-secondary);
}

/* =============================================
   BADGES — sistema unificado en pill
   ============================================= */

/* Base — pill redondeado */
.ga-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.25px;
    border: 1px solid transparent;
    line-height: 1.5;
    white-space: nowrap;
    vertical-align: middle;
}

.ga-badge i { font-size: 10px; line-height: 1; }

/* Si / Cargada / Activo */
.ga-badge-success {
    background: var(--ga-green-pale);
    color: var(--ga-green);
    border-color: var(--ga-green-border);
}

/* Ajustada (check fuerte) */
.ga-badge-check {
    background: #dff0cd;
    color: #2d5a0e;
    border-color: #a8cf7e;
}

/* No / Sin foto / Error */
.ga-badge-danger {
    background: var(--ga-red-pale);
    color: var(--ga-red);
    border-color: var(--ga-red-border);
}

/* No / Neutral / Sin datos */
.ga-badge-muted {
    background: #f2f2f0;
    color: var(--ga-text-muted);
    border-color: rgba(0,0,0,0.08);
}

/* Advertencia / Pendiente */
.ga-badge-warning {
    background: #fff3d4;
    color: #7a4b00;
    border-color: #f0d080;
}

/* Incluir / Info dorado */
.ga-badge-info {
    background: var(--ga-gold-pale);
    color: #7a5918;
    border-color: var(--ga-gold-border);
}

/* Borrador */
.ga-badge-draft {
    background: #f0f0ee;
    color: var(--ga-text-secondary);
    border-color: rgba(0,0,0,0.10);
}

/* =============================================
   TABLA ALUMNOS
   ============================================= */

/* Barra de búsqueda DataTables */
.dataTables_wrapper .dataTables_filter input {
    height: 34px;
    border: 1px solid var(--ga-border-md);
    border-radius: var(--ga-radius-sm);
    padding: 0 12px 0 34px;
    font-size: 13px;
    color: var(--ga-text-primary);
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none'%3E%3Ccircle cx='6' cy='6' r='4' stroke='%239aa3af' stroke-width='1.3'/%3E%3Cpath d='M9.5 9.5l2.5 2.5' stroke='%239aa3af' stroke-width='1.3' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat 10px center;
    box-shadow: none;
    transition: var(--ga-transition);
    margin-left: 0 !important;
}

.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--ga-gold);
    box-shadow: 0 0 0 3px rgba(198,146,45,.10);
    outline: none;
}

.dataTables_wrapper .dataTables_filter label {
    font-size: 13px;
    font-weight: 500;
    color: var(--ga-text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Info y paginacion */
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
    font-size: 12px;
    color: var(--ga-text-secondary);
    padding: 12px 16px !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: var(--ga-radius-xs) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    padding: 4px 9px !important;
    border: 1px solid var(--ga-border-md) !important;
    background: #fff !important;
    color: var(--ga-text-primary) !important;
    margin: 0 2px !important;
    transition: var(--ga-transition) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--ga-gold-pale) !important;
    border-color: var(--ga-gold-border) !important;
    color: var(--ga-gold) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light)) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 2px 8px var(--ga-gold-shadow);
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover {
    opacity: 0.38 !important;
    cursor: default !important;
    background: #fff !important;
    color: var(--ga-text-muted) !important;
}

/* Tabla base */
.tabla-alumnos {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px !important;
}

.tabla-alumnos thead tr {
    background: var(--ga-surface-subtle) !important;
    border-bottom: 1px solid var(--ga-border-md) !important;
}

.tabla-alumnos thead th {
    padding: 11px 14px !important;
    font-size: 10.5px !important;
    font-weight: 700 !important;
    letter-spacing: 0.65px !important;
    text-transform: uppercase !important;
    color: var(--ga-text-muted) !important;
    background: transparent !important;
    border: none !important;
    white-space: nowrap;
}

.tabla-alumnos tbody td {
    padding: 11px 14px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid var(--ga-border) !important;
    border-top: none !important;
    color: var(--ga-text-primary);
    font-size: 13px;
}

.tabla-alumnos tbody tr:last-child td { border-bottom: none !important; }

.tabla-alumnos tbody tr:hover td {
    background: rgba(198,146,45,0.035) !important;
}

/* Columna ID */
.tabla-alumnos td:first-child {
    color: var(--ga-text-muted);
    font-size: 12px;
    font-weight: 500;
}

/* Columna nombre */
.tabla-alumnos td:nth-child(2) {
    font-weight: 500;
}

/* Botón acciones */
.tabla-alumnos .btn-acciones,
.tabla-alumnos td .btn-xs {
    height: 28px !important;
    padding: 0 10px !important;
    font-size: 11px !important;
    border-radius: var(--ga-radius-sm) !important;
    font-weight: 600 !important;
    background: #fff !important;
    border: 1px solid var(--ga-border-md) !important;
    color: var(--ga-text-secondary) !important;
    transition: var(--ga-transition) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
}

.tabla-alumnos td .btn-xs:hover {
    background: var(--ga-surface) !important;
    border-color: var(--ga-gold-border) !important;
    color: var(--ga-gold) !important;
}

/* =============================================
   PANEL FOOTER — Generar cuadros y pago
   ============================================= */
.btn-proyecto-pago,
.btn-success.btn-proyecto-pago,
.btn-success.btn-confirmar-proyecto-pago {
    background: linear-gradient(135deg, #3b6d11, #639922) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: var(--ga-radius-sm) !important;
    padding: 9px 20px !important;
    font-size: 13px !important;
    box-shadow: 0 3px 10px rgba(59,109,17,0.28) !important;
    transition: var(--ga-transition) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
}

.btn-proyecto-pago:hover,
.btn-success.btn-confirmar-proyecto-pago:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 7px 18px rgba(59,109,17,0.36) !important;
}

/* =============================================
   MODALES — base
   ============================================= */
.modal-content {
    border-radius: var(--ga-radius-lg) !important;
    overflow: hidden;
    border: none !important;
    box-shadow: 0 24px 70px rgba(0,0,0,0.20) !important;
}

.modal-header.graduapp-header {
    background: linear-gradient(135deg, var(--ga-dark), var(--ga-dark-2));
    border-bottom: 2px solid var(--ga-gold);
    padding: 14px 20px !important;
    position: relative;
}

.modal-header.graduapp-header::after {
    content: "";
    position: absolute;
    top: 0; left: 0;
    height: 2px; width: 100%;
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-gold-light));
}

.modal-header.graduapp-header .modal-title {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.4px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.modal-header.graduapp-header .small {
    color: rgba(255,255,255,0.48);
    font-size: 12px;
    margin-top: 2px;
}

.modal-header.graduapp-header .close {
    color: var(--ga-gold);
    opacity: 1;
    text-shadow: none;
    font-size: 20px;
    line-height: 1;
    transition: opacity 0.15s;
}

.modal-header.graduapp-header .close:hover { opacity: 0.70; }

.modal-body {
    background: var(--ga-surface-card);
    padding: 24px !important;
}

.modal-footer {
    background: var(--ga-surface-subtle);
    border-top: 1px solid var(--ga-border);
    padding: 14px 20px !important;
    display: flex;
    align-items: center;
    gap: 8px;
}

.modal-footer .btn-default {
    background: #fff;
    border: 1px solid var(--ga-border-md);
    border-radius: var(--ga-radius-sm);
    color: var(--ga-text-secondary);
    font-size: 13px;
    font-weight: 500;
    padding: 7px 16px;
    transition: var(--ga-transition);
}

.modal-footer .btn-default:hover {
    background: var(--ga-surface);
    border-color: #bbb;
    color: var(--ga-text-primary);
}

.modal-footer .btn-primary {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    border: none;
    font-weight: 600;
    border-radius: var(--ga-radius-sm);
    padding: 8px 20px;
    box-shadow: 0 4px 14px var(--ga-gold-shadow);
    transition: var(--ga-transition);
    color: #fff;
}

.modal-footer .btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 7px 18px rgba(198,146,45,.38);
}

.modal-footer .pull-left { margin-right: auto; }
.modal-footer .pull-right { margin-left: auto; }

/* =============================================
   MODAL PAGO — layout refinado
   ============================================= */

/* Alerta de advertencia */
#modal-content .alert-warning,
.modal-body .alert-warning {
    background: #fff8e6 !important;
    border: 1px solid rgba(198,146,45,0.30) !important;
    border-left: 4px solid var(--ga-gold) !important;
    border-radius: var(--ga-radius-md) !important;
    padding: 14px 18px !important;
    font-size: 13px !important;
    color: #6b4b00 !important;
    margin-bottom: 24px !important;
}

.modal-body .alert-warning strong { color: #a0660a; font-weight: 700; }

/* Separadores */
.modal-body hr {
    border: none;
    border-top: 1px solid var(--ga-border);
    margin: 20px 0;
}

/* Labels en modal de pago */
.modal-body label.text-semibold,
.modal-body label {
    font-size: 10.5px !important;
    font-weight: 700 !important;
    letter-spacing: 0.6px !important;
    text-transform: uppercase !important;
    color: var(--ga-text-muted) !important;
    display: block;
    margin-bottom: 6px;
}

/* Valores del resumen de pago */
.modal-body [class*="pago-"] {
    font-size: 15px;
    font-weight: 600;
    color: var(--ga-text-primary);
    margin-top: 2px;
}

/* Subtotal y Total grandes */
.modal-body .pago-subtotal {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ga-text-primary) !important;
    letter-spacing: -0.5px;
}

.modal-body .pago-total {
    font-size: 26px !important;
    font-weight: 700 !important;
    color: var(--ga-green) !important;
    letter-spacing: -0.8px;
}

/* Input despacho */
#pago-despacho {
    height: 40px;
    border-radius: var(--ga-radius-sm);
    border: 1px solid var(--ga-border-md);
    font-size: 15px;
    font-weight: 600;
    padding: 0 12px;
    color: var(--ga-text-primary);
    transition: var(--ga-transition);
    width: 100%;
    max-width: 200px;
    background: #fff;
}

#pago-despacho:focus {
    border-color: var(--ga-gold);
    box-shadow: 0 0 0 3px rgba(198,146,45,.10);
    outline: none;
}

/* =============================================
   FORMS GENERALES — inputs, textarea, select
   ============================================= */
.form-control {
    border-radius: var(--ga-radius-sm) !important;
    border: 1px solid var(--ga-border-md) !important;
    background: #fff !important;
    color: var(--ga-text-primary) !important;
    font-size: 13px !important;
    height: 38px;
    padding: 0 12px !important;
    box-shadow: none !important;
    transition: var(--ga-transition) !important;
}

textarea.form-control {
    height: auto !important;
    padding: 10px 12px !important;
    line-height: 1.55 !important;
    resize: vertical;
}

.form-control:focus {
    border-color: var(--ga-gold) !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.11) !important;
}

.form-control::placeholder { color: var(--ga-text-muted) !important; }

.help-block {
    font-size: 12px;
    color: var(--ga-text-muted);
    margin-top: 5px;
    line-height: 1.4;
}

.form-group { margin-bottom: 16px; }

.control-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--ga-text-secondary) !important;
    padding-top: 9px !important;
}

/* =============================================
   WIZARD — pasos del modal-proyecto
   ============================================= */
.wizard-steps {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
    position: relative;
}

/* Línea conectora */
.wizard-steps::before {
    content: "";
    position: absolute;
    top: 50%; left: 10%; right: 10%;
    height: 1px;
    background: var(--ga-border-md);
    transform: translateY(-50%);
    z-index: 0;
}

.wizard-step-indicator {
    flex: 1;
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 10px 12px;
    border-radius: var(--ga-radius-md);
    font-size: 12px;
    font-weight: 600;
    background: #fff;
    color: var(--ga-text-muted);
    border: 1.5px solid var(--ga-border-md);
    cursor: pointer;
    transition: var(--ga-transition);
    letter-spacing: 0.1px;
}

.wizard-step-indicator:hover {
    border-color: var(--ga-gold-border);
    color: var(--ga-gold);
}

.wizard-step-indicator.active {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light)) !important;
    color: #fff !important;
    border-color: transparent !important;
    box-shadow: 0 4px 14px var(--ga-gold-shadow);
    transform: translateY(-1px);
}

.wizard-step-indicator.completed {
    background: var(--ga-green-pale);
    color: var(--ga-green);
    border-color: var(--ga-green-border);
}

.wizard-step { display: none; }
.wizard-step.active { display: block; }

/* Botones del footer del wizard */
.btn-wizard-siguiente {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light)) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: var(--ga-radius-sm) !important;
    padding: 7px 22px !important;
    font-size: 13px !important;
    box-shadow: 0 3px 10px var(--ga-gold-shadow) !important;
    transition: var(--ga-transition) !important;
}

.btn-wizard-siguiente:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 16px rgba(198,146,45,.38) !important;
}

.btn-wizard-anterior {
    background: #fff !important;
    border: 1px solid var(--ga-border-md) !important;
    color: var(--ga-text-secondary) !important;
    border-radius: var(--ga-radius-sm) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 7px 16px !important;
    transition: var(--ga-transition) !important;
}

.btn-wizard-anterior:hover {
    background: var(--ga-surface) !important;
    border-color: #bbb !important;
    color: var(--ga-text-primary) !important;
}

.btn-proyecto-guardar {
    background: linear-gradient(135deg, #3b6d11, #639922) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: var(--ga-radius-sm) !important;
    padding: 7px 22px !important;
    font-size: 13px !important;
    box-shadow: 0 3px 10px rgba(59,109,17,0.28) !important;
    transition: var(--ga-transition) !important;
}

.btn-proyecto-guardar:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 16px rgba(59,109,17,0.36) !important;
}

/* =============================================
   TARJETAS DE TAMAÑO (wizard paso 1)
   ============================================= */
.tamano-card {
    border: 2px solid var(--ga-border-md);
    border-radius: var(--ga-radius-md);
    padding: 14px 16px;
    margin-bottom: 10px;
    cursor: pointer;
    background: #fff;
    transition: var(--ga-transition);
    position: relative;
    overflow: hidden;
}

.tamano-card::before {
    content: "";
    position: absolute;
    top: 0; left: 0;
    width: 3px; height: 100%;
    background: transparent;
    transition: var(--ga-transition);
    border-radius: 2px 0 0 2px;
}

.tamano-card:hover {
    border-color: var(--ga-gold-border);
    box-shadow: 0 2px 10px var(--ga-gold-pale2);
}

.tamano-card:hover::before {
    background: var(--ga-gold-light);
}

.tamano-card.active {
    border-color: var(--ga-gold);
    box-shadow: 0 0 0 3px rgba(198,146,45,.14), 0 4px 12px rgba(198,146,45,.10);
}

.tamano-card.active::before {
    background: linear-gradient(180deg, var(--ga-gold), var(--ga-gold-light));
}

.tamano-card .text-semibold {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ga-text-primary) !important;
    margin-bottom: 2px;
}

.tamano-card .text-muted {
    font-size: 12px !important;
    color: var(--ga-text-muted) !important;
}

.tamano-card b         { color: var(--ga-gold); font-weight: 700; }
.tamano-card small     { font-size: 11px !important; color: var(--ga-text-muted) !important; }

/* =============================================
   TARJETAS DE PLANTILLA (wizard paso 3)
   ============================================= */
.plantilla-card {
    border: 2px solid var(--ga-border-md);
    border-radius: var(--ga-radius-md);
    padding: 10px;
    cursor: pointer;
    margin-bottom: 14px;
    background: #fff;
    transition: var(--ga-transition);
    overflow: hidden;
}

.plantilla-card img {
    width: 100%;
    height: 150px;
    object-fit: cover;
    border-radius: var(--ga-radius-sm);
    background: var(--ga-surface);
    display: block;
}

.plantilla-card-title {
    margin-top: 9px;
    font-weight: 600;
    font-size: 13px;
    text-align: center;
    color: var(--ga-text-primary);
}

.plantilla-card:hover {
    border-color: var(--ga-gold-border);
    box-shadow: 0 4px 14px var(--ga-gold-pale2);
    transform: translateY(-2px);
}

.plantilla-card.active {
    border-color: var(--ga-gold);
    box-shadow: 0 0 0 3px rgba(198,146,45,.18), 0 6px 20px rgba(198,146,45,.12);
    transform: translateY(-2px);
}

.plantilla-card .text-muted {
    font-size: 11px !important;
    color: var(--ga-text-muted) !important;
}

.plantilla-card[data-visible="0"] { display: none; }

/* =============================================
   ALERTAS GLOBALES
   ============================================= */
.alert {
    border-radius: var(--ga-radius-md) !important;
    padding: 13px 18px !important;
    font-size: 13px !important;
    font-weight: 500;
    border-width: 1px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.alert-info,
.alert.plantilla-ayuda {
    background: var(--ga-gold-pale) !important;
    border-color: var(--ga-gold-border) !important;
    color: #7a5918 !important;
}

.alert-warning {
    background: #fff8e6 !important;
    border-color: rgba(198,146,45,0.35) !important;
    color: #6b4b00 !important;
}

.alert-warning strong { color: var(--ga-gold); font-weight: 700; }

.alert-success {
    background: var(--ga-green-pale) !important;
    border-color: var(--ga-green-border) !important;
    color: var(--ga-green) !important;
}

.alert-danger {
    background: var(--ga-red-pale) !important;
    border-color: var(--ga-red-border) !important;
    color: var(--ga-red) !important;
}

/* =============================================
   EDITOR DE FOTO
   ============================================= */
#editor-frame-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
}

#editor-frame {
    position: relative;
    overflow: hidden;
    background: #111;
    border: 1.5px solid #333;
    border-radius: var(--ga-radius-md);
}

#editor-img {
    position: absolute;
    left: 0; top: 0;
    max-width: none;
    user-select: none;
    -webkit-user-drag: none;
    cursor: grab;
    transform-origin: top left;
}

#editor-frame.editor-transparencia {
    background-color: #fff;
    background-image:
        linear-gradient(45deg, #ccc 25%, transparent 25%),
        linear-gradient(-45deg, #ccc 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #ccc 75%),
        linear-gradient(-45deg, transparent 75%, #ccc 75%);
    background-size: 24px 24px;
    background-position: 0 0, 0 12px, 12px -12px, -12px 0;
}

/* =============================================
   SWEET ALERT — estilo GraduApp
   ============================================= */
.sweet-overlay {
    background: rgba(26,29,35,0.48) !important;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 30000 !important;
}

.sweet-alert {
    border-radius: var(--ga-radius-lg) !important;
    overflow: hidden !important;
    box-shadow: 0 24px 70px rgba(0,0,0,0.22) !important;
    font-family: 'DM Sans', sans-serif !important;
    z-index: 30001 !important;
    padding: 28px 28px 24px !important;
    border: none !important;
    border-top: 4px solid var(--ga-gold) !important;
}

.sweet-alert h2 {
    margin: 8px 0 12px !important;
    color: var(--ga-text-primary) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
}

.sweet-alert p {
    color: var(--ga-text-secondary) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    padding: 0 !important;
    margin: 0 0 16px !important;
}

.sweet-alert .sa-icon { margin: 10px auto 16px !important; transform: scale(.86); }

.sweet-alert button {
    border-radius: var(--ga-radius-sm) !important;
    padding: 9px 20px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    box-shadow: none !important;
    transition: var(--ga-transition) !important;
}

.sweet-alert button.confirm {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light)) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 14px var(--ga-gold-shadow) !important;
}

.sweet-alert button.confirm:hover { transform: translateY(-1px); opacity: .95; }

.sweet-alert button.cancel {
    background: #fff !important;
    color: var(--ga-text-primary) !important;
    border: 1px solid var(--ga-border-md) !important;
}

.sweet-alert button.cancel:hover { background: var(--ga-surface) !important; }

/* Íconos */
.sweet-alert .sa-icon.sa-success { border-color: var(--ga-green) !important; }
.sweet-alert .sa-icon.sa-success .sa-line { background-color: var(--ga-green) !important; }
.sweet-alert .sa-icon.sa-success .sa-placeholder { border-color: rgba(59,109,17,.25) !important; }
.sweet-alert .sa-icon.sa-error { border-color: #7a1f1f !important; }
.sweet-alert .sa-icon.sa-error .sa-line { background-color: #7a1f1f !important; }
.sweet-alert .sa-icon.sa-warning { border-color: var(--ga-gold) !important; }
.sweet-alert .sa-icon.sa-warning .sa-body,
.sweet-alert .sa-icon.sa-warning .sa-dot { background-color: var(--ga-gold) !important; }
.sweet-alert .sa-icon.sa-info { border-color: var(--ga-gold) !important; }
.sweet-alert .sa-icon.sa-info::before,
.sweet-alert .sa-icon.sa-info::after { background-color: var(--ga-gold) !important; }

/* =============================================
   UTILIDADES
   ============================================= */
.mt-5  { margin-top: 5px !important; }
.mt-10 { margin-top: 10px !important; }
.mt-15 { margin-top: 15px !important; }
.mt-20 { margin-top: 20px !important; }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 768px) {
    .content-wrapper   { padding: 14px !important; }
    .page-header-content { flex-direction: column; align-items: flex-start; }
    .heading-btn-group { flex-wrap: wrap; }
    .graduapp-paneles-imagenes { flex-direction: column; }
    .graduapp-paneles-imagenes > [class*="col-"] { padding: 0 !important; }
    .wizard-steps::before { display: none; }
    .modal-footer { flex-wrap: wrap; }
}

/* =============================================
   Wizard pago — indicadores más respirados
   ============================================= */

.pago-wizard-indicators {
    display: flex;
    align-items: stretch;
    gap: 14px;
    margin: 6px 0 22px;
    padding: 0 2px;
}

.pago-wizard-indicators .pago-step-indicator {
    flex: 1 1 0;
    min-width: 0;
    min-height: 54px;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    padding: 0 18px;
    border-radius: 16px;

    text-align: center;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: -.1px;

    background: #fff;
    border: 1px solid var(--ga-border-md);
    color: var(--ga-text-primary);

    transition: var(--ga-transition);
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}

/* Si el número del paso viene dentro de un span o badge */
.pago-wizard-indicators .pago-step-indicator > span:first-child,
.pago-wizard-indicators .pago-step-indicator .step-number,
.pago-wizard-indicators .pago-step-indicator .wizard-step-number {
    width: 26px;
    height: 26px;
    min-width: 26px;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: 999px;
    background: #eef0f3;
    color: var(--ga-text-muted);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

/* Hover suave */
.pago-wizard-indicators .pago-step-indicator:hover {
    border-color: var(--ga-gold-border);
    color: var(--ga-gold);
    background: #fffdf8;
}

/* Paso activo */
.pago-wizard-indicators .pago-step-indicator.active {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 20px var(--ga-gold-shadow);
}

.pago-wizard-indicators .pago-step-indicator.active > span:first-child,
.pago-wizard-indicators .pago-step-indicator.active .step-number,
.pago-wizard-indicators .pago-step-indicator.active .wizard-step-number {
    background: rgba(255,255,255,.22);
    color: #fff;
}

/* Paso completado, si lo ocupas */
.pago-wizard-indicators .pago-step-indicator.completed {
    background: var(--ga-green-pale);
    border-color: var(--ga-green-border);
    color: var(--ga-green);
}

.pago-wizard-indicators .pago-step-indicator.completed > span:first-child,
.pago-wizard-indicators .pago-step-indicator.completed .step-number,
.pago-wizard-indicators .pago-step-indicator.completed .wizard-step-number {
    background: rgba(59,109,17,.12);
    color: var(--ga-green);
}

/* Responsive */
@media (max-width: 768px) {
    .pago-wizard-indicators {
        gap: 8px;
    }

    .pago-wizard-indicators .pago-step-indicator {
        min-height: 48px;
        padding: 0 10px;
        font-size: 13px;
        gap: 8px;
    }

    .pago-wizard-indicators .pago-step-indicator > span:first-child,
    .pago-wizard-indicators .pago-step-indicator .step-number,
    .pago-wizard-indicators .pago-step-indicator .wizard-step-number {
        width: 22px;
        height: 22px;
        min-width: 22px;
        font-size: 11px;
    }
}

/* --- Footer botones de pago --------------------------- */
#modal-content .ga-pago-footer {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    padding: 16px 24px !important;
    background: var(--ga-surface-subtle) !important;
    border-top: 1px solid var(--ga-border) !important;
}

#modal-content .ga-pago-footer-left,
#modal-content .ga-pago-footer-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

#modal-content .ga-pago-footer-right {
    margin-left: auto;
}

#modal-content .ga-pago-btn {
    height: 42px !important;
    min-width: 150px !important;
    padding: 0 18px !important;
    border-radius: 12px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;

    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    letter-spacing: .2px !important;

    box-shadow: none !important;
    transition: var(--ga-transition) !important;
}

#modal-content .ga-pago-btn i {
    font-size: 13px !important;
    line-height: 1 !important;
}

#modal-content .ga-pago-btn-secondary {
    background: #fff !important;
    border: 1px solid var(--ga-border-md) !important;
    color: var(--ga-text-secondary) !important;
}

#modal-content .ga-pago-btn-secondary:hover {
    background: var(--ga-surface) !important;
    border-color: #bbb !important;
    color: var(--ga-text-primary) !important;
}

#modal-content .ga-pago-btn-primary {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light)) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 5px 14px var(--ga-gold-shadow) !important;
}

#modal-content .ga-pago-btn-primary:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 18px rgba(198,146,45,.38) !important;
}

#modal-content .ga-pago-btn-success {
    background: linear-gradient(135deg, #3b6d11, #5a9e20) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 5px 14px rgba(59,109,17,0.30) !important;
}

#modal-content .ga-pago-btn-success:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 18px rgba(59,109,17,0.38) !important;
}

/* Ocultar/mostrar botón "Ir a Pagar" según lógica JS */
#modal-content .btn-confirmar-proyecto-pago {
    display: none !important;
}

#modal-content.modal-pago-step-3:not(.modal-pago-no-minimo) .btn-confirmar-proyecto-pago {
    display: inline-flex !important;
}

/* En paso 3, si NO cumple mínimo, no tiene sentido mostrar siguiente */
#modal-content.modal-pago-step-3.modal-pago-no-minimo .btn-pago-wizard-siguiente {
    display: none !important;
}

@media (max-width: 768px) {
    #modal-content .ga-pago-footer {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    #modal-content .ga-pago-footer-left,
    #modal-content .ga-pago-footer-right {
        width: 100%;
        justify-content: stretch;
    }

    #modal-content .ga-pago-btn {
        width: 100% !important;
        min-width: 0 !important;
    }
}


#modal-content .btn-success.btn-confirmar-proyecto-pago,
#modal-content .btn-confirmar-proyecto-pago {
    display: none !important;
}

#modal-content.modal-pago-step-3:not(.modal-pago-no-minimo) .btn-success.btn-confirmar-proyecto-pago,
#modal-content.modal-pago-step-3:not(.modal-pago-no-minimo) .btn-confirmar-proyecto-pago {
    display: inline-flex !important;
}

.modal-header.graduapp-header .close {
    position: absolute !important;
    top: 50% !important;
    right: 20px !important;
    transform: translateY(-50%) !important;

    margin: 0 !important;
    opacity: 1 !important;
    color: var(--ga-gold) !important;
    text-shadow: none !important;

    width: 32px;
    height: 32px;
    line-height: 32px !important;
    text-align: center;
    border-radius: 8px;
}

.modal-header.graduapp-header .close:hover {
    background: rgba(255,255,255,0.08);
}

.code-gold {
	color: var(--ga-gold) !important;
}

/* =============================================
   GRADUAPP — HOME PRO
   Agregar al final de assets/css/graduapp.css
   ============================================= */

.ga-home-page .content {
    padding-bottom: 28px;
}

.ga-home-hero {
    position: relative;
    overflow: hidden;
    min-height: 330px;
    border-radius: 24px;
    background:
        radial-gradient(circle at 80% 20%, rgba(217,179,91,.24), transparent 32%),
        linear-gradient(135deg, var(--ga-dark), var(--ga-dark-2));
    box-shadow: 0 18px 45px rgba(26,29,35,.16);
    padding: 34px 38px;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    color: #fff;
}

.ga-home-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
    background-size: 36px 36px;
    mask-image: linear-gradient(90deg, #000, transparent 78%);
    pointer-events: none;
}

.ga-home-hero-bg {
    position: absolute;
    width: 280px;
    height: 280px;
    right: -80px;
    top: -80px;
    border-radius: 50%;
    background: rgba(198,146,45,.22);
    filter: blur(2px);
}

.ga-home-hero-content {
    position: relative;
    z-index: 1;
    max-width: 650px;
}

.ga-home-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(198,146,45,.16);
    border: 1px solid rgba(217,179,91,.32);
    color: var(--ga-gold-light);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .75px;
    text-transform: uppercase;
    margin-bottom: 15px;
}

.ga-home-hero h1 {
    margin: 0 0 12px;
    font-size: 38px;
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -1.2px;
    color: #fff;
}

.ga-home-hero p {
    margin: 0;
    max-width: 610px;
    color: rgba(255,255,255,.72);
    font-size: 15px;
    line-height: 1.65;
}

.ga-home-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.ga-home-main-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 0 22px !important;
}

.ga-home-secondary-btn {
    height: 52px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 14px !important;
    padding: 0 18px !important;
    background: rgba(255,255,255,.96) !important;
    color: var(--ga-text-primary) !important;
    border: 1px solid rgba(255,255,255,.25) !important;
    font-weight: 700 !important;
    box-shadow: 0 8px 22px rgba(0,0,0,.10);
    transition: var(--ga-transition);
}

.ga-home-secondary-btn:hover {
    transform: translateY(-2px);
    color: var(--ga-gold) !important;
}

.ga-home-preview-card {
    position: relative;
    z-index: 1;
    flex: 0 0 255px;
    padding: 13px;
    border-radius: 22px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
    box-shadow: 0 22px 50px rgba(0,0,0,.22);
}

.ga-home-preview-top {
    display: flex;
    gap: 5px;
    margin-bottom: 10px;
}

.ga-home-preview-top span {
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: rgba(255,255,255,.45);
}

.ga-home-preview-frame {
    position: relative;
    min-height: 245px;
    border-radius: 16px;
    background:
        linear-gradient(160deg, rgba(255,255,255,.94), rgba(250,250,248,.82)),
        radial-gradient(circle at 50% 20%, rgba(198,146,45,.20), transparent 36%);
    padding: 16px;
    overflow: hidden;
}

.ga-home-preview-logo {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    box-shadow: 0 7px 18px var(--ga-gold-shadow);
}

.ga-home-preview-title {
    position: absolute;
    top: 22px;
    left: 64px;
    right: 18px;
    height: 13px;
    border-radius: 999px;
    background: rgba(26,29,35,.78);
}

.ga-home-preview-group {
    margin-top: 22px;
    height: 82px;
    border-radius: 15px;
    background: var(--ga-dark);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
    padding: 12px;
}

.ga-home-preview-group span,
.ga-home-preview-grid span {
    border-radius: 999px;
    background: linear-gradient(135deg, #d7d2c4, #f4efe3);
    box-shadow: inset 0 -8px 0 rgba(26,29,35,.12);
}

.ga-home-preview-grid {
    margin-top: 15px;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 7px;
}

.ga-home-preview-grid span {
    aspect-ratio: 1 / 1;
}

.ga-home-preview-badge {
    position: absolute;
    right: -16px;
    bottom: 25px;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 12px;
    border-radius: 999px;
    background: #fff;
    color: var(--ga-green);
    font-size: 12px;
    font-weight: 800;
    box-shadow: 0 12px 28px rgba(0,0,0,.18);
}

.ga-home-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}

.ga-home-metric-card {
    display: flex;
    align-items: center;
    gap: 13px;
    min-height: 94px;
    padding: 18px;
    border-radius: var(--ga-radius-lg);
    background: #fff;
    border: 1px solid var(--ga-border);
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    transition: var(--ga-transition);
}

.ga-home-metric-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(0,0,0,.08);
}

.ga-home-metric-icon {
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    font-size: 19px;
}

.ga-home-metric-icon.gold {
    background: var(--ga-gold-pale);
    color: var(--ga-gold);
    border: 1px solid var(--ga-gold-border);
}

.ga-home-metric-icon.green {
    background: var(--ga-green-pale);
    color: var(--ga-green);
    border: 1px solid var(--ga-green-border);
}

.ga-home-metric-icon.soft {
    background: #f0f0ee;
    color: var(--ga-text-secondary);
    border: 1px solid rgba(0,0,0,.08);
}

.ga-home-metric-icon.warning {
    background: #fff3d4;
    color: #7a4b00;
    border: 1px solid #f0d080;
}

.ga-home-metric-value {
    color: var(--ga-text-primary);
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -1px;
}

.ga-home-metric-label {
    margin-top: 5px;
    color: var(--ga-text-muted);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .45px;
}

.ga-home-grid .panel-heading .panel-title i {
    color: var(--ga-gold);
}

.ga-home-panel-heading-flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.ga-home-flow {
    display: grid;
    gap: 10px;
}

.ga-home-flow-step {
    display: flex;
    gap: 13px;
    padding: 14px;
    border-radius: var(--ga-radius-md);
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    opacity: .72;
}

.ga-home-flow-step.active {
    background: linear-gradient(135deg, rgba(198,146,45,.10), rgba(255,255,255,.96));
    border-color: var(--ga-gold-border);
    opacity: 1;
}

.ga-home-flow-num {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: var(--ga-gold);
    border: 1px solid var(--ga-gold-border);
    font-weight: 800;
}

.ga-home-flow-step h6 {
    margin: 0 0 4px;
    color: var(--ga-text-primary);
    font-weight: 800;
    font-size: 13px;
}

.ga-home-flow-step p {
    margin: 0;
    color: var(--ga-text-secondary);
    font-size: 12px;
    line-height: 1.45;
}

.ga-home-progress-wrap {
    margin-top: 18px;
    padding: 15px;
    border-radius: var(--ga-radius-md);
    background: #fff;
    border: 1px solid var(--ga-border);
}

.ga-home-progress-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 9px;
    color: var(--ga-text-secondary);
    font-size: 12px;
    font-weight: 700;
}

.ga-home-progress-head strong {
    color: var(--ga-gold);
    font-size: 14px;
}

.ga-home-progress-bar {
    height: 9px;
    border-radius: 999px;
    overflow: hidden;
    background: #eee;
}

.ga-home-progress-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-gold-light));
    box-shadow: 0 4px 12px var(--ga-gold-shadow);
}

.ga-home-project-list {
    display: grid;
}

.ga-home-project-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--ga-border);
    color: inherit;
    text-decoration: none !important;
    transition: var(--ga-transition);
}

.ga-home-project-row:hover {
    background: rgba(198,146,45,.045);
}

.ga-home-project-row:last-child {
    border-bottom: 0;
}

.ga-home-project-icon {
    width: 38px;
    height: 38px;
    border-radius: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    color: var(--ga-gold);
    border: 1px solid var(--ga-gold-border);
}

.ga-home-project-main {
    min-width: 0;
    flex: 1;
}

.ga-home-project-main strong {
    display: block;
    color: var(--ga-text-primary);
    font-size: 13px;
    font-weight: 800;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ga-home-project-main span {
    display: block;
    margin-top: 2px;
    color: var(--ga-text-muted);
    font-size: 12px;
}

.ga-home-project-status {
    flex: 0 0 auto;
}

.ga-home-empty-state {
    padding: 34px 20px;
    text-align: center;
}

.ga-home-empty-icon {
    width: 62px;
    height: 62px;
    margin: 0 auto 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 22px;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    font-size: 30px;
}

.ga-home-empty-state h4 {
    margin: 0 0 7px;
    font-weight: 800;
    color: var(--ga-text-primary);
}

.ga-home-empty-state p {
    max-width: 420px;
    margin: 0 auto 15px;
    color: var(--ga-text-secondary);
    font-size: 13px;
    line-height: 1.5;
}

.ga-home-tutorial-card {
    display: flex;
    gap: 12px;
    padding: 14px;
    border-radius: var(--ga-radius-md);
    color: inherit;
    text-decoration: none !important;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    margin-bottom: 10px;
    transition: var(--ga-transition);
}

.ga-home-tutorial-card:hover {
    transform: translateY(-2px);
    border-color: var(--ga-gold-border);
    box-shadow: 0 8px 18px rgba(0,0,0,.07);
}

.ga-home-tutorial-card.featured {
    background: linear-gradient(135deg, rgba(198,146,45,.13), #fff);
    border-color: var(--ga-gold-border);
}

.ga-home-tutorial-icon {
    width: 38px;
    height: 38px;
    flex: 0 0 38px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 1px solid var(--ga-border);
    font-size: 18px;
}

.ga-home-tutorial-card strong {
    display: block;
    color: var(--ga-text-primary);
    font-size: 13px;
    font-weight: 800;
    line-height: 1.25;
}

.ga-home-tutorial-card span {
    display: block;
    margin-top: 4px;
    color: var(--ga-text-secondary);
    font-size: 12px;
    line-height: 1.45;
}

.ga-home-tip-panel {
    background:
        radial-gradient(circle at 100% 0%, rgba(198,146,45,.18), transparent 28%),
        #fff !important;
}

.ga-home-tip-label {
    display: inline-flex;
    padding: 4px 9px;
    border-radius: 999px;
    background: var(--ga-gold-pale);
    color: #7a5918;
    border: 1px solid var(--ga-gold-border);
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .6px;
    margin-bottom: 10px;
}

.ga-home-tip-panel h4 {
    margin: 0 0 9px;
    color: var(--ga-text-primary);
    font-weight: 800;
    line-height: 1.25;
}

.ga-home-tip-panel p,
.ga-home-support-panel p {
    color: var(--ga-text-secondary);
    font-size: 13px;
    line-height: 1.55;
}

.ga-home-inline-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--ga-gold);
    font-weight: 800;
    font-size: 13px;
}

.ga-home-support-panel {
    text-align: center;
}

.ga-home-support-icon {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
    border-radius: 18px;
    background: var(--ga-green-pale);
    color: var(--ga-green);
    border: 1px solid var(--ga-green-border);
    font-size: 21px;
}

.ga-home-support-panel h5 {
    margin: 0 0 8px;
    color: var(--ga-text-primary);
    font-weight: 800;
}

.ga-home-support-panel .ga-home-secondary-btn {
    height: 42px;
    border: 1px solid var(--ga-border-md) !important;
    box-shadow: none;
}

@media (max-width: 1200px) {
    .ga-home-preview-card {
        display: none;
    }

    .ga-home-hero {
        min-height: auto;
    }
}

@media (max-width: 992px) {
    .ga-home-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .ga-home-hero {
        padding: 26px 22px;
        border-radius: 18px;
    }

    .ga-home-hero h1 {
        font-size: 30px;
    }

    .ga-home-actions .btn,
    .ga-home-secondary-btn,
    .ga-home-main-btn {
        width: 100%;
    }

    .ga-home-metrics {
        grid-template-columns: 1fr;
    }

    .ga-home-project-row {
        align-items: flex-start;
    }

    .ga-home-project-status {
        display: none;
    }
}

/* ── Sección título ── */
        .dash-section-title {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: 0.9px;
            text-transform: uppercase;
            color: var(--ga-text-muted);
            margin: 0 0 12px;
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .dash-section-title::after {
            content: '';
            flex: 1;
            height: 1px;
            background: var(--ga-border);
        }

        /* =====================================================
   GraduApp — Stat Cards compactas v3
   Mantiene colores, barra lateral y fondo/acento
   ===================================================== */

.dash-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

.stat-card {
    position: relative;
    overflow: hidden;

    min-height: 88px;
    padding: 14px 18px 14px 24px;

    display: grid;
    grid-template-columns: 74px 70px 1fr;
    align-items: center;
    gap: 14px;

    background: var(--ga-surface-card);
    border: 1px solid var(--ga-border);
    border-radius: var(--ga-radius-lg);
    box-shadow: 0 1px 4px rgba(0,0,0,0.05);
    transition: var(--ga-transition);
}

.stat-card:hover {
    border-color: var(--ga-gold-border);
    box-shadow: 0 4px 18px var(--ga-gold-pale2);
    transform: translateY(-1px);
}

/* Barra lateral dorada por defecto */
.stat-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    bottom: 10px;
    width: 4px;
    border-radius: 0 999px 999px 0;
    background: var(--ga-gold);
    z-index: 2;
}

/* Colores de barra según el ícono/acento existente */
.stat-card:has(.stat-card-icon.green)::before,
.stat-card:has(.stat-card-accent.green)::before {
    background: var(--ga-green);
}

.stat-card:has(.stat-card-icon.red)::before,
.stat-card:has(.stat-card-accent.red)::before {
    background: var(--ga-red);
}

.stat-card:has(.stat-card-icon.dark)::before,
.stat-card:has(.stat-card-accent.dark)::before {
    background: var(--ga-dark);
}

/* Acento superior derecho: se mantiene, pero más elegante */
.stat-card-accent {
    display: block !important;
    position: absolute;
    top: -24px;
    right: -24px;
    width: 92px;
    height: 92px;
    border-radius: 999px;
    background: var(--ga-gold-pale);
    opacity: 0.45;
    pointer-events: none;
}

.stat-card-accent.green {
    background: var(--ga-green-pale);
}

.stat-card-accent.red {
    background: var(--ga-red-pale);
}

.stat-card-accent.dark {
    background: rgba(26,29,35,0.05);
}

/* Ícono grande, pero manteniendo el fondo suave de GraduApp */
.stat-card-icon {
    position: relative;
    z-index: 1;

    width: 58px;
    height: 58px;
    margin: 0;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: 15px;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);

    font-size: 24px;
}

.stat-card-icon.green {
    background: var(--ga-green-pale);
    border-color: var(--ga-green-border);
    color: var(--ga-green-mid);
}

.stat-card-icon.red {
    background: var(--ga-red-pale);
    border-color: var(--ga-red-border);
    color: var(--ga-red);
}

.stat-card-icon.dark {
    background: rgba(26,29,35,0.06);
    border-color: rgba(26,29,35,0.12);
    color: var(--ga-dark);
}

.stat-card-icon i {
    font-size: inherit;
    line-height: 1;
}

/* Número */
.stat-card-value {
    position: relative;
    z-index: 1;

    margin: 0;
    font-size: 29px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -1.2px;
    color: var(--ga-text-primary);
    text-align: center;
}

/* Texto */
.stat-card-label {
    position: relative;
    z-index: 1;

    margin: 0;
    max-width: 125px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.12;
    color: var(--ga-text-primary);
}

/* Responsive */
@media (max-width: 1200px) {
    .stat-card {
        grid-template-columns: 62px 58px 1fr;
        gap: 12px;
        padding: 13px 15px 13px 22px;
    }

    .stat-card-icon {
        width: 52px;
        height: 52px;
        font-size: 22px;
    }

    .stat-card-value {
        font-size: 26px;
    }

    .stat-card-label {
        font-size: 13px;
    }
}

@media (max-width: 992px) {
    .dash-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 576px) {
    .dash-stats-grid {
        grid-template-columns: 1fr;
    }

    .stat-card {
        grid-template-columns: 56px 56px 1fr;
        min-height: 82px;
    }

    .stat-card-icon {
        width: 48px;
        height: 48px;
        font-size: 20px;
    }
}
/* ── Acciones rápidas ── */
        .dash-actions-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 14px;
            margin-bottom: 24px;
        }
        @media (max-width: 768px) { .dash-actions-grid { grid-template-columns: 1fr; } }

        .action-card {
            background: var(--ga-surface-card);
            border-radius: var(--ga-radius-lg);
            border: 1px solid var(--ga-border);
            padding: 22px 22px 20px;
            text-decoration: none;
            display: flex;
            align-items: flex-start;
            gap: 16px;
            transition: var(--ga-transition);
            box-shadow: 0 1px 4px rgba(0,0,0,0.05);
        }
        .action-card:hover {
            border-color: var(--ga-gold-border);
            box-shadow: 0 6px 22px var(--ga-gold-pale2);
            transform: translateY(-2px);
            text-decoration: none;
        }
        .action-card-icon {
            width: 46px; height: 46px;
            border-radius: var(--ga-radius-md);
            background: var(--ga-gold-pale);
            border: 1px solid var(--ga-gold-border);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--ga-gold);
            font-size: 20px;
            flex-shrink: 0;
        }
        .action-card-body h5 {
            font-size: 14px;
            font-weight: 700;
            color: var(--ga-text-primary);
            margin: 0 0 4px;
        }
        .action-card-body p {
            font-size: 12.5px;
            color: var(--ga-text-secondary);
            margin: 0;
            line-height: 1.45;
        }
        .action-card-arrow {
            margin-left: auto;
            color: var(--ga-text-muted);
            font-size: 16px;
            align-self: center;
            flex-shrink: 0;
            transition: var(--ga-transition);
        }
        .action-card:hover .action-card-arrow { color: var(--ga-gold); transform: translateX(3px); }
/* ── Actividad reciente ── */
        .activity-list { list-style: none; padding: 0; margin: 0; }
        .activity-item {
            display: flex;
            align-items: flex-start;
            gap: 12px;
            padding: 12px 0;
            border-bottom: 1px solid var(--ga-border);
        }
        .activity-item:last-child { border-bottom: none; }
        .activity-dot {
            width: 8px; height: 8px;
            border-radius: 50%;
            background: var(--ga-gold);
            margin-top: 5px;
            flex-shrink: 0;
        }
        .activity-dot.green { background: var(--ga-green-mid); }
        .activity-dot.red   { background: var(--ga-red); }
        .activity-text {
            font-size: 13px;
            color: var(--ga-text-primary);
            line-height: 1.4;
        }
        .activity-time {
            font-size: 11px;
            color: var(--ga-text-muted);
            margin-top: 2px;
        }

/* =========================================================
   GraduApp - Birretes saltando con caída más natural
   ========================================================= */

.ga-birrete-rain {
    position: fixed;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 99999;
}

.ga-birrete {
    position: absolute;
    bottom: -70px;
    font-size: 34px;
    opacity: 0;
    animation-name: gaBirreteSalto;
    animation-fill-mode: forwards;
    filter: drop-shadow(0 10px 14px rgba(17, 24, 39, 0.18));
    will-change: transform, opacity;
}

/*
   Variables por birrete:
   --ga-x: desplazamiento horizontal
   --ga-h: altura máxima
   --ga-rot: rotación final
*/

@keyframes gaBirreteSalto {
    0% {
        transform: translate(0, 0) scale(0.75) rotate(0deg);
        opacity: 0;
        animation-timing-function: cubic-bezier(.18,.89,.32,1.28);
    }

    8% {
        opacity: 1;
    }

    /* Subida: esta es la que estaba 10/10 */
    42% {
        transform: translate(var(--ga-x), var(--ga-h)) scale(1.12) rotate(calc(var(--ga-rot) / 2));
        opacity: 1;

        /*
           Desde aquí empieza la caída.
           Esta curva parte lenta y termina muy rápida.
        */
        animation-timing-function: cubic-bezier(.12, .01, 1, .35);
    }

    /* Apenas se mueve al inicio, como cuando llega al punto alto */
    48% {
        transform: translate(
            calc(var(--ga-x) * 1.03),
            calc(var(--ga-h) + 2vh)
        ) scale(1.08) rotate(calc(var(--ga-rot) * 0.56));
        opacity: 1;
        animation-timing-function: cubic-bezier(.05, .02, 1, .45);
    }

    /*
       Caída libre:
       Entre 48% y 100% no hay más frenadas.
       Baja fuerte y desaparece fuera de pantalla.
    */
    100% {
        transform: translate(
            calc(var(--ga-x) * 1.22),
            125vh
        ) scale(0.92) rotate(var(--ga-rot));
        opacity: 0;
    }
}

.ga-home-project-progress-wrap {
    margin-top: 9px;
}

.ga-home-project-progress-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 5px;
    font-size: 11px;
    color: rgba(13, 27, 42, 0.62);
    font-weight: 700;
}

.ga-home-project-progress {
    width: 100%;
    height: 9px;
    background: rgba(13, 27, 42, 0.08);
    border-radius: 999px;
    overflow: hidden;
    position: relative;
}

.ga-home-project-progress-bar {
    display: block;
    height: 100%;
    width: 0;
    min-width: 0;
    border-radius: 999px;
    background: linear-gradient(
        90deg,
        var(--ga-gold, #d89a22),
        var(--ga-gold-soft, #f3c96b)
    );
    transition: width 0.45s ease;
}

.ga-home-project-icon {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: 16px;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff8eb;
    border: 1px solid rgba(216, 154, 34, 0.28);
    color: #d89a22;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
}

.ga-home-project-icon-main {
    font-size: 20px;
    line-height: 1;
}

.ga-home-project-icon-badge {
    position: absolute;
    right: -5px;
    bottom: -5px;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #d89a22;
    color: #fff;
    border: 2px solid #fff;
    box-shadow: 0 4px 10px rgba(0,0,0,.08);
    font-size: 11px;
    line-height: 1;
}

/* Estados */
.ga-home-project-icon.is-borrador {
    background: #fff7ea;
    border-color: rgba(216, 154, 34, 0.30);
    color: #d89a22;
}
.ga-home-project-icon.is-borrador .ga-home-project-icon-badge {
    background: #d89a22;
}

.ga-home-project-icon.is-pendiente {
    background: #fff6ec;
    border-color: rgba(230, 126, 34, 0.28);
    color: #e67e22;
}
.ga-home-project-icon.is-pendiente .ga-home-project-icon-badge {
    background: #e67e22;
}

.ga-home-project-icon.is-aprobado {
    background: #eefaf2;
    border-color: rgba(46, 204, 113, 0.25);
    color: #27ae60;
}
.ga-home-project-icon.is-aprobado .ga-home-project-icon-badge {
    background: #27ae60;
}

.ga-home-project-icon.is-pagado {
    background: #eef6ff;
    border-color: rgba(52, 152, 219, 0.25);
    color: #3498db;
}
.ga-home-project-icon.is-pagado .ga-home-project-icon-badge {
    background: #3498db;
}

.ga-home-project-icon.is-produccion {
    background: #f5f1ff;
    border-color: rgba(142, 68, 173, 0.25);
    color: #8e44ad;
}
.ga-home-project-icon.is-produccion .ga-home-project-icon-badge {
    background: #8e44ad;
}

.ga-home-project-icon.is-finalizado {
    background: #edf9f1;
    border-color: rgba(39, 174, 96, 0.25);
    color: #1f8a4c;
}
.ga-home-project-icon.is-finalizado .ga-home-project-icon-badge {
    background: #1f8a4c;
}

.ga-home-project-icon.is-default {
    background: #f5f5f5;
    border-color: rgba(0,0,0,0.08);
    color: #7f8c8d;
}
.ga-home-project-icon.is-default .ga-home-project-icon-badge {
    background: #95a5a6;
}

.ga-home-hero.ga-home-hero-compact {
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    padding: 15px 20px;
    margin-bottom: 24px;
    min-height: auto;
    background: linear-gradient(90deg, #141b2d 0%, #111827 55%, #1a1a1a 100%);
    border: 1px solid rgba(212, 168, 73, 0.16);
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.18);
}

.ga-home-hero.ga-home-hero-compact .ga-home-hero-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 30px 30px;
    opacity: 0.55;
}

.ga-home-hero.ga-home-hero-compact::before {
    content: "";
    position: absolute;
    right: -80px;
    top: 50%;
    width: 340px;
    height: 340px;
    transform: translateY(-50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(212,168,73,0.28) 0%, rgba(212,168,73,0.10) 38%, rgba(212,168,73,0.00) 72%);
    pointer-events: none;
}

.ga-home-hero-inner {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
}

.ga-home-hero-content {
    max-width: 680px;
}

.ga-home-mini-label {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.62);
    margin-bottom: 8px;
    letter-spacing: 0.2px;
}

.ga-home-hero.ga-home-hero-compact h1 {
    margin: 0 0 8px;
    font-size: 28px;
    line-height: 1.15;
    font-weight: 800;
    color: #ffffff;
}

.ga-home-hero.ga-home-hero-compact p {
    margin: 0;
    max-width: 560px;
    font-size: 15px;
    line-height: 1.35;
    color: rgba(255,255,255,0.72);
}

.ga-home-hero-side {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.ga-home-main-btn {
    min-height: 54px;
    padding: 0 28px;
    border-radius: 16px;
    font-size: 15px;
    font-weight: 700;
    box-shadow: 0 10px 28px rgba(212, 168, 73, 0.28);
}

.ga-home-actions-inline {
    margin-top: 14px;
}

.ga-home-inline-link-main {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 700;
    color: #d7aa46;
    text-decoration: none;
    transition: all 0.15s ease;
}

.ga-home-inline-link-main:hover,
.ga-home-inline-link-main:focus {
    color: #f2c96d;
    text-decoration: none;
}

@media (max-width: 991px) {
    .ga-home-hero.ga-home-hero-compact {
        padding: 24px 22px;
    }

    .ga-home-hero-inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .ga-home-hero-side {
        width: 100%;
        justify-content: flex-start;
    }

    .ga-home-main-btn {
        width: 100%;
        justify-content: center;
    }

    .ga-home-hero.ga-home-hero-compact h1 {
        font-size: 25px;
    }

    .ga-home-hero.ga-home-hero-compact p {
        max-width: 100%;
    }
}

/* =========================================================
   GraduApp Home — Hero compacto refinado
   ========================================================= */

.ga-home-hero.ga-home-hero-compact {
    padding: 26px 34px !important;
}

.ga-home-hero.ga-home-hero-compact .ga-home-hero-inner {
    width: 100%;
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
}

.ga-home-hero.ga-home-hero-compact .ga-home-hero-content {
    flex: 1 1 auto;
    max-width: 680px;
}

.ga-home-hero.ga-home-hero-compact .ga-home-hero-side {
    flex: 0 0 auto;
    margin-left: auto;
    align-self: center;
    display: flex;
    justify-content: flex-end;
    min-width: 220px;
}

/* Botón minimalista específico para la cabecera */
.ga-home-hero-new-btn {
    height: 42px;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;

    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    color: #fff !important;
    border: 1px solid rgba(255,255,255,0.10);

    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.2px;
    text-transform: none;
    text-decoration: none !important;

    box-shadow: 0 8px 20px rgba(198,146,45,0.24);
    transition: all 0.16s ease;
}

.ga-home-hero-new-btn i {
    font-size: 13px;
    line-height: 1;
}

.ga-home-hero-new-btn:hover,
.ga-home-hero-new-btn:focus {
    color: #fff !important;
    text-decoration: none !important;
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(198,146,45,0.32);
}

/* Link secundario más sobrio */
.ga-home-hero.ga-home-hero-compact .ga-home-inline-link-main {
    font-size: 13px;
    font-weight: 800;
    color: var(--ga-gold-light);
}

.ga-home-hero.ga-home-hero-compact .ga-home-actions-inline {
    margin-top: 12px;
}

/* Ajuste responsive */
@media (max-width: 991px) {
    .ga-home-hero.ga-home-hero-compact .ga-home-hero-inner {
        min-height: auto;
        flex-direction: column;
        align-items: flex-start;
    }

    .ga-home-hero.ga-home-hero-compact .ga-home-hero-side {
        width: 100%;
        min-width: 0;
        margin-left: 0;
        justify-content: flex-start;
    }

    .ga-home-hero-new-btn {
        width: auto;
    }
}

@media (max-width: 576px) {
    .ga-home-hero-new-btn {
        width: 100%;
    }
}

.dropdown-menu {
    z-index: 3000;
    border: 0;
    border-radius: 14px;
    padding: 8px;
    min-width: 190px;
    box-shadow: 0 12px 35px rgba(15, 23, 42, 0.16);
}

.dropdown.dropup .dropdown-menu {
    top: auto !important;
    bottom: 100%;
    margin-bottom: 8px;
}

.dropdown-menu > li > a {
    display: flex;
    align-items: center;
    gap: 9px;
    border-radius: 10px;
    padding: 10px 14px;
    font-weight: 600;
    color: #1f2937;
}

.dropdown-menu > li > a:hover {
    background: #f4f7ee;
    color: #3f7d12;
}

/* =========================================================
   GraduApp — Modal alumno refinado
   ========================================================= */

.ga-alumno-modal {
    border-radius: 20px !important;
}

.ga-alumno-modal .modal-header.graduapp-header {
    padding: 18px 24px !important;
}

.ga-alumno-modal .modal-header.graduapp-header .modal-title {
    font-size: 15px;
    letter-spacing: .5px;
}

.ga-alumno-body {
    padding: 24px !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(198,146,45,.08), transparent 28%),
        var(--ga-surface-card) !important;
}

.ga-alumno-layout {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 22px;
    align-items: stretch;
}

.ga-alumno-photo-card,
.ga-alumno-fields-card {
    border: 1px solid var(--ga-border);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.ga-alumno-photo-card {
    padding: 18px;
    background:
        linear-gradient(180deg, rgba(198,146,45,.08), rgba(255,255,255,1) 45%),
        #fff;
    text-align: center;
}

.ga-alumno-photo-title {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin-bottom: 14px;
    color: var(--ga-text-primary);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .55px;
}

.ga-alumno-photo-title i {
    color: var(--ga-gold);
    font-size: 15px;
}

.ga-alumno-photo-preview {
    width: 150px;
    height: 150px;
    margin: 0 auto 15px;
    border-radius: 20px;
    overflow: hidden;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border-md);
    box-shadow: 0 10px 24px rgba(15,23,42,.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ga-alumno-photo-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Estado sin foto */
.ga-alumno-photo-empty {
    width: 100%;
    height: 100%;
    display: flex;
    gap: 7px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--ga-text-muted);
    background:
        radial-gradient(circle at center, rgba(198,146,45,.12), transparent 48%),
        #fafaf8;
}

.ga-alumno-photo-empty i {
    font-size: 34px;
    color: var(--ga-gold);
    opacity: .75;
}

.ga-alumno-photo-empty span {
    font-size: 12px;
    font-weight: 700;
}

.ga-file-upload {
    width: 100%;
    margin: 0;
    cursor: pointer;
}

.ga-file-upload input[type="file"] {
    display: none;
}

.ga-file-upload span {
    width: 100%;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 13px;
    border: 1px solid var(--ga-gold-border);
    background: var(--ga-gold-pale);
    color: #7a5918;
    font-size: 13px;
    font-weight: 800;
    transition: var(--ga-transition);
}

.ga-file-upload:hover span {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    color: #fff;
    box-shadow: 0 8px 20px var(--ga-gold-shadow);
    transform: translateY(-1px);
}

.ga-alumno-photo-help {
    margin-top: 10px;
    color: var(--ga-text-muted);
    font-size: 11.5px;
    line-height: 1.45;
}

.ga-alumno-fields-card {
    padding: 20px 22px;
}

.ga-alumno-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}

.ga-alumno-section-title span {
    color: var(--ga-text-primary);
    font-size: 13px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .65px;
}

.ga-alumno-section-title::after {
    content: "";
    height: 1px;
    flex: 1;
    background: var(--ga-border);
}

.ga-form-field {
    margin-bottom: 16px;
}

.ga-form-field label {
    display: block;
    margin-bottom: 7px;
    color: var(--ga-text-muted) !important;
    font-size: 10.5px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: .7px;
}

.ga-alumno-fields-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.ga-alumno-fields-card .form-control {
    height: 44px !important;
    border-radius: 13px !important;
    font-size: 14px !important;
    font-weight: 500;
}

.ga-alumno-fields-card .form-control:focus {
    border-color: var(--ga-gold) !important;
    box-shadow: 0 0 0 4px rgba(198,146,45,.11) !important;
}

.ga-alumno-fields-card .help-block {
    margin: 6px 0 0;
    font-size: 11.5px;
}

.ga-alumno-include-box {
    margin-top: 4px;
    padding: 14px 15px;
    border-radius: 16px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
}

.ga-switch-row {
    display: flex !important;
    align-items: center;
    gap: 12px;
    margin: 0 !important;
    cursor: pointer;
}

.ga-switch-row input {
    display: none;
}

.ga-switch-ui {
    position: relative;
    width: 42px;
    height: 24px;
    flex: 0 0 42px;
    border-radius: 999px;
    background: #d7dce2;
    transition: var(--ga-transition);
}

.ga-switch-ui::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
    transition: var(--ga-transition);
}

.ga-switch-row input:checked + .ga-switch-ui {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
}

.ga-switch-row input:checked + .ga-switch-ui::after {
    left: 21px;
}

.ga-switch-row strong {
    display: block;
    color: var(--ga-text-primary);
    font-size: 13px;
    font-weight: 800;
}

.ga-switch-row small {
    display: block;
    margin-top: 2px;
    color: var(--ga-text-muted);
    font-size: 11.5px;
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
}

/* Footer más equilibrado para este modal */
.ga-alumno-modal .modal-footer {
    padding: 16px 24px !important;
}

.ga-alumno-modal .modal-footer .btn {
    height: 40px;
    min-width: 120px;
    border-radius: 12px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: .25px;
}

.ga-alumno-modal .modal-footer .btn-primary {
    min-width: 128px;
}

/* Responsive */
@media (max-width: 768px) {
    .ga-alumno-layout {
        grid-template-columns: 1fr;
    }

    .ga-alumno-photo-preview {
        width: 135px;
        height: 135px;
    }

    .ga-alumno-fields-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }
}