/* =============================================
   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);
}

.ga-badge-production {
    background: rgba(198, 146, 45, 0.12);
    color: #8a6418;
    border-color: rgba(198, 146, 45, 0.34);
}

.ga-badge-production i {
    color: #c6922d;
}

/* =============================================
   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;
    align-items: center !important;
    gap: 7px !important;
}

.ga-btn-inline-flex {
    display: inline-flex;
    align-items: center;
    gap: 7px;
}

.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;
  will-change: transform, opacity;
  /* dos animaciones encadenadas */
  animation:
    gaBirreteSubida  var(--ga-dur-up)   var(--ga-delay) cubic-bezier(.2,.8,.3,1.1)  forwards,
    gaBirreteCaida   var(--ga-dur-down) calc(var(--ga-delay) + var(--ga-dur-up)) cubic-bezier(.42,0,1,1) forwards;
}

@keyframes gaBirreteSubida {
  0%   { transform: translate(0,0) scale(0.75) rotate(0deg); opacity: 0; }
  12%  { opacity: 1; }
  100% { transform: translate(var(--ga-x), var(--ga-h)) scale(1.12)
                    rotate(calc(var(--ga-rot)*0.45)); opacity: 1; }
}

@keyframes gaBirreteCaida {
  0%   { transform: translate(var(--ga-x), var(--ga-h)) scale(1.12)
                    rotate(calc(var(--ga-rot)*0.45)); opacity: 1; }
  80%  { opacity: 0.6; }
  100% { transform: translate(calc(var(--ga-x)*1.3), 130vh)
                    scale(0.9) 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;
    }
}


.ga-home-project-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
 
.ga-home-project-icon svg {
    width: 36px;
    height: 36px;
    display: block;
    flex-shrink: 0;
}
 
.ga-home-project-row:hover .ga-home-project-icon {
    transform: scale(1.06);
}
 
/* Borrador — gris neutro */
.ga-home-project-icon.is-borrador {
    background: #f0f0ee;
    color: #8a929f;
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 2px 6px rgba(0,0,0,.06);
}
 
/* Pendiente — ámbar cálido */
.ga-home-project-icon.is-pendiente {
    background: linear-gradient(135deg, #fff3d4 0%, #fde9a8 100%);
    color: #9a6200;
    border: 1px solid rgba(198,146,45,.25);
    box-shadow: 0 2px 8px rgba(198,146,45,.15);
}
 
/* Aprobado — verde suave */
.ga-home-project-icon.is-aprobado {
    background: linear-gradient(135deg, #eaf3de 0%, #d4eab8 100%);
    color: #3b6d11;
    border: 1px solid rgba(59,109,17,.2);
    box-shadow: 0 2px 8px rgba(59,109,17,.12);
}
 
/* Pagado — dorado graduapp */
.ga-home-project-icon.is-pagado {
    background: linear-gradient(135deg, #c6922d 0%, #d9b35b 100%);
    color: #fff;
    border: none;
    box-shadow: 0 4px 12px rgba(198,146,45,.35);
}
 
/* Producción — azul pizarrón / tinta */
.ga-home-project-icon.is-produccion {
    background: linear-gradient(135deg, #1e293b 0%, #2d3d55 100%);
    color: #d9b35b;
    border: none;
    box-shadow: 0 4px 12px rgba(30,41,59,.22);
}
 
/* Finalizado — dorado oscuro premium */
.ga-home-project-icon.is-finalizado {
    background: linear-gradient(135deg, #7a5214 0%, #c6922d 50%, #d9b35b 100%);
    color: #fff;
    border: none;
    box-shadow: 0 4px 14px rgba(198,146,45,.40);
}
 
/* Default / sin estado */
.ga-home-project-icon.is-default {
    background: #f5f5f3;
    color: #c0c4cc;
    border: 1px solid rgba(0,0,0,.07);
    box-shadow: none;
}
 
/* Quitar los estilos del badge circular anterior si existían */
.ga-home-project-icon-main,
.ga-home-project-icon-badge {
    display: none !important;
}

/*MODAL MEJORADO DE CARGAS MASIVAS*/
/* =========================================================
   GraduApp — Modales masivos alumnos/fotos
   ========================================================= */

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

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

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

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

.ga-masivo-side-card {
    padding: 22px 20px;
    background:
        linear-gradient(180deg, rgba(198,146,45,.10), rgba(255,255,255,1) 46%),
        #fff;
}

.ga-masivo-main-card {
    padding: 20px 22px;
}

.ga-masivo-icon {
    width: 58px;
    height: 58px;
    border-radius: 19px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 24px;
    margin-bottom: 16px;
    box-shadow: 0 10px 24px rgba(198,146,45,.10);
}

.ga-masivo-side-card h5 {
    margin: 0 0 8px;
    color: var(--ga-text-primary);
    font-size: 16px;
    font-weight: 900;
    letter-spacing: -.2px;
}

.ga-masivo-side-card p {
    margin: 0 0 16px;
    color: var(--ga-text-secondary);
    font-size: 12.5px;
    line-height: 1.5;
}

.ga-masivo-mini-rules {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.ga-masivo-rule {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 9px 10px;
    border-radius: 13px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 11.8px;
    line-height: 1.35;
}

.ga-masivo-rule i {
    color: var(--ga-green);
    font-size: 12px;
    margin-top: 2px;
}

.ga-masivo-textarea {
    min-height: 265px;
    border-radius: 16px !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
    resize: vertical;
}

.ga-masivo-example-box {
    margin: 14px 0 12px;
    padding: 13px;
    border-radius: 15px;
    background: #fff8e6;
    border: 1px solid var(--ga-gold-border);
}

.ga-masivo-example-box span {
    display: block;
    margin-bottom: 8px;
    color: #7a5918;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .65px;
}

.ga-masivo-example-box code {
    display: block;
    margin-top: 5px;
    padding: 6px 8px;
    border-radius: 9px;
    background: rgba(255,255,255,.75);
    color: #7a5918 !important;
    border: 1px solid rgba(198,146,45,.20);
    font-size: 11.5px;
    white-space: normal;
    word-break: break-word;
}

.ga-masivo-upload-zone {
    position: relative;
    margin-bottom: 18px;
}

.ga-masivo-upload-zone input[type="file"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}

.ga-masivo-upload-visual {
    min-height: 150px;
    border-radius: 18px;
    border: 1.5px dashed var(--ga-gold-border);
    background:
        radial-gradient(circle at center, rgba(198,146,45,.12), transparent 48%),
        var(--ga-surface-subtle);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    text-align: center;
    padding: 20px;
    transition: var(--ga-transition);
}

.ga-masivo-upload-zone:hover .ga-masivo-upload-visual {
    border-color: var(--ga-gold);
    background:
        radial-gradient(circle at center, rgba(198,146,45,.16), transparent 50%),
        #fffdf8;
    box-shadow: 0 8px 22px rgba(198,146,45,.10);
    transform: translateY(-1px);
}

.ga-masivo-upload-icon {
    width: 48px;
    height: 48px;
    border-radius: 17px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 20px;
    margin-bottom: 4px;
}

.ga-masivo-upload-visual strong {
    color: var(--ga-text-primary);
    font-size: 14px;
    font-weight: 900;
}

.ga-masivo-upload-visual span {
    color: var(--ga-text-muted);
    font-size: 12px;
}

.ga-masivo-files-box {
    max-height: 220px;
    overflow: auto;
    padding: 10px;
    border-radius: 16px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
}

.ga-masivo-files-box ul {
    margin: 0 !important;
}

.ga-masivo-files-box li {
    padding: 8px 10px;
    border-radius: 11px;
    background: #fff;
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 12px;
    font-weight: 600;
}

.ga-masivo-files-box li + li {
    margin-top: 6px;
}

/* Footer coherente con modal alumno */
.ga-masivo-modal .modal-footer {
    padding: 16px 24px !important;
}

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

.ga-masivo-modal .modal-footer .btn-primary {
    min-width: 170px;
}

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

    .ga-masivo-side-card,
    .ga-masivo-main-card {
        padding: 18px;
    }

    .ga-masivo-textarea {
        min-height: 220px;
    }

    .ga-masivo-modal .modal-footer {
        flex-wrap: wrap;
    }

    .ga-masivo-modal .modal-footer .btn {
        width: 100%;
    }
}

.ga-home-project-observation-text {
    color: #b98216;
    font-weight: 800;
}

.ga-home-project-icon-observation {
    background: #fff7df;
    border: 1px solid rgba(199, 143, 30, 0.28);
    color: #b98216;
    box-shadow: 0 8px 18px rgba(199, 143, 30, 0.14);
}

.ga-home-project-status .ga-badge-danger {
    background: #fff1f1;
    border-color: #f0b8b8;
    color: #b84242;
}

.ga-home-project-status .ga-badge-danger i {
    margin-right: 4px;
}

/* =========================================================
   GRADUAPP - MODAL TUTORIAL FOTO GRUPAL
========================================================= */

.ga-tutorial-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
}

.ga-tutorial-backdrop {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top left, rgba(199, 145, 35, 0.18), transparent 38%),
        rgba(3, 12, 15, 0.78);
    backdrop-filter: blur(5px);
}

.ga-tutorial-box {
    position: relative;
    width: min(1040px, calc(100vw - 32px));
    max-height: calc(100vh - 32px);
    margin: 16px auto;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.98), rgba(252,248,238,0.98));
    border-radius: 24px;
    box-shadow: 0 24px 70px rgba(0,0,0,0.35);
    overflow: hidden;
    border: 1px solid rgba(199,145,35,0.22);
    animation: gaTutorialIn .22s ease-out;
}

@keyframes gaTutorialIn {
    from {
        opacity: 0;
        transform: translateY(16px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.ga-tutorial-close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: rgba(15, 23, 42, 0.08);
    color: #111827;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 5;
    transition: all .18s ease;
}

.ga-tutorial-close:hover {
    background: rgba(199, 145, 35, 0.18);
    color: #9a6a0a;
}

.ga-tutorial-header {
    padding: 26px 72px 18px 30px;
    background:
        linear-gradient(135deg, #071b22, #0b2a32),
        repeating-linear-gradient(
            45deg,
            rgba(255,255,255,0.02) 0,
            rgba(255,255,255,0.02) 1px,
            transparent 1px,
            transparent 10px
        );
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.ga-tutorial-brand {
    display: flex;
    align-items: center;
    gap: 16px;
}

.ga-tutorial-brand-icon {
    width: 54px;
    height: 54px;
    border-radius: 16px;
    border: 1px solid rgba(245, 181, 45, 0.55);
    background: rgba(245, 181, 45, 0.12);
    color: #f5b52d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
}

.ga-tutorial-header h3 {
    margin: 0;
    color: #fff;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.ga-tutorial-header p {
    margin: 4px 0 0;
    color: rgba(255,255,255,0.72);
    font-size: 14px;
}

.ga-tutorial-counter {
    min-width: 64px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(245, 181, 45, 0.12);
    border: 1px solid rgba(245, 181, 45, 0.4);
    color: #f5b52d;
    font-weight: 800;
    text-align: center;
}

.ga-tutorial-progress {
    height: 5px;
    background: rgba(199, 145, 35, 0.12);
}

.ga-tutorial-progress > div {
    height: 100%;
    width: 14.28%;
    background: linear-gradient(90deg, #c79123, #f5b52d);
    transition: width .22s ease;
}

.ga-tutorial-content {
    padding: 28px 30px 22px;
    min-height: 460px;
}

.ga-tutorial-slide {
    display: none;
}

.ga-tutorial-slide.active {
    display: block;
}

.ga-tutorial-slide-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.35fr;
    gap: 26px;
    align-items: center;
}

.ga-tutorial-text {
    padding: 8px 4px;
}

.ga-tutorial-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 13px;
    border-radius: 999px;
    background: rgba(199, 145, 35, 0.12);
    color: #9a6a0a;
    font-size: 13px;
    font-weight: 800;
    margin-bottom: 16px;
}

.ga-tutorial-tag.success {
    background: rgba(46, 125, 50, 0.11);
    color: #2e7d32;
}

.ga-tutorial-tag.danger {
    background: rgba(170, 45, 45, 0.10);
    color: #a82d2d;
}

.ga-tutorial-text h4 {
    margin: 0 0 12px;
    color: #111827;
    font-size: 28px;
    line-height: 1.15;
    font-weight: 900;
    letter-spacing: -0.035em;
}

.ga-tutorial-text p {
    color: #5f6773;
    font-size: 16px;
    line-height: 1.55;
    margin: 0 0 18px;
}

.ga-tutorial-text ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ga-tutorial-text li {
    position: relative;
    padding-left: 28px;
    color: #303846;
    font-size: 15px;
    margin-bottom: 10px;
}

.ga-tutorial-text li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    width: 19px;
    height: 19px;
    border-radius: 50%;
    background: rgba(199, 145, 35, 0.15);
    color: #c79123;
    font-size: 12px;
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ga-tutorial-image-wrap {
    position: relative;
    border-radius: 22px;
    overflow: hidden;
    background: #071b22;
    border: 1px solid rgba(199, 145, 35, 0.35);
    box-shadow: 0 16px 36px rgba(15,23,42,0.18);
    aspect-ratio: 16 / 9;
}

.ga-tutorial-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    user-select: none;
    pointer-events: none;
}

.ga-tutorial-watermark {
    position: absolute;
    right: 14px;
    bottom: 12px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(3, 12, 15, 0.62);
    color: rgba(255,255,255,0.86);
    font-size: 12px;
    font-weight: 700;
}

.ga-tutorial-final-card {
    min-height: 320px;
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(245,181,45,0.25), transparent 40%),
        linear-gradient(135deg, #071b22, #0c3038);
    color: #fff;
    border: 1px solid rgba(245,181,45,0.36);
    box-shadow: 0 16px 36px rgba(15,23,42,0.22);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 34px;
    text-align: center;
}

.ga-tutorial-final-card i {
    font-size: 54px;
    color: #f5b52d;
    margin-bottom: 18px;
}

.ga-tutorial-final-card h4 {
    color: #fff;
    font-size: 28px;
    font-weight: 900;
    margin: 0 0 10px;
}

.ga-tutorial-final-card p {
    color: rgba(255,255,255,0.75);
    margin: 0;
    font-size: 16px;
}

.ga-tutorial-footer {
    padding: 18px 30px 26px;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    border-top: 1px solid rgba(15,23,42,0.07);
}

.ga-tutorial-btn {
    border: 0;
    border-radius: 999px;
    min-height: 44px;
    padding: 0 20px;
    font-size: 14px;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    cursor: pointer;
    transition: all .18s ease;
}

.ga-tutorial-btn.primary {
    color: #fff;
    background: linear-gradient(135deg, #c79123, #f5b52d);
    box-shadow: 0 8px 20px rgba(199,145,35,0.28);
}

.ga-tutorial-btn.primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 26px rgba(199,145,35,0.34);
}

.ga-tutorial-btn.secondary {
    color: #1f2937;
    background: #fff;
    border: 1px solid rgba(15,23,42,0.12);
}

.ga-tutorial-btn.secondary:hover {
    background: #faf7ef;
    border-color: rgba(199,145,35,0.32);
}

.ga-tutorial-btn:disabled {
    opacity: .42;
    cursor: not-allowed;
    transform: none !important;
    box-shadow: none !important;
}

@media (max-width: 820px) {
    .ga-tutorial-box {
        width: calc(100vw - 20px);
        margin: 10px auto;
        max-height: calc(100vh - 20px);
        overflow-y: auto;
    }

    .ga-tutorial-header {
        padding: 22px 62px 16px 20px;
        align-items: flex-start;
    }

    .ga-tutorial-brand-icon {
        width: 46px;
        height: 46px;
        font-size: 20px;
    }

    .ga-tutorial-header h3 {
        font-size: 18px;
    }

    .ga-tutorial-header p {
        font-size: 13px;
    }

    .ga-tutorial-counter {
        display: none;
    }

    .ga-tutorial-content {
        padding: 22px 20px;
        min-height: auto;
    }

    .ga-tutorial-slide-grid {
        grid-template-columns: 1fr;
    }

    .ga-tutorial-text h4 {
        font-size: 23px;
    }

    .ga-tutorial-footer {
        padding: 16px 20px 22px;
    }

    .ga-tutorial-btn {
        flex: 1;
        padding: 0 14px;
    }
}

body.ga-modal-open {
    overflow: hidden;
}

.ga-tutorial-brand-icon .icon-user {
    transform: translateY(1px);
}

/* =========================================================
   GRADUAPP - TUTORIAL LOGO COLEGIO
========================================================= */

.ga-tutorial-logo-preview,
.ga-logo-comparison,
.ga-logo-cleaner-card,
.ga-logo-quality-card,
.ga-logo-mistakes-grid {
    min-height: 330px;
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(245,181,45,0.16), transparent 42%),
        #fff;
    border: 1px solid rgba(199,145,35,0.22);
    box-shadow: 0 16px 36px rgba(15,23,42,0.12);
    padding: 26px;
}

.ga-tutorial-logo-preview {
    display: flex;
    align-items: center;
    justify-content: center;
}

.ga-logo-good-card {
    width: min(360px, 100%);
    min-height: 260px;
    border-radius: 24px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.95), rgba(250,247,239,0.95));
    border: 1px solid rgba(46,125,50,0.18);
    box-shadow: 0 14px 30px rgba(15,23,42,0.12);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    position: relative;
}

.ga-logo-check {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #2e7d32;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ga-logo-sample,
.ga-logo-transparent-bg,
.ga-logo-white-bg {
    width: 120px;
    height: 120px;
    border-radius: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 54px;
    color: #071b22;
}

.ga-logo-sample,
.ga-logo-transparent-bg {
    background-color: #fff;
    background-image:
        linear-gradient(45deg, rgba(15,23,42,0.06) 25%, transparent 25%),
        linear-gradient(-45deg, rgba(15,23,42,0.06) 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, rgba(15,23,42,0.06) 75%),
        linear-gradient(-45deg, transparent 75%, rgba(15,23,42,0.06) 75%);
    background-size: 18px 18px;
    background-position: 0 0, 0 9px, 9px -9px, -9px 0;
    border: 1px dashed rgba(15,23,42,0.18);
}

.ga-logo-white-bg {
    background: #fff;
    border: 1px solid rgba(15,23,42,0.12);
    box-shadow: inset 0 0 0 10px rgba(15,23,42,0.025);
}

.ga-logo-good-card h5 {
    margin: 8px 0 0;
    font-size: 22px;
    font-weight: 900;
    color: #111827;
}

.ga-logo-good-card p {
    margin: 0;
    font-size: 14px;
    color: #6b7280;
}

.ga-logo-comparison {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    align-items: stretch;
}

.ga-logo-example {
    border-radius: 22px;
    background: #fff;
    border: 1px solid rgba(15,23,42,0.08);
    padding: 22px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-align: center;
}

.ga-logo-example.good {
    border-color: rgba(46,125,50,0.25);
    background: rgba(46,125,50,0.035);
}

.ga-logo-example.bad {
    border-color: rgba(170,45,45,0.22);
    background: rgba(170,45,45,0.035);
}

.ga-logo-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
}

.ga-logo-example.good .ga-logo-status {
    background: rgba(46,125,50,0.12);
    color: #2e7d32;
}

.ga-logo-example.bad .ga-logo-status {
    background: rgba(170,45,45,0.10);
    color: #a82d2d;
}

.ga-logo-example strong {
    color: #111827;
    font-size: 17px;
    font-weight: 900;
}

.ga-logo-example small {
    color: #6b7280;
    font-size: 13px;
}

.ga-logo-cleaner-card {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 18px;
    align-items: center;
}

.ga-logo-cleaner-before,
.ga-logo-cleaner-after {
    border-radius: 22px;
    background: #fff;
    border: 1px solid rgba(15,23,42,0.08);
    min-height: 230px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
}

.ga-logo-cleaner-before span,
.ga-logo-cleaner-after span {
    font-weight: 900;
    color: #111827;
}

.ga-logo-cleaner-arrow {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: linear-gradient(135deg, #c79123, #f5b52d);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 22px rgba(199,145,35,0.28);
}

.ga-logo-quality-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    align-content: center;
}

.ga-logo-quality-item {
    border-radius: 20px;
    padding: 22px;
    display: grid;
    grid-template-columns: 42px 1fr;
    column-gap: 14px;
    row-gap: 4px;
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15,23,42,0.08);
}

.ga-logo-quality-item i {
    grid-row: span 2;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.ga-logo-quality-item.good i {
    background: #2e7d32;
}

.ga-logo-quality-item.bad i {
    background: #a82d2d;
}

.ga-logo-quality-item strong {
    font-size: 18px;
    font-weight: 900;
    color: #111827;
}

.ga-logo-quality-item span {
    font-size: 14px;
    color: #6b7280;
}

.ga-logo-mistakes-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
}

.ga-logo-mistake {
    border-radius: 20px;
    background: rgba(170,45,45,0.055);
    border: 1px solid rgba(170,45,45,0.18);
    min-height: 130px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-align: center;
}

.ga-logo-mistake i {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #a82d2d;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ga-logo-mistake strong {
    color: #7f1d1d;
    font-size: 15px;
    font-weight: 900;
}

@media (max-width: 820px) {
    .ga-logo-comparison,
    .ga-logo-cleaner-card {
        grid-template-columns: 1fr;
    }

    .ga-logo-cleaner-arrow {
        transform: rotate(90deg);
        justify-self: center;
    }

    .ga-logo-mistakes-grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   GraduApp — Modal editor de foto sin scroll
   ========================================================= */

body.ga-editor-open {
    overflow: hidden !important;
}

.ga-editor-modal-root {
    overflow: hidden !important;
}

.ga-editor-modal-root .modal-dialog.ga-editor-dialog {
    width: min(1120px, calc(100vw - 36px));
    max-width: 1120px;
    margin: 18px auto !important;
}

.ga-editor-modal {
    height: calc(100vh - 36px);
    max-height: calc(100vh - 36px);
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
    border-radius: 20px !important;
}

.ga-editor-header {
    flex: 0 0 auto;
}

.ga-editor-header .modal-title {
    font-size: 15px !important;
}

.ga-editor-header-subtitle {
    margin-top: 4px;
    padding-left: 26px;
    color: rgba(255,255,255,.56);
    font-size: 12px;
    line-height: 1.35;
}

.ga-editor-body {
    flex: 1 1 auto;
    min-height: 0;
    padding: 18px !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(198,146,45,.08), transparent 30%),
        var(--ga-surface-card) !important;
}

.ga-editor-layout {
    height: 100%;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 18px;
}

.ga-editor-preview-card,
.ga-editor-side-card {
    min-height: 0;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--ga-border);
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
    overflow: hidden;
}

.ga-editor-preview-card {
    display: flex;
    flex-direction: column;
    padding: 14px;
    background:
        linear-gradient(180deg, rgba(198,146,45,.07), rgba(255,255,255,1) 42%),
        #fff;
}

.ga-editor-stage {
    flex: 1 1 auto;
    min-height: 0;
    border-radius: 16px;
    background:
        radial-gradient(circle at center, rgba(198,146,45,.10), transparent 45%),
        linear-gradient(135deg, #151515 0%, #282828 100%);
    border: 1px solid rgba(198,146,45,.26);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 14px;
}

.ga-editor-stage #editor-frame-wrap {
    width: 100%;
    height: 100%;
}

.ga-editor-stage #editor-frame {
    box-shadow: 0 18px 44px rgba(0,0,0,.32);
    border: 2px solid rgba(255,255,255,.85);
    border-radius: 16px;
}

.ga-editor-photo-caption {
    flex: 0 0 auto;
    margin-top: 12px;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    border-radius: 14px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 12.5px;
    font-weight: 700;
}

.ga-editor-photo-caption i {
    color: var(--ga-gold);
}

.ga-editor-side-card {
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    background:
        radial-gradient(circle at top right, rgba(198,146,45,.12), transparent 40%),
        #fff;
}

.ga-editor-side-head {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding-bottom: 13px;
    border-bottom: 1px solid var(--ga-border);
}

.ga-editor-side-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 18px;
}

.ga-editor-side-head h6 {
    margin: 0 0 4px !important;
    color: var(--ga-text-primary) !important;
    font-size: 14px !important;
    font-weight: 900 !important;
}

.ga-editor-side-head p {
    margin: 0;
    color: var(--ga-text-secondary);
    font-size: 12px;
    line-height: 1.4;
}

.ga-editor-controls-box {
    padding: 14px;
    border-radius: 16px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
}

.ga-editor-controls-box label {
    display: block;
    margin-bottom: 10px;
    color: var(--ga-text-muted) !important;
    font-size: 10.5px !important;
    font-weight: 900 !important;
    letter-spacing: .7px;
    text-transform: uppercase;
}

.ga-editor-zoom-actions {
    display: grid;
    grid-template-columns: 46px 1fr 46px;
    gap: 8px;
}

.ga-editor-zoom-btn,
.ga-editor-reset-btn {
    height: 42px;
    border: 0;
    border-radius: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: var(--ga-transition);
    font-weight: 900;
}

.ga-editor-zoom-btn {
    background: #fff;
    border: 1px solid var(--ga-border-md);
    color: var(--ga-text-primary);
    font-size: 15px;
}

.ga-editor-zoom-btn:hover {
    background: var(--ga-gold-pale);
    border-color: var(--ga-gold-border);
    color: var(--ga-gold);
    transform: translateY(-1px);
}

.ga-editor-reset-btn {
    gap: 7px;
    background: linear-gradient(135deg, var(--ga-dark), var(--ga-dark-2));
    color: #fff;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .25px;
    border: 1px solid rgba(198,146,45,.30);
}

.ga-editor-reset-btn i {
    color: var(--ga-gold);
}

.ga-editor-reset-btn:hover {
    color: #fff;
    filter: brightness(1.05);
    transform: translateY(-1px);
}

.ga-editor-help-list {
    display: grid;
    gap: 9px;
}

.ga-editor-help-item {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    padding: 11px;
    border-radius: 14px;
    background: #fff;
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 12px;
    line-height: 1.35;
}

.ga-editor-help-item i {
    color: var(--ga-green);
    margin-top: 2px;
    font-size: 12px;
}

.ga-editor-warning {
    margin-top: auto;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    padding: 12px;
    border-radius: 15px;
    background: #fff8e6;
    border: 1px solid var(--ga-gold-border);
    color: #7a5918;
    font-size: 12px;
    line-height: 1.35;
}

.ga-editor-warning i {
    color: var(--ga-gold);
    margin-top: 2px;
}

.ga-editor-footer {
    flex: 0 0 auto;
    justify-content: flex-end;
}

.ga-editor-footer .btn {
    height: 40px;
    min-width: 130px;
    border-radius: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase;
    letter-spacing: .25px;
}

.ga-editor-btn-primary {
    min-width: 165px !important;
}

@media (max-width: 991px) {
    .ga-editor-modal-root .modal-dialog.ga-editor-dialog {
        width: calc(100vw - 20px);
        margin: 10px auto !important;
    }

    .ga-editor-modal {
        height: calc(100vh - 20px);
        max-height: calc(100vh - 20px);
    }

    .ga-editor-layout {
        grid-template-columns: 1fr;
        grid-template-rows: minmax(0, 1fr) auto;
    }

    .ga-editor-side-card {
        max-height: 230px;
    }

    .ga-editor-help-list,
    .ga-editor-warning {
        display: none;
    }
}

/* =========================================================
   GraduApp — Overlay de plantilla sobre foto individual
   ========================================================= */

.ga-editor-layout-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    pointer-events: none;
    display: none;
}

.ga-editor-layout-overlay.is-active {
    display: block;
}

.ga-editor-overlay-box {
    position: absolute;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.58);
    border: 1px solid rgba(255, 255, 255, 0.42);
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.03);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 4px;
    color: rgba(255,255,255,.96);
    font-size: 10px;
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: .35px;
    text-transform: uppercase;
    text-shadow: 0 1px 3px rgba(0,0,0,.28);
}

.ga-editor-overlay-box.is-logo {
    background: rgba(255,255,255,.52);
}

.ga-editor-overlay-box.is-title,
.ga-editor-overlay-box.is-profesora {
    background: rgba(255,255,255,.48);
}

.ga-editor-overlay-box.is-lista {
    background: rgba(255,255,255,.55);
}

.ga-editor-overlay-box.is-grupal {
    background: rgba(255,255,255,.48);
}

.ga-editor-overlay-box span {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ga-editor-overlay-hint {
    position: absolute;
    left: 12px;
    bottom: 12px;
    max-width: calc(100% - 24px);
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(15, 15, 15, 0.58);
    color: rgba(255,255,255,.86);
    font-size: 11px;
    font-weight: 800;
    backdrop-filter: blur(4px);
}

.ga-editor-preview-card.has-layout-overlay .ga-editor-photo-caption {
    background: #fff8e6;
    border-color: var(--ga-gold-border);
    color: #7a5918;
}

.ga-editor-preview-card.has-layout-overlay .ga-editor-photo-caption i {
    color: var(--ga-gold);
}

#editor-frame {
    position: relative;
}

#editor-img {
    z-index: 2;
}

.ga-editor-layout-overlay {
    z-index: 5;
}

/* =========================================================
   GraduApp — Navbar navegación principal
   ========================================================= */

.navbar-graduapp {
    min-height: 64px;
}

.navbar-graduapp .navbar-header {
    min-height: 64px;
}

.navbar-graduapp .navbar-brand {
    height: 64px;
    padding-top: 15px;
    padding-bottom: 15px;
}

.navbar-graduapp .navbar-brand > img {
    margin-top: 0;
    height: 34px;
}

.ga-navbar-menu {
    margin-left: 18px;
}

.ga-navbar-menu > li > a {
    height: 64px;
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    padding: 0 15px !important;
    color: rgba(255,255,255,0.66) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    letter-spacing: .15px;
    position: relative;
}

.ga-navbar-menu > li > a i {
    color: rgba(217,179,91,0.72);
    font-size: 15px;
}

.ga-navbar-menu > li > a:hover {
    color: #fff !important;
    background: rgba(255,255,255,0.035) !important;
}

.ga-navbar-menu > li.active > a {
    color: #fff !important;
    background: rgba(198,146,45,0.10) !important;
}

.ga-navbar-menu > li.active > a::after {
    content: "";
    position: absolute;
    left: 15px;
    right: 15px;
    bottom: 0;
    height: 3px;
    border-radius: 999px 999px 0 0;
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-gold-light));
}

.navbar-graduapp .navbar-right > li > a {
    height: 64px;
    display: flex !important;
    align-items: center;
}

.navbar-graduapp .dropdown-user > a img {
    width: 38px;
    height: 38px;
    margin-top: 0;
}

.navbar-graduapp .dropdown-user > a span {
    color: rgba(255,255,255,0.72) !important;
    font-weight: 700;
}

.navbar-graduapp .dropdown-user > a .caret {
    color: rgba(255,255,255,0.55) !important;
}

.ga-navbar-mobile-toggle {
    height: 64px !important;
    display: flex !important;
    align-items: center;
    color: var(--ga-gold-light) !important;
}

.ga-navbar-menu > li.dropdown.open > a,
.ga-navbar-menu > li.dropdown > a:focus {
    color: #fff !important;
    background: rgba(198,146,45,0.10) !important;
}

.ga-navbar-admin-dropdown {
    min-width: 260px;
    margin-top: 0 !important;
    padding: 8px 0;
    border: 1px solid rgba(217,177,93,0.18);
    border-radius: 14px;
    background: #141922;
    box-shadow: 0 16px 38px rgba(0,0,0,0.28);
    overflow: hidden;
}

.ga-navbar-admin-dropdown > li > a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 16px;
    color: rgba(255,255,255,0.84);
    font-size: 13px;
    font-weight: 700;
    transition: var(--ga-transition);
}

.ga-navbar-admin-dropdown > li > a i {
    color: var(--ga-gold-light);
    font-size: 15px;
    min-width: 16px;
}

.ga-navbar-admin-dropdown > li > a:hover,
.ga-navbar-admin-dropdown > li.active > a {
    background: rgba(217,177,93,0.10) !important;
    color: #fff !important;
}

@media (max-width: 768px) {
    .ga-navbar-menu {
        margin-left: 0;
        padding: 8px 0;
        border-top: 1px solid rgba(255,255,255,0.06);
    }

    .ga-navbar-menu > li > a {
        height: 44px;
        width: 100%;
        padding: 0 20px !important;
    }

    .ga-navbar-menu > li.active > a::after {
        display: none;
    }

    .ga-navbar-menu > li.active > a {
        border-left: 3px solid var(--ga-gold);
    }
}

/* =========================================================
   GraduApp — Modal editar proyecto refinado
   ========================================================= */

.ga-proyecto-editar-dialog {
    width: min(980px, calc(100vw - 34px));
    max-width: 980px;
    margin: 24px auto;
}

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

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

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

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

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

.ga-proyecto-editar-side-card,
.ga-proyecto-editar-main-card {
    border: 1px solid var(--ga-border);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.ga-proyecto-editar-side-card {
    padding: 22px 20px;
    background:
        linear-gradient(180deg, rgba(198,146,45,.10), rgba(255,255,255,1) 46%),
        #fff;
}

.ga-proyecto-editar-main-card {
    padding: 20px 22px;
}

.ga-proyecto-editar-icon {
    width: 58px;
    height: 58px;
    border-radius: 19px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 24px;
    margin-bottom: 16px;
    box-shadow: 0 10px 24px rgba(198,146,45,.10);
}

.ga-proyecto-editar-side-card h5 {
    margin: 0 0 8px;
    color: var(--ga-text-primary);
    font-size: 16px;
    font-weight: 900;
    letter-spacing: -.2px;
}

.ga-proyecto-editar-side-card p {
    margin: 0 0 16px;
    color: var(--ga-text-secondary);
    font-size: 12.5px;
    line-height: 1.5;
}

.ga-proyecto-editar-mini-rules {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.ga-proyecto-editar-rule {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 9px 10px;
    border-radius: 13px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 11.8px;
    line-height: 1.35;
}

.ga-proyecto-editar-rule i {
    color: var(--ga-green);
    font-size: 12px;
    margin-top: 2px;
}

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

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

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

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

.ga-proyecto-editar-grid .span-2 {
    grid-column: span 2;
}

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

.ga-proyecto-editar-main-card textarea.form-control {
    height: auto !important;
    min-height: 92px;
    line-height: 1.5 !important;
}

.ga-proyecto-editar-main-card .help-block {
    margin: 6px 0 0;
    font-size: 11.5px;
}

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

.ga-proyecto-editar-footer {
    padding: 16px 24px !important;
}

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

.ga-proyecto-editar-footer .btn-primary {
    min-width: 128px;
}

/* =========================================================
   GraduApp — Modal preview cuadro refinado
   ========================================================= */

.ga-preview-modal-root .ga-preview-dialog {
    width: min(1080px, calc(100vw - 34px)) !important;
    max-width: 1080px !important;
    margin: 24px auto;
}

.ga-preview-modal {
    border-radius: 20px !important;
    max-height: calc(100vh - 48px);
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
}

.ga-preview-header {
    flex: 0 0 auto;
    padding: 18px 24px !important;
}

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

.ga-preview-body {
    flex: 1 1 auto;
    min-height: 0;
    padding: 24px !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(198,146,45,.08), transparent 30%),
        var(--ga-surface-card) !important;
}

.ga-preview-layout {
    height: 100%;
    min-height: 0;
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 22px;
    align-items: stretch;
}

.ga-preview-side-card,
.ga-preview-main-card {
    min-height: 0;
    border: 1px solid var(--ga-border);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.ga-preview-side-card {
    padding: 22px 20px;
    background:
        linear-gradient(180deg, rgba(198,146,45,.10), rgba(255,255,255,1) 46%),
        #fff;
}

.ga-preview-main-card {
    padding: 18px;
    display: flex;
    flex-direction: column;
}

.ga-preview-side-icon {
    width: 58px;
    height: 58px;
    border-radius: 19px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 24px;
    margin-bottom: 16px;
    box-shadow: 0 10px 24px rgba(198,146,45,.10);
}

.ga-preview-side-card h5 {
    margin: 0 0 8px;
    color: var(--ga-text-primary);
    font-size: 16px;
    font-weight: 900;
    letter-spacing: -.2px;
}

.ga-preview-side-card p {
    margin: 0 0 16px;
    color: var(--ga-text-secondary);
    font-size: 12.5px;
    line-height: 1.5;
}

.ga-preview-mini-rules {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.ga-preview-rule {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 9px 10px;
    border-radius: 13px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 11.8px;
    line-height: 1.35;
}

.ga-preview-rule i {
    color: var(--ga-green);
    font-size: 12px;
    margin-top: 2px;
}

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

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

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

.ga-preview-stage {
    position: relative;
    flex: 1 1 auto;
    min-height: 360px;
    max-height: calc(100vh - 270px);
    border-radius: 18px;
    background:
        radial-gradient(circle at center, rgba(198,146,45,.10), transparent 45%),
        linear-gradient(135deg, #151515 0%, #282828 100%);
    border: 1px solid rgba(198,146,45,.26);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: auto;
    padding: 18px;
}

.ga-preview-img,
#cuadro-preview-img {
    display: none;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: calc(100vh - 330px) !important;
    object-fit: contain !important;
    margin: 0 auto;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 18px 44px rgba(0,0,0,.34);
    border: 0 !important;
}

.ga-preview-loader {
    min-width: 250px;
    max-width: 360px;
    padding: 22px 24px;
    border-radius: 20px;
    background:
        radial-gradient(circle at top, rgba(198,146,45,.16), transparent 48%),
        rgba(18,18,18,.74);
    border: 1px solid rgba(198,146,45,.28);
    box-shadow: 0 18px 48px rgba(0,0,0,.26);
    color: #fff;
    text-align: center;
    backdrop-filter: blur(8px);
}

.ga-preview-loader-mark {
    width: 48px;
    height: 48px;
    margin: 0 auto 12px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    color: #181818;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 24px rgba(198,146,45,.28);
}

.ga-preview-loader-mark i {
    font-size: 22px;
    color: #181818 !important;
}

.ga-preview-loader strong {
    display: block;
    font-size: 14px;
    font-weight: 900;
    color: #fff;
    margin-bottom: 5px;
}

.ga-preview-loader span {
    display: block;
    font-size: 12px;
    line-height: 1.4;
    color: rgba(255,255,255,.68);
}

.ga-preview-error {
    width: 100%;
    padding: 14px 16px;
    border-radius: 14px;
    background: var(--ga-red-pale);
    border: 1px solid var(--ga-red-border);
    color: var(--ga-red);
    font-size: 13px;
    font-weight: 700;
    text-align: center;
}

.ga-preview-caption {
    flex: 0 0 auto;
    margin-top: 12px;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    border-radius: 14px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    color: var(--ga-text-secondary);
    font-size: 12.5px;
    font-weight: 700;
}

.ga-preview-caption i {
    color: var(--ga-gold);
}

.ga-preview-footer {
    flex: 0 0 auto;
    padding: 16px 24px !important;
    justify-content: flex-end;
}

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

@media (max-width: 991px) {
    .ga-proyecto-editar-dialog,
    .ga-preview-modal-root .ga-preview-dialog {
        width: calc(100vw - 20px) !important;
        margin: 10px auto !important;
    }

    .ga-proyecto-editar-layout,
    .ga-preview-layout {
        grid-template-columns: 1fr;
    }

    .ga-preview-modal {
        max-height: calc(100vh - 20px);
    }

    .ga-preview-body {
        overflow: auto !important;
    }

    .ga-preview-stage {
        min-height: 300px;
        max-height: none;
    }

    .ga-preview-img,
    #cuadro-preview-img {
        max-height: 62vh !important;
    }
}

@media (max-width: 768px) {
    .ga-proyecto-editar-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .ga-proyecto-editar-grid .span-2 {
        grid-column: span 1;
    }

    .ga-proyecto-editar-side-card,
    .ga-proyecto-editar-main-card,
    .ga-preview-side-card,
    .ga-preview-main-card {
        padding: 18px;
    }

    .ga-proyecto-editar-footer,
    .ga-preview-footer {
        flex-wrap: wrap;
    }

    .ga-proyecto-editar-footer .btn,
    .ga-preview-footer .btn {
        width: 100%;
    }
}

/* ============================================================
   GraduApp Onboarding Fullscreen
   ============================================================ */

.ga-onboarding-overlay {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background:
        radial-gradient(circle at top left, rgba(212,175,55,.22), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,241,224,.96));
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.ga-onboarding-overlay::before {
    content: "";
    position: absolute;
    inset: 0;
    backdrop-filter: blur(7px);
}

.ga-onboarding-card {
    width: min(520px, 100%);
    min-height: 520px;
    background: #fff;
    border-radius: 28px;
    box-shadow: 0 24px 70px rgba(0,0,0,.18);
    border: 1px solid rgba(212,175,55,.25);
    position: relative;
    z-index: 2;
    padding: 42px 38px 30px;
    text-align: center;
    overflow: hidden;
}

.ga-onboarding-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 5px;
    background: linear-gradient(90deg, #c69b2d, #f1d987, #c69b2d);
}

.ga-onboarding-skip {
    position: absolute;
    top: 16px;
    right: 18px;
    border: 0;
    background: transparent;
    color: #777;
    font-size: 13px;
    font-weight: 600;
}

.ga-onboarding-slide {
    display: none;
    padding-top: 38px;
}

.ga-onboarding-slide.active {
    display: block;
    animation: gaOnboardingFade .25s ease;
}

@keyframes gaOnboardingFade {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ga-onboarding-icon {
    width: 126px;
    height: 126px;
    border-radius: 36px;
    background: linear-gradient(135deg, #fff7df, #f4df9b);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 28px;
    color: #1f1f1f;
    box-shadow: 0 14px 35px rgba(212,175,55,.24);
}

.ga-onboarding-icon i {
    font-size: 52px;
    color: #c69b2d;
}

.ga-onboarding-slide h2 {
    margin: 0 0 14px;
    font-size: 28px;
    font-weight: 800;
    color: #1f1f1f;
}

.ga-onboarding-slide p {
    margin: 0 auto;
    max-width: 380px;
    color: #5f5f5f;
    font-size: 15px;
    line-height: 1.65;
}

.ga-onboarding-note {
    margin: 20px auto 0;
    max-width: 390px;
    border-radius: 16px;
    padding: 12px 14px;
    background: #fff8e6;
    border: 1px solid rgba(212,175,55,.32);
    color: #6b5417;
    font-size: 13px;
    font-weight: 600;
}

.ga-onboarding-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin: 36px 0 28px;
}

.ga-onboarding-dots button {
    width: 8px;
    height: 8px;
    border-radius: 99px;
    border: 0;
    background: #ddd;
    padding: 0;
    transition: all .2s ease;
}

.ga-onboarding-dots button.active {
    width: 28px;
    background: #c69b2d;
}

.ga-onboarding-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
}

.ga-onboarding-btn {
    border-radius: 999px;
    padding: 11px 22px;
    border: 0;
    font-weight: 700;
    min-width: 130px;
}

.ga-onboarding-btn.ghost {
    background: #f4f4f4;
    color: #555;
}

.ga-onboarding-btn.main {
    background: #1f1f1f;
    color: #fff;
    box-shadow: 0 12px 25px rgba(0,0,0,.18);
}

.ga-onboarding-btn.main:hover {
    background: #c69b2d;
}

@media (max-width: 600px) {
    .ga-onboarding-card {
        min-height: auto;
        padding: 36px 24px 26px;
        border-radius: 22px;
    }

    .ga-onboarding-actions {
        flex-direction: column;
    }

    .ga-onboarding-btn {
        width: 100%;
    }
}

/* =========================================================
   GraduApp — Plantillas con imagen real
   ========================================================= */

.plantilla-preview {
    position: relative;
    width: 100%;
    height: 220px;
    padding: 10px;
    border-radius: 22px;
    overflow: hidden;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
    display: flex;
    align-items: center;
    justify-content: center;
}

.plantilla-preview .plantilla-img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;      /* importante: muestra la imagen completa */
    object-position: center;
    border-radius: 16px;      /* curvas suaves en la imagen */
    background: #fff;
    transition: transform 0.22s ease;
}

/* opcional: hover sutil */
.plantilla-card:hover .plantilla-preview .plantilla-img {
    transform: scale(1.015);
}

.plantilla-badge {
    position: absolute;
    right: 12px;
    bottom: 12px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 11px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .35px;
    text-transform: uppercase;
    background: rgba(255,255,255,0.92);
    color: var(--ga-text-primary);
    box-shadow: 0 8px 20px rgba(0,0,0,.14);
}

/* =========================================================
   GraduApp — Mini preview en últimos proyectos
   ========================================================= */

/* =========================================================
   GraduApp — Mini preview / placeholder en últimos proyectos
   ========================================================= */

.ga-home-project-preview-thumb {
    width: 76px;
    height: 54px;
    min-width: 76px;
    border-radius: 14px;
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at center, rgba(15, 23, 42, .08), transparent 58%),
        #eeeeec;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 8px 18px rgba(15,23,42,.08);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--ga-transition);
}

.ga-home-project-preview-thumb.has-preview {
    background:
        radial-gradient(circle at center, rgba(198,146,45,.10), transparent 55%),
        #171717;
    border-color: rgba(198,146,45,.26);
}

.ga-home-project-preview-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    background: #111;
}

.ga-home-project-preview-empty {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        linear-gradient(135deg, #f3f3f1, #e4e5e2);
    color: #a0a5ad;
}

.ga-home-project-preview-empty i {
    font-size: 20px;
    opacity: .62;
}

/* Icono de estado: sin fondo grueso, solo glow */
.ga-home-project-preview-status-icon {
    position: absolute;
    right: 6px;
    bottom: 5px;
    z-index: 2;
    font-size: 13px;
    line-height: 1;
    color: var(--ga-gold);
    text-shadow:
        0 1px 2px rgba(255,255,255,.95),
        0 0 9px rgba(198,146,45,.60),
        0 3px 8px rgba(0,0,0,.18);
}

/* Colores del icono según estado */
.ga-home-project-preview-thumb.is-borrador .ga-home-project-preview-status-icon {
    color: #8a929f;
    text-shadow:
        0 1px 2px rgba(255,255,255,.95),
        0 0 8px rgba(138,146,159,.36),
        0 3px 8px rgba(0,0,0,.13);
}

.ga-home-project-preview-thumb.is-pendiente .ga-home-project-preview-status-icon {
    color: #c6922d;
}

.ga-home-project-preview-thumb.is-pagado .ga-home-project-preview-status-icon {
    color: #3498db;
    text-shadow:
        0 1px 2px rgba(255,255,255,.95),
        0 0 9px rgba(52,152,219,.48),
        0 3px 8px rgba(0,0,0,.18);
}

.ga-home-project-preview-thumb.is-revision .ga-home-project-preview-status-icon {
    color: #9a6200;
}

.ga-home-project-preview-thumb.is-observacion .ga-home-project-preview-status-icon {
    color: #b84242;
    text-shadow:
        0 1px 2px rgba(255,255,255,.95),
        0 0 9px rgba(184,66,66,.42),
        0 3px 8px rgba(0,0,0,.18);
}

.ga-home-project-preview-thumb.is-aprobado .ga-home-project-preview-status-icon,
.ga-home-project-preview-thumb.is-finalizado .ga-home-project-preview-status-icon {
    color: #2f7d21;
    text-shadow:
        0 1px 2px rgba(255,255,255,.95),
        0 0 9px rgba(47,125,33,.45),
        0 3px 8px rgba(0,0,0,.18);
}

.ga-home-project-preview-thumb.is-produccion .ga-home-project-preview-status-icon {
    color: #d9b35b;
    text-shadow:
        0 1px 2px rgba(0,0,0,.35),
        0 0 10px rgba(217,179,91,.62),
        0 3px 8px rgba(0,0,0,.25);
}

.ga-home-project-preview-thumb.is-despacho .ga-home-project-preview-status-icon {
    color: #4f7fbf;
    text-shadow:
        0 1px 2px rgba(255,255,255,.95),
        0 0 9px rgba(79,127,191,.45),
        0 3px 8px rgba(0,0,0,.18);
}

.ga-home-project-row:hover .ga-home-project-preview-thumb {
    transform: scale(1.035);
    box-shadow: 0 10px 24px rgba(15,23,42,.14);
    border-color: var(--ga-gold-border);
}

.ga-home-project-row:hover .ga-home-project-preview-status-icon {
    transform: translateY(-1px) scale(1.08);
}

@media (max-width: 768px) {
    .ga-home-project-preview-thumb {
        width: 62px;
        height: 46px;
        min-width: 62px;
        border-radius: 12px;
    }

    .ga-home-project-preview-empty i {
        font-size: 17px;
    }

    .ga-home-project-preview-status-icon {
        right: 5px;
        bottom: 5px;
        font-size: 11px;
    }
}

/* Segunda foto grupal: mismo estilo visual que la grupal principal */
.ga-editor-overlay-box.is-grupal-2 {
    background: rgba(255,255,255,.48);
    border: 1px solid rgba(255, 255, 255, 0.42);
    color: rgba(255,255,255,.96);
    text-shadow: 0 1px 3px rgba(0,0,0,.28);
}

.ga-editor-overlay-box.is-grupal-2 span {
    background: transparent;
    color: inherit;
}

.ga-tutorial-index-card {
    display: block;
    min-height: 210px;
    padding: 22px;
    margin-bottom: 18px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid var(--ga-border);
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    color: inherit;
    text-decoration: none !important;
    transition: var(--ga-transition);
}

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

.ga-tutorial-index-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 20px;
    margin-bottom: 14px;
}

.ga-tutorial-index-card strong {
    display: block;
    color: var(--ga-text-primary);
    font-size: 16px;
    font-weight: 900;
    margin-bottom: 8px;
}

.ga-tutorial-index-card p {
    margin: 0;
    color: var(--ga-text-secondary);
    font-size: 13px;
    line-height: 1.5;
}

.ga-photo-quality-inline-help {
    display: flex;
    gap: 11px;
    padding: 13px 14px;
    margin-bottom: 14px;
    border-radius: 16px;
    background: #fff8e6;
    border: 1px solid rgba(198,146,45,.32);
    color: #6b4b00;
}

.ga-photo-quality-inline-help > i {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.14);
    color: var(--ga-gold);
    border: 1px solid rgba(198,146,45,.28);
}

.ga-photo-quality-inline-help strong {
    display: block;
    font-size: 12.5px;
    font-weight: 900;
    color: #5f4200;
}

.ga-photo-quality-inline-help span {
    display: block;
    margin-top: 2px;
    font-size: 12px;
    line-height: 1.4;
    color: #7a5918;
}

.ga-photo-quality-inline-help a {
    display: inline-flex;
    margin-top: 6px;
    color: var(--ga-gold);
    font-weight: 900;
    font-size: 12px;
}

.ga-tutorial-device-card,
.ga-tutorial-quality-comparison {
    min-height: 320px;
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(198,146,45,.18), transparent 42%),
        #fff;
    border: 1px solid rgba(198,146,45,.22);
    box-shadow: 0 16px 36px rgba(15,23,42,.12);
    padding: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ga-device-phone,
.ga-device-camera {
    width: min(360px, 100%);
    min-height: 230px;
    border-radius: 24px;
    background: linear-gradient(135deg, #111827, #273142);
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-align: center;
    padding: 24px;
}

.ga-device-phone i,
.ga-device-camera i {
    font-size: 54px;
    color: var(--ga-gold-light);
}

.ga-device-phone strong,
.ga-device-camera strong {
    font-size: 22px;
    font-weight: 900;
}

.ga-device-phone span,
.ga-device-camera span {
    color: rgba(255,255,255,.72);
    font-size: 13px;
    line-height: 1.4;
}

.ga-tutorial-quality-comparison {
    gap: 14px;
    flex-wrap: wrap;
}

.ga-quality-good,
.ga-quality-bad {
    flex: 1 1 180px;
    min-height: 180px;
    border-radius: 20px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
}

.ga-quality-good {
    background: var(--ga-green-pale);
    border: 1px solid var(--ga-green-border);
    color: var(--ga-green);
}

.ga-quality-bad {
    background: var(--ga-red-pale);
    border: 1px solid var(--ga-red-border);
    color: var(--ga-red);
}

.ga-quality-good i,
.ga-quality-bad i {
    font-size: 34px;
}

.ga-quality-good strong,
.ga-quality-bad strong {
    font-size: 16px;
    font-weight: 900;
}

.ga-quality-good span,
.ga-quality-bad span {
    font-size: 12.5px;
    line-height: 1.35;
}

/* =========================================================
   GraduApp — Tutoriales estilo sistema / proyecto-detalle
   Sobrescribe look onboarding redondo
   ========================================================= */

.ga-tutorial-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
}

.ga-tutorial-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(26, 29, 35, 0.58);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}

/* Caja principal: más parecida a panel/modal del sistema */
.ga-tutorial-box {
    position: relative;
    width: min(1120px, calc(100vw - 48px));
    max-height: calc(100vh - 48px);
    margin: 24px auto;
    display: flex;
    flex-direction: column;

    background: #fff;
    border-radius: var(--ga-radius-lg);
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 24px 70px rgba(0,0,0,.22);
    overflow: hidden;
    animation: gaTutorialSystemIn .16s ease-out;
}

@keyframes gaTutorialSystemIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Header compacto, como modal GraduApp */
.ga-tutorial-header {
    flex: 0 0 auto;
    padding: 16px 22px !important;
    background: linear-gradient(135deg, var(--ga-dark), var(--ga-dark-2));
    border-bottom: 2px solid var(--ga-gold);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.ga-tutorial-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.ga-tutorial-brand-icon {
    width: 38px;
    height: 38px;
    flex: 0 0 38px;
    border-radius: var(--ga-radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.14);
    border: 1px solid rgba(198,146,45,.34);
    color: var(--ga-gold-light);
    font-size: 17px;
}

.ga-tutorial-header h3 {
    margin: 0;
    color: #fff;
    font-size: 15px;
    font-weight: 800;
    letter-spacing: .2px;
    line-height: 1.2;
}

.ga-tutorial-header p {
    margin: 3px 0 0;
    color: rgba(255,255,255,.62);
    font-size: 12px;
    line-height: 1.35;
}

.ga-tutorial-counter {
    min-width: 54px;
    padding: 5px 10px;
    border-radius: var(--ga-radius-sm);
    background: rgba(198,146,45,.13);
    border: 1px solid rgba(198,146,45,.32);
    color: var(--ga-gold-light);
    font-size: 12px;
    font-weight: 900;
    text-align: center;
}

/* Cerrar menos circular */
.ga-tutorial-close {
    position: absolute;
    top: 13px;
    right: 16px;
    width: 30px;
    height: 30px;
    border: 0;
    border-radius: var(--ga-radius-sm);
    background: rgba(255,255,255,.08);
    color: var(--ga-gold-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    cursor: pointer;
    transition: var(--ga-transition);
}

.ga-tutorial-close:hover {
    background: rgba(255,255,255,.14);
    color: #fff;
}

/* Barra de progreso más sobria */
.ga-tutorial-progress {
    flex: 0 0 auto;
    height: 3px;
    background: #eee;
}

.ga-tutorial-progress > div {
    height: 100%;
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-gold-light));
    transition: width .22s ease;
}

/* Cuerpo estilo panel */
.ga-tutorial-content {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    padding: 22px 24px;
    background:
        radial-gradient(circle at top right, rgba(198,146,45,.07), transparent 30%),
        var(--ga-surface-card);
}

.ga-tutorial-slide {
    display: none;
}

.ga-tutorial-slide.active {
    display: block;
}

.ga-tutorial-slide-grid {
    display: grid;
    grid-template-columns: 0.92fr 1.08fr;
    gap: 20px;
    align-items: stretch;
}

/* Panel texto */
.ga-tutorial-text {
    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,.04);
}

.ga-tutorial-tag {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 4px 9px;
    border-radius: 999px;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: #7a5918;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .55px;
    margin-bottom: 13px;
}

.ga-tutorial-tag.success {
    background: var(--ga-green-pale);
    border-color: var(--ga-green-border);
    color: var(--ga-green);
}

.ga-tutorial-tag.danger {
    background: var(--ga-red-pale);
    border-color: var(--ga-red-border);
    color: var(--ga-red);
}

.ga-tutorial-text h4 {
    margin: 0 0 10px;
    color: var(--ga-text-primary);
    font-size: 22px;
    line-height: 1.18;
    font-weight: 900;
    letter-spacing: -.5px;
}

.ga-tutorial-text p {
    margin: 0 0 14px;
    color: var(--ga-text-secondary);
    font-size: 13.5px;
    line-height: 1.55;
}

.ga-tutorial-text ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ga-tutorial-text li {
    position: relative;
    padding-left: 24px;
    margin-bottom: 8px;
    color: var(--ga-text-primary);
    font-size: 13px;
    line-height: 1.45;
}

.ga-tutorial-text li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 1px;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: var(--ga-gold-pale);
    color: var(--ga-gold);
    border: 1px solid var(--ga-gold-border);
    font-size: 10px;
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Imagen / cards visuales más tipo dashboard, menos oscuras */
.ga-tutorial-image-wrap,
.ga-tutorial-final-card,
.ga-tutorial-device-card,
.ga-tutorial-quality-comparison,
.ga-tutorial-logo-preview,
.ga-logo-comparison,
.ga-logo-cleaner-card,
.ga-logo-quality-card,
.ga-logo-mistakes-grid {
    min-height: 350px;
    border-radius: var(--ga-radius-lg) !important;
    background:
        linear-gradient(135deg, rgba(198,146,45,.08), rgba(255,255,255,.98));
    border: 1px solid var(--ga-border);
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    overflow: hidden;
}

.ga-tutorial-image-wrap {
    position: relative;
}

.ga-tutorial-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Si no hay imagen, las cards quedan claras y sobrias */
.ga-tutorial-final-card,
.ga-tutorial-device-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 26px;
    text-align: center;
    color: var(--ga-text-primary);
}

.ga-tutorial-final-card i,
.ga-device-phone i,
.ga-device-camera i {
    width: 58px;
    height: 58px;
    margin-bottom: 14px;
    border-radius: var(--ga-radius-lg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ga-gold-pale);
    border: 1px solid var(--ga-gold-border);
    color: var(--ga-gold);
    font-size: 24px;
}

.ga-tutorial-final-card h4,
.ga-device-phone strong,
.ga-device-camera strong {
    margin: 0 0 7px;
    color: var(--ga-text-primary);
    font-size: 20px;
    font-weight: 900;
}

.ga-tutorial-final-card p,
.ga-device-phone span,
.ga-device-camera span {
    margin: 0;
    max-width: 420px;
    color: var(--ga-text-secondary);
    font-size: 13px;
    line-height: 1.5;
}

.ga-device-phone,
.ga-device-camera {
    width: 100%;
    min-height: 260px;
    border-radius: var(--ga-radius-lg);
    background: transparent;
    color: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

/* Watermark más discreto */
.ga-tutorial-watermark {
    position: absolute;
    right: 12px;
    bottom: 12px;
    padding: 5px 9px;
    border-radius: var(--ga-radius-sm);
    background: rgba(26,29,35,.76);
    color: rgba(255,255,255,.86);
    font-size: 11px;
    font-weight: 700;
}

/* Footer tipo modal sistema */
.ga-tutorial-footer {
    flex: 0 0 auto;
    padding: 14px 22px !important;
    background: var(--ga-surface-subtle);
    border-top: 1px solid var(--ga-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.ga-tutorial-btn {
    min-height: 36px;
    padding: 0 14px;
    border-radius: var(--ga-radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .2px;
    text-transform: uppercase;
    border: 1px solid transparent;
    cursor: pointer;
    transition: var(--ga-transition);
}

.ga-tutorial-btn.primary {
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    color: #fff;
    border: none;
    box-shadow: 0 3px 10px var(--ga-gold-shadow);
}

.ga-tutorial-btn.primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(198,146,45,.36);
}

.ga-tutorial-btn.secondary {
    background: #fff;
    border: 1px solid var(--ga-border-md);
    color: var(--ga-text-secondary);
}

.ga-tutorial-btn.secondary:hover {
    background: var(--ga-surface);
    border-color: var(--ga-gold-border);
    color: var(--ga-gold);
}

.ga-tutorial-btn:disabled {
    opacity: .42;
    cursor: not-allowed;
    transform: none !important;
    box-shadow: none !important;
}

/* Comparaciones good/bad menos caricaturescas */
.ga-tutorial-quality-comparison {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    padding: 18px;
}

.ga-quality-good,
.ga-quality-bad {
    border-radius: var(--ga-radius-lg);
    min-height: 210px;
    padding: 18px;
}

.ga-quality-good {
    background: var(--ga-green-pale);
    border: 1px solid var(--ga-green-border);
    color: var(--ga-green);
}

.ga-quality-bad {
    background: var(--ga-red-pale);
    border: 1px solid var(--ga-red-border);
    color: var(--ga-red);
}

/* Responsive */
@media (max-width: 900px) {
    .ga-tutorial-box {
        width: calc(100vw - 20px);
        max-height: calc(100vh - 20px);
        margin: 10px auto;
    }

    .ga-tutorial-header {
        padding: 14px 54px 14px 16px !important;
    }

    .ga-tutorial-counter {
        display: none;
    }

    .ga-tutorial-content {
        padding: 16px;
    }

    .ga-tutorial-slide-grid {
        grid-template-columns: 1fr;
    }

    .ga-tutorial-text h4 {
        font-size: 19px;
    }

    .ga-tutorial-image-wrap,
    .ga-tutorial-final-card,
    .ga-tutorial-device-card,
    .ga-tutorial-quality-comparison,
    .ga-tutorial-logo-preview,
    .ga-logo-comparison,
    .ga-logo-cleaner-card,
    .ga-logo-quality-card,
    .ga-logo-mistakes-grid {
        min-height: 260px;
    }

    .ga-tutorial-footer {
        padding: 12px 16px !important;
    }

    .ga-tutorial-btn {
        flex: 1;
    }
}

/* =========================================================
   GraduApp — Fix scroll horizontal tutoriales
   ========================================================= */

.ga-tutorial-box {
    overflow: hidden !important;
}

.ga-tutorial-content {
    overflow-x: hidden !important;
    overflow-y: auto !important;
}

.ga-tutorial-slide,
.ga-tutorial-slide.active {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.ga-tutorial-slide-grid {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr) !important;
}

.ga-tutorial-text,
.ga-tutorial-image-wrap,
.ga-tutorial-final-card,
.ga-tutorial-device-card,
.ga-tutorial-quality-comparison,
.ga-tutorial-logo-preview,
.ga-logo-comparison,
.ga-logo-cleaner-card,
.ga-logo-quality-card,
.ga-logo-mistakes-grid {
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box;
}

.ga-tutorial-image-wrap {
    width: 100% !important;
}

.ga-tutorial-image-wrap img {
    max-width: 100% !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    display: block;
}

/* Evita que textos largos o badges internos empujen el ancho */
.ga-tutorial-text h4,
.ga-tutorial-text p,
.ga-tutorial-text li,
.ga-tutorial-header h3,
.ga-tutorial-header p {
    overflow-wrap: anywhere;
}

/* En pantallas medianas, baja antes a una sola columna */
@media (max-width: 1050px) {
    .ga-tutorial-slide-grid {
        grid-template-columns: 1fr !important;
    }

    .ga-tutorial-image-wrap,
    .ga-tutorial-final-card,
    .ga-tutorial-device-card,
    .ga-tutorial-quality-comparison,
    .ga-tutorial-logo-preview,
    .ga-logo-comparison,
    .ga-logo-cleaner-card,
    .ga-logo-quality-card,
    .ga-logo-mistakes-grid {
        min-height: 280px !important;
    }
}

/* ============================================================
   GraduApp — Guías fullscreen de fotos estilo onboarding
   ============================================================ */

body.ga-photo-guide-open {
    overflow: hidden;
}

.ga-help-tutorial-btn {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    border: 1px solid var(--ga-gold-border) !important;
    color: var(--ga-gold) !important;
    font-weight: 900 !important;
    box-shadow: 0 2px 8px rgba(198,146,45,.10);
    transition: var(--ga-transition);
}

.ga-help-tutorial-btn:hover,
.ga-help-tutorial-btn:focus {
    background: var(--ga-gold-pale) !important;
    color: var(--ga-gold) !important;
    transform: translateY(-1px);
}

.ga-photo-guide-overlay {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background:
        radial-gradient(circle at top left, rgba(212,175,55,.22), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,241,224,.96));
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.ga-photo-guide-overlay::before {
    content: "";
    position: absolute;
    inset: 0;
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
}

.ga-photo-guide-card {
    width: min(1180px, 100%);
    max-height: calc(100vh - 48px);
    background: #fff;
    border-radius: 28px;
    box-shadow: 0 24px 70px rgba(0,0,0,.18);
    border: 1px solid rgba(212,175,55,.25);
    position: relative;
    z-index: 2;
    padding: 30px 34px 24px;
    text-align: center;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.ga-photo-guide-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 5px;
    background: linear-gradient(90deg, #c69b2d, #f1d987, #c69b2d);
}

.ga-photo-guide-skip {
    position: absolute;
    top: 16px;
    right: 18px;
    border: 0;
    background: transparent;
    color: #777;
    font-size: 13px;
    font-weight: 700;
    z-index: 4;
}

.ga-photo-guide-skip:hover {
    color: var(--ga-gold);
}

.ga-photo-guide-head {
    flex: 0 0 auto;
    padding: 4px 44px 18px;
}

.ga-photo-guide-kicker {
    color: #c69b2d;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.ga-photo-guide-head h2 {
    margin: 0 0 8px;
    font-size: 25px;
    font-weight: 900;
    color: #1f1f1f;
}

.ga-photo-guide-head p {
    margin: 0 auto;
    max-width: 560px;
    color: #5f5f5f;
    font-size: 14px;
    line-height: 1.45;
}

.ga-photo-guide-stage {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ga-photo-guide-slide {
    display: none;
    width: 100%;
    min-height: 0;
}

.ga-photo-guide-slide.active {
    display: flex;
    align-items: center;
    justify-content: center;
    animation: gaPhotoGuideFade .25s ease;
}

@keyframes gaPhotoGuideFade {
    from {
        opacity: 0;
        transform: translateY(8px) scale(.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.ga-photo-guide-slide img {
    display: block;
    max-width: 100%;
    max-height: min(68vh, 640px);
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 14px 38px rgba(0,0,0,.10);
}

.ga-photo-guide-dots {
    flex: 0 0 auto;
    display: flex;
    justify-content: center;
    gap: 8px;
    margin: 20px 0 18px;
}

.ga-photo-guide-dots button {
    width: 8px;
    height: 8px;
    border-radius: 99px;
    border: 0;
    background: #ddd;
    padding: 0;
    transition: all .2s ease;
}

.ga-photo-guide-dots button.active {
    width: 28px;
    background: #c69b2d;
}

.ga-photo-guide-actions {
    flex: 0 0 auto;
    display: flex;
    justify-content: center;
    gap: 12px;
}

/* Links de ayuda dentro de tips y carga masiva */

.ga-tip-tutorial-links {
    display: grid;
    gap: 7px;
    margin-top: 10px;
}

.ga-inline-tutorial-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}

.ga-inline-tutorial-links a {
    font-size: 12px;
    font-weight: 700;
    color: var(--ga-gold);
    text-decoration: none;
}

.ga-inline-tutorial-links a:hover {
    text-decoration: underline;
}

.ga-masivo-tutorial-box {
    margin-top: 14px;
    padding: 12px;
    border-radius: 14px;
    background: var(--ga-surface-subtle);
    border: 1px solid var(--ga-border);
}

.ga-masivo-tutorial-box > span {
    display: block;
    margin-bottom: 8px;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--ga-text-muted);
}

.ga-masivo-tutorial-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    font-size: 12px;
    font-weight: 700;
    color: var(--ga-text-primary);
    text-decoration: none !important;
}

.ga-masivo-tutorial-link + .ga-masivo-tutorial-link {
    border-top: 1px solid var(--ga-border);
}

.ga-masivo-tutorial-link i {
    color: var(--ga-gold);
}

.ga-masivo-tutorial-link:hover {
    color: var(--ga-gold);
}

@media (max-width: 768px) {
    .ga-photo-guide-overlay {
        padding: 12px;
    }

    .ga-photo-guide-card {
        max-height: calc(100vh - 24px);
        padding: 28px 16px 18px;
        border-radius: 22px;
    }

    .ga-photo-guide-head {
        padding: 8px 28px 14px;
    }

    .ga-photo-guide-head h2 {
        font-size: 20px;
    }

    .ga-photo-guide-head p {
        font-size: 12.5px;
    }

    .ga-photo-guide-slide img {
        max-height: 58vh;
        border-radius: 14px;
    }

    .ga-photo-guide-actions {
        flex-direction: column;
    }

    .ga-photo-guide-actions .ga-onboarding-btn {
        width: 100%;
    }
}