/* =============================================
   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-dark);
    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 v2 · ficha con drag & drop
   ========================================================= */

.ga-alumno-dialog {
    width: min(760px, calc(100vw - 36px));
}

.ga-alumno-modal-v2 {
    border-radius: 24px !important;
    overflow: hidden;
    background: #fff;
}

.ga-alumno-header-v2 {
    position: relative;
    padding: 22px 26px !important;
    border-bottom: 0 !important;
    background:
        radial-gradient(circle at 88% -20%, rgba(217,179,91,.25), transparent 34%),
        linear-gradient(135deg, #171a20 0%, #292f39 100%) !important;
}

.ga-alumno-header-v2::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-gold-light));
}

.ga-alumno-header-v2 .close {
    top: 22px !important;
    transform: none !important;
}

.ga-alumno-header-inner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-right: 44px;
}

.ga-alumno-header-icon {
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--ga-gold), var(--ga-gold-light));
    color: #171a20;
    box-shadow: 0 12px 28px rgba(198,146,45,.28);
}

.ga-alumno-header-icon i {
    font-size: 21px;
    color: #171a20 !important;
}

.ga-alumno-kicker {
    margin-bottom: 4px;
    color: rgba(255,255,255,.58);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.ga-alumno-modal-v2 .modal-title {
    margin: 0;
    color: #fff;
    font-size: 18px !important;
    font-weight: 900 !important;
    letter-spacing: -.15px !important;
}

.ga-alumno-modal-v2 .small {
    margin-top: 4px;
    color: rgba(255,255,255,.64) !important;
    font-size: 12.5px !important;
}

.ga-alumno-body {
    padding: 0 !important;
    background:
        linear-gradient(180deg, #fff 0%, #fffaf0 100%) !important;
}

.ga-alumno-layout {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 0;
    min-height: 360px;
}

.ga-alumno-photo-card,
.ga-alumno-fields-card {
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
}

.ga-alumno-photo-card {
    padding: 26px;
    background:
        radial-gradient(circle at 20% 8%, rgba(198,146,45,.16), transparent 36%),
        linear-gradient(180deg, #fff7e4 0%, #fff 100%);
    border-right: 1px solid rgba(198,146,45,.18);
}

.ga-alumno-dropzone {
    position: relative;
    width: 100%;
    min-height: 278px;
    margin: 0;
    padding: 18px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    text-align: center;
    border: 2px dashed rgba(198,146,45,.42);
    border-radius: 18px;
    background: rgba(255,255,255,.72);
    transition: var(--ga-transition);
}

.ga-alumno-dropzone:hover,
.ga-alumno-dropzone.is-dragover {
    border-color: var(--ga-gold);
    background: #fff;
    box-shadow: 0 14px 34px rgba(198,146,45,.14);
    transform: translateY(-1px);
}

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

.ga-alumno-photo-preview {
    width: 132px;
    height: 132px;
    border-radius: 50%;
    overflow: hidden;
    background: #fff;
    border: 3px solid rgba(255,255,255,.92);
    box-shadow:
        0 12px 24px rgba(28,30,36,.13),
        0 0 0 1px rgba(198,146,45,.16);
    display: flex;
    align-items: center;
    justify-content: center;
}

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

.ga-alumno-photo-preview.is-empty {
    border-radius: 22px;
    background:
        radial-gradient(circle at center, rgba(198,146,45,.14), transparent 50%),
        #fff;
}

.ga-alumno-photo-empty {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ga-gold);
}

.ga-alumno-photo-empty i {
    font-size: 42px;
    opacity: .72;
}

.ga-alumno-drop-copy strong {
    display: block;
    color: var(--ga-text-primary);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.2;
}

.ga-alumno-drop-copy span {
    display: block;
    margin-top: 4px;
    color: var(--ga-text-secondary);
    font-size: 12px;
    font-weight: 650;
    line-height: 1.35;
}

.ga-alumno-file-name {
    max-width: 100%;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(198,146,45,.11);
    color: #7a5918;
    font-size: 11px;
    font-weight: 800;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ga-alumno-save-note {
    margin-top: -4px;
    color: var(--ga-text-muted);
    font-size: 11px;
    font-weight: 700;
}

.ga-alumno-photo-help {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    margin-top: 14px;
    color: var(--ga-text-secondary);
    font-size: 11.5px;
    line-height: 1.45;
}

.ga-alumno-photo-help i {
    margin-top: 2px;
    color: var(--ga-gold);
}

.ga-alumno-photo-help a {
    color: #9a6d14;
    font-weight: 900;
    text-decoration: none;
}

.ga-alumno-photo-help a:hover {
    color: var(--ga-gold);
    text-decoration: underline;
}

.ga-alumno-fields-card {
    padding: 30px 30px 26px;
}

.ga-alumno-section-title {
    margin-bottom: 24px;
}

.ga-alumno-section-title span {
    display: block;
    color: var(--ga-text-primary);
    font-size: 15px;
    font-weight: 900;
    letter-spacing: -.05px;
}

.ga-alumno-section-title small {
    display: block;
    margin-top: 5px;
    color: var(--ga-text-muted);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
}

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

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

.ga-alumno-fields-card .form-control {
    height: 46px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 700;
    background: #fff !important;
}

.ga-form-field-main .form-control {
    height: 50px !important;
    font-size: 15px !important;
}

.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-options-row {
    display: grid;
    grid-template-columns: 138px minmax(0, 1fr);
    gap: 16px;
    align-items: end;
    margin-top: 8px;
}

.ga-form-field-qty {
    margin-bottom: 0;
}

.ga-alumno-fields-card .help-block {
    margin: 7px 0 0;
    color: var(--ga-text-muted);
    font-size: 11.5px;
    line-height: 1.35;
}

.ga-alumno-include-box {
    min-height: 82px;
    display: flex;
    align-items: center;
    padding: 14px 15px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(198,146,45,.09), rgba(255,255,255,.92));
    border: 1px solid rgba(198,146,45,.16);
}

.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: 44px;
    height: 26px;
    flex: 0 0 44px;
    border-radius: 999px;
    background: #d7dce2;
    transition: var(--ga-transition);
}

.ga-switch-ui::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    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: 900;
    line-height: 1.2;
}

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

.ga-alumno-footer {
    padding: 17px 26px !important;
    background: #fff !important;
    border-top: 1px solid rgba(0,0,0,.06) !important;
}

.ga-alumno-footer .btn {
    height: 42px;
    min-width: 124px;
    border-radius: 13px !important;
    font-weight: 900 !important;
    text-transform: uppercase;
    letter-spacing: .2px;
}

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

@media (max-width: 768px) {
    .ga-alumno-dialog {
        width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    .ga-alumno-layout {
        grid-template-columns: 1fr;
    }

    .ga-alumno-photo-card {
        border-right: 0;
        border-bottom: 1px solid rgba(198,146,45,.18);
        padding: 20px;
    }

    .ga-alumno-dropzone {
        min-height: 235px;
    }

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

    .ga-alumno-options-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .ga-alumno-footer {
        flex-direction: column-reverse;
        align-items: stretch;
    }

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


.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%;
    }
}

/* =========================================================
   GraduApp — MVP responsivo global producción
   Landing / dashboard / proyecto / modales
   ========================================================= */
:root {
    --ga-mobile-gap: 14px;
}

html, body {
    max-width: 100%;
    overflow-x: hidden;
}

img, video, canvas, svg {
    max-width: 100%;
    height: auto;
}

.ga-btn-inline-flex,
.btn.ga-btn-inline-flex,
.ga-home-hero-new-btn,
.ga-home-inline-link-main,
.ga-home-secondary-btn,
.ga-detail-secondary-btn,
.ga-payment-action-btn {
    min-height: 38px;
}

.ga-mobile-scroll-x,
.ga-table-scroll-x,
.table-responsive,
.datatable-scroll,
.dataTables_scrollBody {
    -webkit-overflow-scrolling: touch;
}

.modal-open {
    padding-right: 0 !important;
}

.modal-dialog {
    max-width: calc(100vw - 24px);
}

.modal-content {
    max-width: 100%;
}

.modal-body {
    overflow-x: hidden;
}

/* Botones y footers de modal usables en celular */
@media (max-width: 767px) {
    body {
        font-size: 14px;
    }

    .page-container,
    .page-content,
    .content-wrapper,
    .content {
        min-width: 0 !important;
    }

    .content {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .page-header,
    .breadcrumb-line {
        display: none;
    }

    .modal-dialog,
    .modal-lg,
    .modal-md,
    .modal-sm {
        width: calc(100vw - 18px) !important;
        max-width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    .modal-content,
    .ga-alumno-modal,
    .ga-proyecto-editar-modal,
    .ga-preview-modal,
    .ga-editor-modal,
    .ga-quality-content,
    .ga-template-change-modal {
        border-radius: 18px !important;
        max-height: calc(100vh - 18px);
        display: flex;
        flex-direction: column;
    }

    .modal-header.graduapp-header,
    .ga-editor-header,
    .ga-preview-header,
    .ga-quality-header {
        padding: 16px 18px !important;
        min-height: auto !important;
    }

    .modal-header.graduapp-header .modal-title,
    .ga-editor-header .modal-title,
    .ga-preview-header .modal-title,
    .ga-quality-header .modal-title {
        font-size: 15px !important;
        line-height: 1.25 !important;
        padding-right: 34px;
    }

    .modal-header.graduapp-header .small,
    .ga-editor-header .small,
    .ga-preview-header .small {
        font-size: 11.5px !important;
        line-height: 1.35 !important;
    }

    .modal-header.graduapp-header .close,
    .ga-editor-header .close,
    .ga-preview-header .close,
    .ga-quality-header .close {
        top: 12px !important;
        right: 12px !important;
        width: 34px !important;
        height: 34px !important;
    }

    .modal-body,
    .ga-alumno-body,
    .ga-proyecto-editar-body,
    .ga-editor-body,
    .ga-preview-body,
    .ga-quality-body,
    .ga-template-change-modal .modal-body {
        padding: 16px !important;
        overflow-y: auto !important;
        flex: 1 1 auto;
        -webkit-overflow-scrolling: touch;
    }

    .modal-footer,
    .ga-proyecto-editar-footer,
    .ga-editor-footer,
    .ga-preview-footer,
    .ga-quality-footer {
        padding: 12px 16px !important;
        display: flex !important;
        flex-direction: column-reverse !important;
        align-items: stretch !important;
        gap: 8px !important;
        flex-shrink: 0;
    }

    .modal-footer .btn,
    .ga-proyecto-editar-footer .btn,
    .ga-editor-footer .btn,
    .ga-preview-footer .btn,
    .ga-quality-footer .btn {
        width: 100% !important;
        margin: 0 !important;
        justify-content: center;
        min-height: 42px;
    }

    .form-control,
    .select2-container,
    .select2-choice,
    .select2-selection,
    select.form-control,
    textarea.form-control {
        max-width: 100% !important;
    }

    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    select,
    textarea {
        font-size: 16px !important; /* evita zoom automático iOS */
    }

    .row {
        margin-left: -8px;
        margin-right: -8px;
    }

    [class*="col-"] {
        padding-left: 8px;
        padding-right: 8px;
    }
}

/* DataTables como tarjetas en móvil para proyectos y alumnos */
@media (max-width: 700px) {
    table.ga-mobile-card-table,
    table.ga-mobile-card-table thead,
    table.ga-mobile-card-table tbody,
    table.ga-mobile-card-table th,
    table.ga-mobile-card-table td,
    table.ga-mobile-card-table tr {
        display: block !important;
        width: 100% !important;
    }

    table.ga-mobile-card-table thead {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        overflow: hidden !important;
        clip: rect(0 0 0 0) !important;
        white-space: nowrap !important;
    }

    table.ga-mobile-card-table tbody tr {
        margin: 12px 0 !important;
        padding: 12px !important;
        border: 1px solid rgba(20,20,20,.08) !important;
        border-radius: 18px !important;
        background: #fff !important;
        box-shadow: 0 8px 22px rgba(0,0,0,.055) !important;
    }

    table.ga-mobile-card-table tbody tr.dataTables_empty,
    table.ga-mobile-card-table tbody tr.odd.dataTables_empty,
    table.ga-mobile-card-table tbody tr.even.dataTables_empty {
        padding: 18px !important;
        text-align: center !important;
    }

    table.ga-mobile-card-table tbody td {
        display: flex !important;
        align-items: flex-start !important;
        justify-content: space-between !important;
        gap: 14px !important;
        min-height: 34px;
        padding: 8px 0 !important;
        border: 0 !important;
        border-bottom: 1px solid rgba(0,0,0,.055) !important;
        white-space: normal !important;
        word-break: break-word;
        text-align: right !important;
    }

    table.ga-mobile-card-table tbody td:last-child {
        border-bottom: 0 !important;
        justify-content: flex-end !important;
    }

    table.ga-mobile-card-table tbody td::before {
        content: attr(data-label);
        min-width: 110px;
        max-width: 42%;
        color: #7b735f;
        font-size: 11px;
        font-weight: 900;
        letter-spacing: .04em;
        text-transform: uppercase;
        text-align: left;
    }

    table.ga-mobile-card-table tbody td:last-child::before {
        display: none;
    }

    .datatable-header,
    .datatable-footer {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .datatable-header,
    .datatable-footer,
    .dataTables_length,
    .dataTables_filter,
    .dataTables_info,
    .dataTables_paginate {
        float: none !important;
        display: block !important;
        width: 100% !important;
        text-align: left !important;
    }

    .dataTables_filter label,
    .dataTables_length label {
        width: 100% !important;
        margin: 0 0 8px !important;
    }

    .dataTables_filter input {
        width: 100% !important;
        margin-left: 0 !important;
    }

    .table-responsive,
    .datatable-scroll {
        overflow: visible !important;
    }
}

/* =========================================================
   GraduApp — Administración de usuarios / validación email
   Versión: 2026-05-10
   ========================================================= */
.ga-usuarios-page .content { padding-top: 24px; }
.ga-admin-hero.ga-users-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    padding: 28px 30px;
    margin-bottom: 20px;
    border-radius: 26px;
    background: radial-gradient(circle at top left, rgba(198,146,45,.18), transparent 34%), linear-gradient(135deg, #10141f 0%, #181818 100%);
    color: #fff;
    border: 1px solid rgba(198,146,45,.24);
    box-shadow: 0 22px 70px rgba(0,0,0,.16);
}
.ga-admin-hero.ga-users-hero .ga-kicker {
    display: inline-flex;
    color: #d9b35b;
    font-size: 12px;
    letter-spacing: .9px;
    text-transform: uppercase;
    font-weight: 800;
    margin-bottom: 7px;
}
.ga-admin-hero.ga-users-hero h1 {
    margin: 0 0 8px;
    font-size: 28px;
    line-height: 1.15;
    font-weight: 900;
}
.ga-admin-hero.ga-users-hero p {
    margin: 0;
    max-width: 720px;
    color: rgba(255,255,255,.72);
    font-size: 14px;
    line-height: 1.5;
}
.ga-admin-hero-actions { flex-shrink: 0; }
.ga-users-stats { margin-bottom: 20px; }
.ga-users-stat-card {
    min-height: 104px;
    padding: 18px 20px;
    margin-bottom: 15px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 12px 34px rgba(0,0,0,.06);
    position: relative;
    overflow: hidden;
}
.ga-users-stat-card:before {
    content: "";
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 5px;
    background: #c6922d;
}
.ga-users-stat-card.warning:before { background: #d97706; }
.ga-users-stat-card.muted:before { background: #6b7280; }
.ga-users-stat-label {
    display: block;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: #8a7a6a;
    font-weight: 800;
    margin-bottom: 8px;
}
.ga-users-stat-card strong {
    display: block;
    color: #1a1d23;
    font-size: 30px;
    line-height: 1;
    font-weight: 900;
}
.ga-users-panel {
    border: 0 !important;
    border-radius: 22px;
    overflow: visible;
    box-shadow: 0 14px 40px rgba(0,0,0,.07);
}
.ga-panel-heading-flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 22px !important;
    border-bottom: 1px solid rgba(0,0,0,.07) !important;
}
.ga-users-table-wrap { overflow: visible; }
.ga-user-cell strong { display: block; color: #1a1d23; font-size: 14px; }
.ga-user-cell span,
.ga-contact-cell span { display: block; color: #6b7280; font-size: 12px; line-height: 1.45; }
.ga-contact-cell i { color: #c6922d; margin-right: 5px; }
.ga-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    border-radius: 999px;
    padding: 5px 9px;
    font-size: 11px;
    line-height: 1;
    font-weight: 800;
    white-space: nowrap;
    border: 1px solid transparent;
}
.ga-badge-ok { background: #eaf3de; color: #3b6d11; border-color: #b8d990; }
.ga-badge-warn { background: #fff8ed; color: #8b5e34; border-color: #eadfce; }
.ga-badge-danger { background: #fde8ea; color: #8b2f36; border-color: #f2b9bf; }
.ga-users-actions { margin: 0; }
.ga-users-actions .dropdown-menu { z-index: 1070; }
.ga-user-modal .modal-content {
    border: 0;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 24px 80px rgba(0,0,0,.20);
}
.ga-user-modal-body { background: #fafaf8; padding: 24px 28px !important; }
.ga-user-modal-body .form-group { margin-bottom: 16px; }
.ga-user-modal-body label {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: #8a7a6a;
    font-weight: 800;
    margin-bottom: 6px;
}
.ga-user-modal-note,
.ga-user-validation-warning {
    border-radius: 14px;
    padding: 14px 16px;
    margin-bottom: 18px;
    font-size: 13px;
    line-height: 1.5;
}
.ga-user-modal-note { background: #fff8ed; border: 1px solid #eadfce; color: #6b4a2f; }
.ga-user-validation-warning { background: #fde8ea; border: 1px solid #f2b9bf; color: #8b2f36; }
.ga-user-validation-warning i { margin-right: 6px; }
@media (max-width: 767px) {
    .ga-admin-hero.ga-users-hero { flex-direction: column; align-items: flex-start; padding: 22px; border-radius: 20px; }
    .ga-admin-hero.ga-users-hero h1 { font-size: 23px; }
    .ga-admin-hero-actions,
    .ga-admin-hero-actions .btn { width: 100%; }
    .ga-users-table-wrap { overflow-x: auto; }
}

/* =========================================================
   GraduApp - Pago - Datos de coordinación / despacho
   Estilo equilibrado tipo proyecto-detalle
   ========================================================= */

.ga-pago-despacho-box {
    margin-top: 18px;
    padding: 20px;
    border-radius: 22px;
    background: #ffffff;
    border: 1px solid rgba(17, 24, 39, .08);
    box-shadow: 0 16px 40px rgba(17, 24, 39, .06);
}

.ga-pago-despacho-head {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 18px;
    padding: 16px 16px 18px;
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(198, 146, 45, .10), rgba(255, 255, 255, .85)),
        #faf9f6;
    border: 1px solid rgba(198, 146, 45, .16);
}

.ga-pago-despacho-icon {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #171717;
    color: #d6aa45;
    font-size: 18px;
    box-shadow: 0 10px 22px rgba(17, 17, 17, .14);
}

.ga-pago-despacho-title-wrap {
    min-width: 0;
}

.ga-pago-despacho-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 7px;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(198, 146, 45, .15);
    color: #8a6119;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .075em;
    line-height: 1;
    text-transform: uppercase;
}

.ga-pago-despacho-head h5 {
    margin: 0 0 5px;
    color: #1c2230;
    font-size: 17px;
    font-weight: 800;
    line-height: 1.25;
}

.ga-pago-despacho-head p {
    margin: 0;
    max-width: 760px;
    color: #6b7280;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.45;
}

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

/* Cada campo como ficha suave */
.ga-pago-field {
    padding: 14px;
    border-radius: 16px;
    background: #fbfbfa;
    border: 1px solid rgba(17, 24, 39, .07);
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.ga-pago-field.full {
    grid-column: 1 / -1;
}

.ga-pago-field:focus-within {
    background: #ffffff;
    border-color: rgba(198, 146, 45, .42);
    box-shadow: 0 0 0 4px rgba(198, 146, 45, .10);
}

.ga-pago-field-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 9px;
}

.ga-pago-field-label label {
    margin: 0!important;
    color: #252b36!important;
    font-size: 13px!important;
    font-weight: 800!important;
    letter-spacing: 0!important;
    line-height: 1.2!important;
    text-transform: none!important;
}

.ga-pago-field-label span {
    flex: 0 0 auto;
    padding: 3px 8px;
    border-radius: 999px;
    background: rgba(179, 64, 52, .09);
    color: #a33a30;
    font-size: 10px;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.ga-pago-field-label span.optional {
    background: rgba(107, 114, 128, .10);
    color: #6b7280;
}

.ga-pago-control,
.ga-pago-field .form-control {
    width: 100%;
    min-height: 42px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(17, 24, 39, .11);
    background: #ffffff;
    color: #202633;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
    box-shadow: none;
    transition: border-color .18s ease, box-shadow .18s ease;
}

.ga-pago-control::placeholder,
.ga-pago-field .form-control::placeholder {
    color: #a1a8b3;
    font-weight: 500;
}

.ga-pago-control:focus,
.ga-pago-field .form-control:focus {
    border-color: #c6922d;
    box-shadow: none;
    outline: none;
}

.ga-pago-field textarea.form-control,
textarea.ga-pago-control {
    min-height: 78px;
    resize: vertical;
}

.ga-pago-field-help {
    margin-top: 8px!important;
    color: #7a8492!important;
    font-size: 11px!important;
    font-weight: normal!important;
    line-height: 1.35!important;
}

/* Limpia herencia de .form-group / help-block si quedó algo anterior */
.ga-pago-despacho-form .form-group {
    margin-bottom: 0;
}

.ga-pago-despacho-form .help-block {
    margin: 7px 0 0;
    color: #7a8492;
    font-size: 12px;
    font-weight: 500;
}

/* Responsive */
@media (max-width: 767px) {
    .ga-pago-despacho-box {
        padding: 16px;
        border-radius: 18px;
    }

    .ga-pago-despacho-head {
        padding: 14px;
        border-radius: 16px;
    }

    .ga-pago-despacho-icon {
        width: 38px;
        height: 38px;
        flex-basis: 38px;
        border-radius: 12px;
        font-size: 17px;
    }

    .ga-pago-despacho-form {
        grid-template-columns: 1fr;
    }

    .ga-pago-field {
        padding: 13px;
    }

    .ga-pago-field-label {
        align-items: flex-start;
        flex-direction: column;
        gap: 6px;
    }
}
/* GraduApp mejora 2026-05-12: autoencuadre, guía y revisión de ajustes */
.ga-label-revisada {
    background: #d9b15d;
    color: #1f1a10;
    border-radius: 999px;
    font-weight: 700;
    margin-left: 4px;
    margin-right: 6px;
}

.ga-label-pendiente-ajuste {
    background: #f6efe0;
    color: #8a641d;
    border: 1px solid rgba(217, 177, 93, .45);
    border-radius: 999px;
    font-weight: 700;
    margin-left: 4px;
    margin-right: 6px;
}

.ga-label-revisada i,
.ga-label-pendiente-ajuste i {
    margin-right: 4px;
}

.ga-editor-silueta-guia {
    position: absolute;
    inset: 0;
    z-index: 4;
    pointer-events: none;
    opacity: .40;
    display: block;
}

.ga-editor-silueta-guia:before {
    content: "Guía referencial";
    position: absolute;
    left: 50%;
    top: 10px;
    transform: translateX(-50%);
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(0,0,0,.42);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .02em;
}

.ga-silueta-head {
    position: absolute;
    left: 50%;
    top: 11%;
    width: 36%;
    height: 40%;
    transform: translateX(-50%);
    border: 4px dashed rgba(255,255,255,.96);
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(0,0,0,.22), 0 8px 25px rgba(0,0,0,.15);
}

.ga-silueta-body {
    position: absolute;
    left: 50%;
    top: 70%;
    width: 48%;
    height: 18%;
    transform: translateX(-50%);
    border: 4px dashed rgba(255,255,255,.92);
    border-top: none;
    border-radius: 0 0 22% 22%;
    box-shadow: 0 0 0 1px rgba(0,0,0,.20), 0 8px 25px rgba(0,0,0,.12);
}

.ga-silueta-shoulders {
    position: absolute;
    left: 50%;
    top: 55%;
    width: 80%;
    height: 18%;
    transform: translateX(-50%);
    border: 4px dashed rgba(255,255,255,.92);
    border-bottom: none;
    border-radius: 48% 48% 0 0;
}

.ga-editor-auto-fit-note {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    margin-bottom: 14px;
    border-radius: 14px;
    background: #fff7df;
    border: 1px solid rgba(217, 177, 93, .45);
    color: #5b4214;
    font-size: 13px;
    line-height: 1.35;
}

.ga-editor-auto-fit-note i {
    color: #b78b25;
    font-size: 18px;
    margin-top: 1px;
}

#modal-editor-foto:not(.ga-editor-tipo-individual) .ga-editor-silueta-guia {
    display: none;
}

/* GraduApp 2026-05-12 — ajuste: ocultar silueta cuando la foto individual es fondo */
#modal-editor-foto.ga-editor-foto-fondo .ga-editor-silueta-guia,
#modal-editor-foto.ga-editor-tipo-proyecto .ga-editor-silueta-guia {
    display: none !important;
}

#modal-editor-foto.ga-editor-foto-fondo .ga-editor-help-silueta,
#modal-editor-foto.ga-editor-tipo-proyecto .ga-editor-help-silueta {
    display: none !important;
}

.ga-label-pendiente-ajuste,
.imagen-proyecto-estado .label.ga-label-pendiente-ajuste, 
.imagen-proyecto-estado span.label.ga-label-pendiente-ajuste {
    background: #f6efe0!important;
    color: #8a641d!important;
    border: 1px solid rgba(217, 177, 93, .45)!important;
    border-radius: 999px;
    font-weight: 700;
    margin-left: 4px;
    margin-right: 6px;
}

/* GraduApp Institucional */
.ga-institutional-section{padding:72px 0;background:linear-gradient(180deg,#fff 0%,#fbf7ed 100%)}
.ga-institutional-card{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;align-items:center;background:#111;border-radius:28px;padding:42px;box-shadow:0 24px 70px rgba(0,0,0,.16);position:relative;overflow:hidden}
.ga-institutional-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 0%,rgba(217,171,73,.24),transparent 34%);pointer-events:none}
.ga-institutional-copy,.ga-institutional-list{position:relative;z-index:1}
.ga-institutional-copy h2{color:#fff;margin-top:12px}
.ga-institutional-copy .section-sub{color:rgba(255,255,255,.78)}
.ga-institutional-list{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:24px;display:grid;gap:14px;color:#fff}
.ga-institutional-list div{display:flex;gap:10px;align-items:flex-start;color:rgba(255,255,255,.86);font-weight:600}
.ga-institutional-list span{color:#d6a23a;font-weight:900}
.ga-institutional-list .btn{margin-top:8px;justify-self:start}
@media(max-width:991px){.ga-institutional-card{grid-template-columns:1fr;padding:28px}.ga-institutional-section{padding:48px 0}}

/* =========================================================
   GraduApp — Modal alumno v3 · estilo limpio tipo checkout
   ========================================================= */
.ga-alumno-dialog-v3 {
    width: min(920px, calc(100vw - 44px)) !important;
    margin: 18px auto !important;
}

.ga-alumno-modal-v3 {
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 22px 70px rgba(16, 18, 24, .22) !important;
    border: 0 !important;
}

.ga-alumno-topbar-v3 {
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 0 24px;
    background: #fff;
    border-bottom: 1px solid #e6ded2;
}

.ga-alumno-breadcrumb-v3 {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: #9a8c7a;
    font-size: 11px;
    line-height: 1;
}

.ga-alumno-breadcrumb-v3 span {
    font-size: 10px;
    font-weight: 500;
    color: #a28d6c;
}

.ga-alumno-breadcrumb-v3 i {
    color: #c6922d;
    font-size: 9px;
}

.ga-alumno-breadcrumb-v3 strong {
    color: #111827;
    font-size: 12px;
    font-weight: 600;
}

.ga-alumno-actions-v3 {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
}

.ga-alumno-top-btn,
.ga-alumno-icon-btn {
    height: 34px;
    border-radius: 6px;
    border: 1px solid #cfc7bc;
    background: #fff;
    color: #111827;
    padding: 0 15px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    transition: background .15s ease, border-color .15s ease, color .15s ease, transform .15s ease;
}

.ga-alumno-top-btn:hover,
.ga-alumno-icon-btn:hover {
    background: #faf8f4;
    border-color: #b9a98f;
    color: #7a5918;
}

.ga-alumno-top-btn-main {
    border-color: #b9913c;
    background: #fff;
    color: #20160a;
}

.ga-alumno-icon-btn {
    width: 34px;
    padding: 0;
    font-size: 20px;
    color: #8f98a8;
}

.ga-alumno-body-v3 {
    padding: 0 !important;
    background: #f7f2ea !important;
}

.ga-alumno-layout-v3 {
    display: grid;
    grid-template-columns: 48% 52%;
    min-height: 395px;
}

.ga-alumno-modal-v3 .ga-alumno-photo-card,
.ga-alumno-modal-v3 .ga-alumno-fields-pane-v3 {
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.ga-alumno-photo-pane-v3 {
    padding: 28px 34px 24px !important;
    background: #fbf7ef !important;
    border-right: 1px solid #e0d5c7 !important;
}

.ga-alumno-fields-pane-v3 {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 28px 32px 22px;
    background: #f7f2ea;
}

.ga-alumno-pane-label,
.ga-alumno-modal-v3 .ga-form-field label {
    display: block;
    margin: 0 0 11px !important;
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-alumno-modal-v3 .ga-form-field {
    margin-bottom: 22px !important;
}

.ga-alumno-modal-v3 .ga-form-field-main .form-control,
.ga-alumno-modal-v3 .ga-form-field .form-control {
    height: 40px !important;
    border-radius: 5px !important;
    border: 1px solid #d8d0c6 !important;
    background: #fff !important;
    color: #1f2937 !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    padding: 0 13px !important;
    box-shadow: none !important;
}

.ga-alumno-modal-v3 .form-control::placeholder {
    color: #b3a799 !important;
    font-weight: 400 !important;
}

.ga-alumno-modal-v3 .form-control:focus {
    border-color: #c6922d !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.11) !important;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone {
    position: relative;
    width: 100%;
    min-height: 270px;
    margin: 0 !important;
    padding: 28px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    cursor: pointer;
    text-align: center;
    border: 1.5px dashed #c6922d !important;
    border-radius: 9px !important;
    background: #f1e7d8 !important;
    box-shadow: none !important;
    transition: border-color .15s ease, background .15s ease, transform .15s ease;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone:hover,
.ga-alumno-modal-v3 .ga-alumno-dropzone.is-dragover {
    background: #f7eddd !important;
    border-color: #a87512 !important;
    transform: none !important;
    box-shadow: inset 0 0 0 2px rgba(198,146,45,.08) !important;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone input[type="file"] {
    display: none;
}

.ga-alumno-modal-v3 .ga-alumno-photo-preview {
    width: 58px;
    height: 58px;
    border-radius: 50% !important;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,.28) !important;
    border: 0 !important;
    box-shadow: none !important;
}

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

.ga-alumno-modal-v3 .ga-alumno-dropzone.has-photo .ga-alumno-photo-preview {
    width: 100%;
    height: 178px;
    border-radius: 8px !important;
    background: #fff !important;
}

.ga-alumno-modal-v3 .ga-alumno-photo-empty {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #c6922d;
}

.ga-alumno-modal-v3 .ga-alumno-photo-empty i {
    font-size: 20px;
    opacity: .95;
}

.ga-alumno-modal-v3 .ga-alumno-drop-copy strong {
    display: block;
    margin-top: 2px;
    color: #3b2a17;
    font-size: 12.5px;
    font-weight: 600;
    line-height: 1.2;
}

.ga-alumno-modal-v3 .ga-alumno-drop-copy span,
.ga-alumno-modal-v3 .ga-alumno-drop-copy em {
    display: block;
    margin-top: 3px;
    color: #9a7a4b;
    font-size: 10.5px;
    font-weight: 400;
    line-height: 1.25;
    font-style: normal;
    text-transform: uppercase;
}

.ga-alumno-modal-v3 .ga-alumno-drop-copy em {
    color: #bd8c27;
    font-size: 9.6px;
}

.ga-alumno-modal-v3 .ga-alumno-file-name {
    max-width: 90%;
    margin-top: 4px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.55);
    color: #7a5918;
    font-size: 10.5px;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ga-alumno-modal-v3 .ga-alumno-save-note {
    margin-top: 0;
    color: #7a5918;
    font-size: 10.5px;
    font-weight: 500;
}

.ga-alumno-quality-link {
    display: block;
    margin-top: 15px;
    text-align: center;
    color: #b97911 !important;
    font-size: 11px;
    font-weight: 500;
    text-decoration: none !important;
}

.ga-alumno-quality-link:hover {
    color: #8f5f0a !important;
    text-decoration: underline !important;
}

.ga-alumno-qty-control-v3 {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    min-height: 68px;
    border: 1px solid #e0cdb4;
    border-radius: 10px;
    background: #fffaf2;
    overflow: hidden;
}

.ga-alumno-qty-copy-v3 {
    position: relative;
    flex: 1 1 auto;
    padding: 12px 48px 10px 16px;
}

.ga-alumno-qty-copy-v3 span {
    display: block;
    margin-bottom: 2px;
    color: #9d9388;
    font-size: 9.5px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.ga-alumno-modal-v3 .ga-alumno-qty-input {
    width: 100% !important;
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #1f2937 !important;
    font-size: 22px !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    box-shadow: none !important;
    text-align: left !important;
    -moz-appearance: textfield;
}

.ga-alumno-modal-v3 .ga-alumno-qty-input::-webkit-outer-spin-button,
.ga-alumno-modal-v3 .ga-alumno-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.ga-alumno-qty-copy-v3 small {
    display: block;
    margin-top: 1px;
    color: #9a7a4b;
    font-size: 10px;
    font-weight: 400;
}

.ga-alumno-qty-buttons-v3 {
    width: 40px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    gap: 6px;
    padding: 9px 10px 9px 0;
}

.ga-alumno-qty-btn {
    width: 24px;
    height: 22px;
    padding: 0;
    border-radius: 7px;
    border: 1px solid #d6c7b2;
    background: #fff;
    color: #4b5563;
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.ga-alumno-qty-btn:hover {
    background: #f5eddf;
    border-color: #c6922d;
    color: #7a5918;
}

.ga-alumno-include-strip-v3 {
    margin-top: auto !important;
    min-height: 54px;
    padding: 11px 12px 11px 16px;
    border-radius: 9px;
    background: #3b2818;
    color: #fff;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    cursor: pointer;
}

.ga-alumno-include-strip-v3 input {
    display: none;
}

.ga-alumno-include-strip-v3 > span:first-of-type {
    min-width: 0;
}

.ga-alumno-include-strip-v3 strong {
    display: block;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
}

.ga-alumno-include-strip-v3 small {
    display: block;
    margin-top: 2px;
    color: rgba(255,255,255,.72);
    font-size: 10.5px;
    font-weight: 400;
    line-height: 1.25;
    text-transform: none;
    letter-spacing: 0;
}

.ga-alumno-include-strip-v3 .ga-switch-ui {
    width: 34px;
    height: 20px;
    flex: 0 0 34px;
    border-radius: 999px;
    background: rgba(255,255,255,.22);
}

.ga-alumno-include-strip-v3 .ga-switch-ui::after {
    top: 3px;
    left: 3px;
    width: 14px;
    height: 14px;
    background: #fff;
}

.ga-alumno-include-strip-v3 input:checked ~ .ga-switch-ui {
    background: linear-gradient(135deg, #c6922d, #e0b65a);
}

.ga-alumno-include-strip-v3 input:checked ~ .ga-switch-ui::after {
    left: 17px;
}

.ga-alumno-footer-v3 {
    min-height: 54px;
    padding: 0 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    background: #fff !important;
    border-top: 1px solid #e6ded2 !important;
}

.ga-alumno-status-v3 {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: #8c857c;
    font-size: 11px;
    font-weight: 400;
}

.ga-alumno-status-v3 span {
    width: 5px;
    height: 5px;
    border-radius: 999px;
    background: #c6922d;
}

.ga-alumno-status-v3.is-dirty {
    color: #7a5918;
}

.ga-alumno-footer-actions-v3 {
    display: flex;
    align-items: center;
    gap: 9px;
}

.ga-alumno-footer-v3 .btn {
    height: 34px !important;
    min-width: 108px !important;
    padding: 0 14px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    box-shadow: none !important;
}

.ga-alumno-footer-v3 .btn-default {
    background: #fff !important;
    border: 1px solid #cfc7bc !important;
    color: #111827 !important;
}

.ga-alumno-footer-v3 .btn-default:hover {
    background: #faf8f4 !important;
    border-color: #b9a98f !important;
    color: #7a5918 !important;
}

.ga-alumno-footer-v3 .btn-primary {
    min-width: 138px !important;
    background: #fff !important;
    border: 1px solid #cfc7bc !important;
    color: #111827 !important;
}

.ga-alumno-footer-v3 .btn-primary:hover {
    background: #faf8f4 !important;
    border-color: #b9913c !important;
    color: #7a5918 !important;
    transform: none !important;
}

@media (max-width: 820px) {
    .ga-alumno-dialog-v3 {
        width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    .ga-alumno-topbar-v3 {
        height: auto;
        min-height: 56px;
        padding: 12px 16px;
        align-items: flex-start;
        flex-direction: column;
    }

    .ga-alumno-actions-v3 {
        width: 100%;
    }

    .ga-alumno-top-btn {
        flex: 1;
    }

    .ga-alumno-layout-v3 {
        grid-template-columns: 1fr;
    }

    .ga-alumno-photo-pane-v3 {
        border-right: 0 !important;
        border-bottom: 1px solid #e0d5c7 !important;
        padding: 22px 18px !important;
    }

    .ga-alumno-fields-pane-v3 {
        padding: 22px 18px;
        min-height: 280px;
    }

    .ga-alumno-footer-v3 {
        height: auto;
        padding: 12px 16px !important;
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .ga-alumno-footer-actions-v3 {
        width: 100%;
    }

    .ga-alumno-footer-v3 .btn {
        flex: 1;
        min-width: 0 !important;
    }
}

/* =========================================================
   GraduApp — Modal alumno v4
   Foto con más espacio + metadatos al costado
   ========================================================= */
.ga-alumno-dialog-v3 {
    width: min(940px, calc(100vw - 44px)) !important;
}

.ga-alumno-layout-v3 {
    grid-template-columns: minmax(0, 52%) minmax(0, 48%) !important;
    min-height: 438px !important;
}

.ga-alumno-photo-pane-v3 {
    padding: 28px 34px 26px !important;
}

.ga-alumno-fields-pane-v3 {
    padding: 28px 32px 22px !important;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone {
    min-height: 332px !important;
    padding: 18px !important;
    gap: 11px !important;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone.has-photo {
    justify-content: center !important;
    align-items: stretch !important;
    padding: 16px !important;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone.has-photo .ga-alumno-photo-preview {
    width: 100% !important;
    height: 286px !important;
    min-height: 286px !important;
    border-radius: 7px !important;
    background: rgba(255,255,255,.35) !important;
}

.ga-alumno-modal-v3 .ga-alumno-photo-preview img {
    object-fit: contain !important;
    object-position: center !important;
    background: transparent !important;
}

.ga-alumno-modal-v3 .ga-alumno-dropzone.has-photo .ga-alumno-drop-copy {
    display: none !important;
}

.ga-alumno-photo-side-info {
    flex: 1 1 auto;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin: 4px 0 20px;
    padding: 15px 0 0;
    border-top: 1px solid rgba(111, 91, 66, .16);
    color: #5f5143;
}

.ga-alumno-photo-side-icon {
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.11);
    color: #b57e18;
    font-size: 14px;
}

.ga-alumno-photo-side-copy {
    min-width: 0;
    padding-top: 1px;
}

.ga-alumno-photo-side-label {
    display: block;
    margin-bottom: 5px;
    color: #9d9388;
    font-size: 9.6px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.ga-alumno-photo-side-copy strong {
    display: block;
    max-width: 315px;
    color: #3b2a17;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.38;
}

.ga-alumno-photo-side-copy small,
.ga-alumno-photo-side-copy em {
    display: block;
    max-width: 315px;
    margin-top: 7px;
    color: #8b755c;
    font-size: 10.8px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ga-alumno-photo-side-copy em {
    color: #9a6f1e;
    white-space: normal;
}

.ga-alumno-photo-side-info.is-empty .ga-alumno-photo-side-icon {
    background: rgba(17,24,39,.06);
    color: #9d9388;
}

.ga-alumno-include-strip-v3 {
    margin-top: auto !important;
}

@media (max-width: 820px) {
    .ga-alumno-layout-v3 {
        grid-template-columns: 1fr !important;
        min-height: 0 !important;
    }

    .ga-alumno-modal-v3 .ga-alumno-dropzone,
    .ga-alumno-modal-v3 .ga-alumno-dropzone.has-photo .ga-alumno-photo-preview {
        min-height: 260px !important;
        height: auto !important;
    }

    .ga-alumno-photo-side-info {
        flex: 0 0 auto;
        margin-bottom: 18px;
    }
}

.ga-alumno-modal-v3 .ga-alumno-photo-side-copy .ga-alumno-file-name,
.ga-alumno-modal-v3 .ga-alumno-photo-side-copy .ga-alumno-save-note {
    max-width: 315px !important;
    margin-top: 7px !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #8b755c !important;
    font-size: 10.8px !important;
    font-weight: 400 !important;
    line-height: 1.35 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.ga-alumno-modal-v3 .ga-alumno-photo-side-copy .ga-alumno-save-note {
    color: #9a6f1e !important;
    white-space: normal !important;
}

/* =========================================================
   GraduApp — Modal carga masiva de alumnos · estilo alumno v4
   Agregar al final de graduapp.css
   ========================================================= */

.ga-masivo-dialog-v2 {
    width: min(960px, calc(100vw - 44px)) !important;
}

.ga-masivo-modal-v2 {
    border-radius: 0 !important;
}

.ga-masivo-body-v2 {
    padding: 0 !important;
    background: #f7f2ea !important;
}

.ga-masivo-layout-v2 {
    display: grid;
    grid-template-columns: minmax(280px, 34%) minmax(0, 66%);
    min-height: 462px;
}

.ga-masivo-side-pane-v2 {
    padding: 28px 30px 26px !important;
    background: #fbf7ef !important;
    border-right: 1px solid #e0d5c7 !important;
}

.ga-masivo-main-pane-v2 {
    display: flex;
    flex-direction: column;
    padding: 28px 32px 22px !important;
    background: #f7f2ea !important;
}

.ga-masivo-pane-label-v2 {
    display: block;
    margin: 0 0 14px !important;
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-masivo-side-intro-v2 {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 20px;
}

.ga-masivo-side-icon-v2 {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.11);
    color: #b57e18;
    font-size: 18px;
}

.ga-masivo-side-copy-v2 h3 {
    margin: 1px 0 7px;
    color: #1f2937;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.15;
}

.ga-masivo-side-copy-v2 p {
    margin: 0;
    color: #756b5d;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.55;
}

.ga-masivo-rule-list-v2 {
    display: grid;
    gap: 11px;
}

.ga-masivo-rule-item-v2 {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 13px;
    border: 1px solid #e4d8ca;
    border-radius: 10px;
    background: rgba(255,255,255,.56);
}

.ga-masivo-rule-item-v2 i {
    margin-top: 2px;
    color: #7fa043;
    font-size: 13px;
}

.ga-masivo-rule-item-v2 strong {
    display: block;
    margin: 0 0 3px;
    color: #3b2a17;
    font-size: 12.2px;
    font-weight: 500;
    line-height: 1.25;
}

.ga-masivo-rule-item-v2 span {
    display: block;
    color: #85796b;
    font-size: 11.3px;
    font-weight: 400;
    line-height: 1.38;
}

.ga-masivo-tip-v2 {
    margin-top: 16px;
    padding: 13px 14px;
    border-radius: 10px;
    background: #fffaf2;
    border: 1px solid #e0cdb4;
}

.ga-masivo-tip-v2 > span {
    display: block;
    margin-bottom: 5px;
    color: #9d9388;
    font-size: 9.5px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.ga-masivo-tip-v2 p {
    margin: 0;
    color: #6d6153;
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.45;
}

.ga-masivo-field-v2 {
    margin-bottom: 18px !important;
}

.ga-masivo-field-v2 > label {
    display: block;
    margin: 0 0 11px !important;
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-masivo-main-pane-v2 .form-control.ga-masivo-textarea-v2 {
    min-height: 292px !important;
    resize: none !important;
    border-radius: 8px !important;
    border: 1px solid #d8d0c6 !important;
    background: #fff !important;
    color: #1f2937 !important;
    padding: 14px 14px !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 1.65 !important;
    box-shadow: none !important;
}

.ga-masivo-main-pane-v2 .ga-masivo-textarea-v2::placeholder {
    color: #b3a799 !important;
    font-weight: 400 !important;
}

.ga-masivo-main-pane-v2 .ga-masivo-textarea-v2:focus {
    border-color: #c6922d !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.11) !important;
}

.ga-masivo-help-v2 {
    margin-top: 9px;
    color: #8b8073;
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.45;
}

.ga-masivo-include-strip-v2 {
    margin-top: auto !important;
}

.ga-masivo-footer-v2 .btn-primary {
    min-width: 170px !important;
}

@media (max-width: 820px) {
    .ga-masivo-dialog-v2 {
        width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    .ga-masivo-layout-v2 {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .ga-masivo-side-pane-v2 {
        padding: 22px 18px !important;
        border-right: 0 !important;
        border-bottom: 1px solid #e0d5c7 !important;
    }

    .ga-masivo-main-pane-v2 {
        padding: 22px 18px !important;
    }

    .ga-masivo-main-pane-v2 .form-control.ga-masivo-textarea-v2 {
        min-height: 240px !important;
    }

    .ga-masivo-footer-v2 {
        height: auto;
        padding: 12px 16px !important;
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .ga-masivo-footer-actions-v2 {
        width: 100%;
    }

    .ga-masivo-footer-v2 .btn {
        flex: 1;
        min-width: 0 !important;
    }
}
/* =========================================================
   GraduApp — Modal subida masiva de fotos · estilo alumno v4
   Agregar al final de graduapp.css
   ========================================================= */

.ga-fotos-dialog-v2 {
    width: min(980px, calc(100vw - 44px)) !important;
}

.ga-fotos-modal-v2 {
    border-radius: 0 !important;
}

.ga-fotos-body-v2 {
    padding: 0 !important;
    background: #f7f2ea !important;
}

.ga-fotos-layout-v2 {
    display: grid;
    grid-template-columns: minmax(280px, 34%) minmax(0, 66%);
    min-height: 490px;
}

.ga-fotos-side-pane-v2 {
    padding: 28px 30px 26px !important;
    background: #fbf7ef !important;
    border-right: 1px solid #e0d5c7 !important;
}

.ga-fotos-main-pane-v2 {
    display: flex;
    flex-direction: column;
    padding: 28px 32px 22px !important;
    background: #f7f2ea !important;
}

.ga-fotos-pane-label-v2,
.ga-fotos-field-v2 > label {
    display: block;
    margin: 0 0 14px !important;
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-fotos-side-intro-v2 {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 20px;
}

.ga-fotos-side-icon-v2,
.ga-fotos-drop-icon-v2 {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.11);
    color: #b57e18;
    font-size: 18px;
}

.ga-fotos-side-copy-v2 h3 {
    margin: 1px 0 7px;
    color: #1f2937;
    font-size: 23px;
    font-weight: 500;
    line-height: 1.15;
}

.ga-fotos-side-copy-v2 p {
    margin: 0;
    color: #756b5d;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.55;
}

.ga-fotos-examples-v2 {
    margin: 0 0 16px;
    padding: 13px 14px;
    border-radius: 9px;
    background: #fffaf2;
    border: 1px solid #e0cdb4;
}

.ga-fotos-examples-v2 > span,
.ga-fotos-help-links-v2 > span,
.ga-fotos-selected-head-v2 > span {
    display: block;
    margin-bottom: 9px;
    color: #9d9388;
    font-size: 9.5px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.ga-fotos-examples-v2 code {
    display: block;
    margin-top: 7px;
    padding: 7px 0 0;
    border-top: 1px solid rgba(111,91,66,.12);
    background: transparent;
    color: #5d4420;
    font-family: Consolas, Monaco, monospace;
    font-size: 11px;
    font-weight: 400;
    line-height: 1.35;
    white-space: normal;
}

.ga-fotos-rule-list-v2 {
    display: grid;
    gap: 10px;
}

.ga-fotos-rule-item-v2 {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 11px 0;
    border-top: 1px solid rgba(111,91,66,.13);
}

.ga-fotos-rule-item-v2:first-child {
    border-top: 0;
    padding-top: 0;
}

.ga-fotos-rule-item-v2 i {
    margin-top: 2px;
    color: #7fa043;
    font-size: 13px;
}

.ga-fotos-rule-item-v2 strong {
    display: block;
    margin: 0 0 3px;
    color: #3b2a17;
    font-size: 12.2px;
    font-weight: 500;
    line-height: 1.25;
}

.ga-fotos-rule-item-v2 span {
    display: block;
    color: #85796b;
    font-size: 11.3px;
    font-weight: 400;
    line-height: 1.38;
}

.ga-fotos-help-links-v2 {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid rgba(111,91,66,.15);
}

.ga-fotos-help-links-v2 a {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 8px 0;
    color: #3b2a17 !important;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none !important;
    border-top: 1px solid rgba(111,91,66,.10);
}

.ga-fotos-help-links-v2 a:first-of-type {
    border-top: 0;
}

.ga-fotos-help-links-v2 a i {
    color: #c6922d;
    font-size: 14px;
}

.ga-fotos-help-links-v2 a:hover {
    color: #8f5f0a !important;
}

.ga-fotos-field-v2 {
    margin-bottom: 16px !important;
}

.ga-fotos-dropzone-v2 {
    position: relative;
    width: 100%;
    min-height: 176px;
    margin: 0 !important;
    padding: 22px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    cursor: pointer;
    text-align: center;
    border: 1.5px dashed #c6922d !important;
    border-radius: 9px !important;
    background: #f1e7d8 !important;
    transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

.ga-fotos-dropzone-v2:hover,
.ga-fotos-dropzone-v2.is-dragover {
    background: #f7eddd !important;
    border-color: #a87512 !important;
    box-shadow: inset 0 0 0 2px rgba(198,146,45,.08) !important;
}

.ga-fotos-dropzone-v2.has-files {
    background: #f5ecdc !important;
    border-color: #b98216 !important;
}

.ga-fotos-file-input-v2 {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.ga-fotos-dropzone-v2 strong {
    display: block;
    margin-top: 5px;
    color: #3b2a17;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.2;
}

.ga-fotos-dropzone-v2 span,
.ga-fotos-dropzone-v2 em {
    display: block;
    color: #9a7a4b;
    font-size: 11px;
    font-weight: 400;
    line-height: 1.25;
    font-style: normal;
}

.ga-fotos-dropzone-v2 em {
    color: #bd8c27;
    font-size: 9.8px;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.ga-fotos-drop-count-v2 {
    margin-top: 9px;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,.55);
    color: #7a5918;
    font-size: 11px;
    font-weight: 500;
}

.ga-fotos-help-v2 {
    margin-top: 9px;
    color: #8b8073;
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.45;
}

.ga-fotos-selected-panel-v2 {
    margin-bottom: 16px;
    padding-top: 2px;
}

.ga-fotos-selected-head-v2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 9px;
}

.ga-fotos-selected-head-v2 > span {
    margin: 0;
}

.ga-fotos-clear-btn-v2 {
    border: 0;
    padding: 0;
    background: transparent;
    color: #9a6f1e;
    font-size: 11px;
    font-weight: 500;
}

.ga-fotos-clear-btn-v2:hover {
    color: #6f4d12;
    text-decoration: underline;
}

.ga-fotos-file-list-v2 {
    max-height: 116px;
    overflow: auto;
    margin: 0;
    padding: 0;
    border-top: 1px solid rgba(111,91,66,.14);
}

.ga-fotos-file-list-v2 li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 9px 0;
    border-bottom: 1px solid rgba(111,91,66,.10);
    color: #746a60;
    font-size: 12px;
}

.ga-fotos-file-list-v2 li.text-muted {
    color: #9d9388 !important;
}

.ga-fotos-file-list-v2 li i {
    margin-top: 2px;
    color: #b98216;
    font-size: 13px;
}

.ga-fotos-file-list-v2 li strong {
    display: block;
    max-width: 420px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #3b2a17;
    font-size: 12px;
    font-weight: 500;
}

.ga-fotos-file-list-v2 li em {
    display: block;
    margin-top: 2px;
    color: #928575;
    font-size: 10.5px;
    font-style: normal;
    font-weight: 400;
}

.ga-fotos-file-list-v2 li.is-invalid i,
.ga-fotos-file-list-v2 li.is-invalid strong,
.ga-fotos-file-list-v2 li.is-invalid em {
    color: #9a332f;
}

.ga-fotos-bottom-row-v2 {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(245px, .95fr);
    gap: 14px;
    margin-top: auto;
    align-items: stretch;
}

.ga-fotos-quality-note-v2,
.ga-fotos-option-strip-v2 {
    min-height: 82px;
    border-radius: 9px;
}

.ga-fotos-quality-note-v2 {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    padding: 14px 15px;
    background: #fffaf2;
    border: 1px solid #e0cdb4;
}

.ga-fotos-quality-note-v2 i {
    margin-top: 2px;
    color: #c6922d;
    font-size: 16px;
}

.ga-fotos-quality-note-v2 strong {
    display: block;
    margin-bottom: 3px;
    color: #3b2a17;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.25;
}

.ga-fotos-quality-note-v2 span {
    display: block;
    color: #756b5d;
    font-size: 11.2px;
    font-weight: 400;
    line-height: 1.38;
}

.ga-fotos-quality-note-v2 a {
    display: inline-flex;
    margin-top: 7px;
    color: #b97911 !important;
    font-size: 11px;
    font-weight: 500;
    text-decoration: none !important;
}

.ga-fotos-quality-note-v2 a:hover {
    text-decoration: underline !important;
}

.ga-fotos-option-strip-v2 {
    margin: 0 !important;
    padding: 13px 13px 13px 15px;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 13px;
    background: #3b2818;
    color: #fff;
    cursor: pointer;
}

.ga-fotos-option-strip-v2 input {
    display: none;
}

.ga-fotos-option-strip-v2 > span:first-of-type {
    min-width: 0;
}

.ga-fotos-option-strip-v2 strong {
    display: block;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.25;
}

.ga-fotos-option-strip-v2 small {
    display: block;
    margin-top: 3px;
    color: rgba(255,255,255,.72);
    font-size: 10.5px;
    font-weight: 400;
    line-height: 1.3;
    text-transform: none;
    letter-spacing: 0;
}

.ga-fotos-option-strip-v2 .ga-switch-ui {
    width: 34px;
    height: 20px;
    flex: 0 0 34px;
    border-radius: 999px;
    background: rgba(255,255,255,.22);
}

.ga-fotos-option-strip-v2 .ga-switch-ui::after {
    top: 3px;
    left: 3px;
    width: 14px;
    height: 14px;
    background: #fff;
}

.ga-fotos-option-strip-v2 input:checked ~ .ga-switch-ui {
    background: linear-gradient(135deg, #c6922d, #e0b65a);
}

.ga-fotos-option-strip-v2 input:checked ~ .ga-switch-ui::after {
    left: 17px;
}

.ga-fotos-footer-v2 .btn-primary {
    min-width: 158px !important;
}

@media (max-width: 900px) {
    .ga-fotos-layout-v2 {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .ga-fotos-side-pane-v2 {
        padding: 22px 18px !important;
        border-right: 0 !important;
        border-bottom: 1px solid #e0d5c7 !important;
    }

    .ga-fotos-main-pane-v2 {
        padding: 22px 18px !important;
    }

    .ga-fotos-bottom-row-v2 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 820px) {
    .ga-fotos-dialog-v2 {
        width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    .ga-fotos-dropzone-v2 {
        min-height: 160px;
    }

    .ga-fotos-footer-v2 {
        height: auto;
        padding: 12px 16px !important;
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .ga-fotos-footer-actions-v2 {
        width: 100%;
    }

    .ga-fotos-footer-v2 .btn {
        flex: 1;
        min-width: 0 !important;
    }
}

/* =========================================================
   GraduApp — Modal proyecto v2
   Editar proyecto + retoque visual para ingreso
   Agregar al final de graduapp.css
   ========================================================= */

.ga-proyecto-dialog-v2 {
    width: min(980px, calc(100vw - 44px)) !important;
    max-width: 980px !important;
    margin: 18px auto !important;
}

.ga-proyecto-modal-v2 {
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 22px 70px rgba(16, 18, 24, .22) !important;
    border: 0 !important;
}

.ga-proyecto-topbar-v2 {
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 0 24px;
    background: #fff;
    border-bottom: 1px solid #e6ded2;
}

.ga-proyecto-breadcrumb-v2 {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: #9a8c7a;
    font-size: 11px;
    line-height: 1;
}

.ga-proyecto-breadcrumb-v2 span {
    font-size: 10px;
    font-weight: 500;
    color: #a28d6c;
}

.ga-proyecto-breadcrumb-v2 i {
    color: #c6922d;
    font-size: 9px;
}

.ga-proyecto-breadcrumb-v2 strong {
    color: #111827;
    font-size: 12px;
    font-weight: 600;
}

.ga-proyecto-actions-v2 {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
}

.ga-proyecto-top-btn-v2,
.ga-proyecto-icon-btn-v2 {
    height: 34px;
    border-radius: 6px;
    border: 1px solid #cfc7bc;
    background: #fff;
    color: #111827;
    padding: 0 15px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.ga-proyecto-top-btn-v2:hover,
.ga-proyecto-icon-btn-v2:hover {
    background: #faf8f4;
    border-color: #b9a98f;
    color: #7a5918;
}

.ga-proyecto-icon-btn-v2 {
    width: 34px;
    padding: 0;
    font-size: 20px;
    color: #8f98a8;
}

.ga-proyecto-body-v2 {
    padding: 0 !important;
    background: #f7f2ea !important;
}

.ga-proyecto-layout-v2 {
    display: grid;
    grid-template-columns: minmax(260px, 34%) minmax(0, 66%);
    min-height: 520px;
}

.ga-proyecto-side-pane-v2 {
    padding: 28px 30px 26px !important;
    background: #fbf7ef !important;
    border-right: 1px solid #e0d5c7 !important;
}

.ga-proyecto-main-pane-v2 {
    display: flex;
    flex-direction: column;
    padding: 28px 32px 22px !important;
    background: #f7f2ea !important;
}

.ga-proyecto-pane-label-v2,
.ga-proyecto-section-title-v2 span,
.ga-proyecto-main-pane-v2 .ga-form-field > label {
    display: block;
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-proyecto-pane-label-v2 {
    margin: 0 0 14px !important;
}

.ga-proyecto-side-intro-v2 {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 20px;
}

.ga-proyecto-side-icon-v2 {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.11);
    color: #b57e18;
    font-size: 18px;
}

.ga-proyecto-side-copy-v2 h3 {
    margin: 1px 0 7px;
    color: #1f2937;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.15;
}

.ga-proyecto-side-copy-v2 p {
    margin: 0;
    color: #756b5d;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.55;
}

.ga-proyecto-rule-list-v2 {
    display: grid;
    gap: 11px;
}

.ga-proyecto-rule-item-v2 {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 13px;
    border: 1px solid #e4d8ca;
    border-radius: 10px;
    background: rgba(255,255,255,.56);
}

.ga-proyecto-rule-item-v2 i {
    margin-top: 2px;
    color: #7fa043;
    font-size: 13px;
}

.ga-proyecto-rule-item-v2 strong {
    display: block;
    margin: 0 0 3px;
    color: #3b2a17;
    font-size: 12.2px;
    font-weight: 500;
    line-height: 1.25;
}

.ga-proyecto-rule-item-v2 span {
    display: block;
    color: #85796b;
    font-size: 11.3px;
    font-weight: 400;
    line-height: 1.38;
}

.ga-proyecto-section-title-v2 {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 17px;
}

.ga-proyecto-section-title-v2:after {
    content: "";
    height: 1px;
    flex: 1 1 auto;
    background: rgba(111, 91, 66, .16);
}

.ga-proyecto-section-title-spaced-v2 {
    margin-top: 10px;
}

.ga-proyecto-grid-v2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 12px;
    row-gap: 17px;
}

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

.ga-proyecto-main-pane-v2 .ga-form-field {
    margin-bottom: 0 !important;
}

.ga-proyecto-main-pane-v2 .ga-form-field > label {
    margin: 0 0 10px !important;
}

.ga-proyecto-main-pane-v2 .ga-form-field label small {
    color: #a9a096;
    font-size: 9.3px;
    font-weight: 600;
    letter-spacing: .06em;
}

.ga-proyecto-main-pane-v2 .form-control {
    height: 40px !important;
    border-radius: 5px !important;
    border: 1px solid #d8d0c6 !important;
    background: #fff !important;
    color: #1f2937 !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    padding: 0 13px !important;
    box-shadow: none !important;
}

.ga-proyecto-main-pane-v2 textarea.form-control {
    height: auto !important;
    min-height: 78px !important;
    padding: 11px 13px !important;
    line-height: 1.45 !important;
    resize: vertical;
}

.ga-proyecto-main-pane-v2 .form-control::placeholder {
    color: #b3a799 !important;
    font-weight: 400 !important;
}

.ga-proyecto-main-pane-v2 .form-control:focus {
    border-color: #c6922d !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.11) !important;
}

.ga-proyecto-main-pane-v2 .help-block {
    margin: 7px 0 0 !important;
    color: #8b8073 !important;
    font-size: 11.2px !important;
    font-weight: 400 !important;
    line-height: 1.35 !important;
}

.ga-proyecto-switch-strip-v2 {
    margin: 19px 0 2px !important;
    min-height: 58px;
    padding: 12px 14px 12px 16px;
    border-radius: 9px;
    background: #fffaf2;
    border: 1px solid #e0cdb4;
    color: #3b2a17;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    cursor: pointer;
}

.ga-proyecto-switch-strip-v2 input {
    display: none;
}

.ga-proyecto-switch-strip-v2 > span:first-of-type {
    min-width: 0;
}

.ga-proyecto-switch-strip-v2 strong {
    display: block;
    color: #3b2a17;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
}

.ga-proyecto-switch-strip-v2 small {
    display: block;
    margin-top: 3px;
    color: #8b755c;
    font-size: 10.6px;
    font-weight: 400;
    line-height: 1.25;
    text-transform: none;
    letter-spacing: 0;
}

.ga-proyecto-switch-strip-v2 .ga-switch-ui {
    width: 34px;
    height: 20px;
    flex: 0 0 34px;
    border-radius: 999px;
    background: rgba(17,24,39,.16);
}

.ga-proyecto-switch-strip-v2 .ga-switch-ui::after {
    top: 3px;
    left: 3px;
    width: 14px;
    height: 14px;
    background: #fff;
}

.ga-proyecto-switch-strip-v2 input:checked ~ .ga-switch-ui {
    background: linear-gradient(135deg, #c6922d, #e0b65a);
}

.ga-proyecto-switch-strip-v2 input:checked ~ .ga-switch-ui::after {
    left: 17px;
}

.ga-proyecto-observaciones-v2 {
    margin-bottom: 0 !important;
}

.ga-proyecto-footer-v2 {
    min-height: 54px;
    padding: 0 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    background: #fff !important;
    border-top: 1px solid #e6ded2 !important;
}

.ga-proyecto-status-v2 {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: #8c857c;
    font-size: 11px;
    font-weight: 400;
}

.ga-proyecto-status-v2 span {
    width: 5px;
    height: 5px;
    border-radius: 999px;
    background: #c6922d;
}

.ga-proyecto-footer-actions-v2 {
    display: flex;
    align-items: center;
    gap: 9px;
}

.ga-proyecto-footer-v2 .btn {
    height: 34px !important;
    min-width: 108px !important;
    padding: 0 14px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    box-shadow: none !important;
}

.ga-proyecto-footer-v2 .btn-default {
    background: #fff !important;
    border: 1px solid #cfc7bc !important;
    color: #111827 !important;
}

.ga-proyecto-footer-v2 .btn-default:hover {
    background: #faf8f4 !important;
    border-color: #b9a98f !important;
    color: #7a5918 !important;
}

.ga-proyecto-footer-v2 .btn-primary {
    min-width: 132px !important;
    background: #d6a541 !important;
    border: 1px solid #d6a541 !important;
    color: #fff !important;
}

.ga-proyecto-footer-v2 .btn-primary:hover {
    background: #c6922d !important;
    border-color: #c6922d !important;
    color: #fff !important;
    transform: none !important;
}

/* =========================================================
   Modal ingreso proyecto — retoque sin cambiar modal-proyecto.php
   Se activa desde graduapp.proyecto.js agregando ga-proyecto-ingreso-root-v2.
   ========================================================= */

.ga-proyecto-ingreso-root-v2 .modal-dialog {
    width: min(1040px, calc(100vw - 44px)) !important;
    max-width: 1040px !important;
    margin: 18px auto !important;
}

.ga-proyecto-ingreso-root-v2 .modal-content {
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 22px 70px rgba(16, 18, 24, .22) !important;
    border: 0 !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header {
    min-height: 56px !important;
    padding: 0 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    background: #fff !important;
    border-bottom: 1px solid #e6ded2 !important;
    color: #111827 !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header::after {
    display: none !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .modal-title {
    margin: 0 !important;
    color: #111827 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    padding: 0 !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .modal-title b {
    font-weight: 600 !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .modal-title i {
    color: #c6922d !important;
    margin-right: 6px;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .small {
    display: none !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .close {
    position: static !important;
    transform: none !important;
    width: 34px !important;
    height: 34px !important;
    line-height: 32px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    border: 1px solid #cfc7bc !important;
    background: #fff !important;
    color: #8f98a8 !important;
    opacity: 1 !important;
    font-size: 20px !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .close:hover {
    background: #faf8f4 !important;
    border-color: #b9a98f !important;
    color: #7a5918 !important;
}

.ga-proyecto-ingreso-root-v2 .modal-body {
    padding: 24px !important;
    background: #f7f2ea !important;
}

.ga-proyecto-ingreso-root-v2 #form-proyecto .form-control {
    height: 40px !important;
    border-radius: 5px !important;
    border: 1px solid #d8d0c6 !important;
    background: #fff !important;
    color: #1f2937 !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    padding: 0 13px !important;
    box-shadow: none !important;
}

.ga-proyecto-ingreso-root-v2 #form-proyecto textarea.form-control {
    height: auto !important;
    min-height: 78px !important;
    padding: 11px 13px !important;
    line-height: 1.45 !important;
}

.ga-proyecto-ingreso-root-v2 #form-proyecto label,
.ga-proyecto-ingreso-root-v2 #form-proyecto .control-label,
.ga-proyecto-ingreso-root-v2 #form-proyecto label.text-semibold {
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-proyecto-ingreso-root-v2 .wizard-steps {
    margin: 0 0 18px !important;
    padding: 0 !important;
    gap: 10px !important;
}

.ga-proyecto-ingreso-root-v2 .wizard-steps::before {
    display: none !important;
}

.ga-proyecto-ingreso-root-v2 .wizard-step-indicator {
    min-height: 38px !important;
    padding: 0 14px !important;
    border-radius: 6px !important;
    background: #fff !important;
    border: 1px solid #d8d0c6 !important;
    color: #8c857c !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.ga-proyecto-ingreso-root-v2 .wizard-step-indicator.active {
    background: #3b2818 !important;
    border-color: #3b2818 !important;
    color: #fff !important;
    box-shadow: none !important;
    transform: none !important;
}

.ga-proyecto-ingreso-root-v2 .wizard-step {
    padding: 20px 22px !important;
    border: 1px solid #e6ded2 !important;
    border-radius: 0 !important;
    background: #fff !important;
    box-shadow: none !important;
}

.ga-proyecto-ingreso-root-v2 .ga-producto-card,
.ga-proyecto-ingreso-root-v2 .tamano-card,
.ga-proyecto-ingreso-root-v2 .plantilla-card {
    border-radius: 8px !important;
    border: 1px solid #ded5c9 !important;
    background: #fff !important;
    box-shadow: none !important;
}

.ga-proyecto-ingreso-root-v2 .ga-producto-card:hover,
.ga-proyecto-ingreso-root-v2 .tamano-card:hover,
.ga-proyecto-ingreso-root-v2 .plantilla-card:hover {
    border-color: #c6922d !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.08) !important;
    transform: none !important;
}

.ga-proyecto-ingreso-root-v2 .ga-producto-card.active,
.ga-proyecto-ingreso-root-v2 .tamano-card.active,
.ga-proyecto-ingreso-root-v2 .plantilla-card.active {
    border-color: #c6922d !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.12) !important;
    transform: none !important;
}

.ga-proyecto-ingreso-root-v2 .tamano-card::before {
    display: none !important;
}

.ga-proyecto-ingreso-root-v2 .tamano-card .text-semibold,
.ga-proyecto-ingreso-root-v2 .plantilla-card-title,
.ga-proyecto-ingreso-root-v2 .ga-producto-card strong,
.ga-proyecto-ingreso-root-v2 .ga-producto-card h5 {
    font-weight: 600 !important;
}

.ga-proyecto-ingreso-root-v2 .plantilla-card img {
    border-radius: 5px !important;
}

.ga-proyecto-ingreso-root-v2 .modal-footer {
    min-height: 54px !important;
    padding: 0 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 9px !important;
    background: #fff !important;
    border-top: 1px solid #e6ded2 !important;
}

.ga-proyecto-ingreso-root-v2 .modal-footer .btn,
.ga-proyecto-ingreso-root-v2 .btn-wizard-anterior,
.ga-proyecto-ingreso-root-v2 .btn-wizard-siguiente,
.ga-proyecto-ingreso-root-v2 .btn-proyecto-guardar {
    height: 34px !important;
    min-width: 108px !important;
    padding: 0 14px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: none !important;
}

.ga-proyecto-ingreso-root-v2 .modal-footer .btn-default,
.ga-proyecto-ingreso-root-v2 .btn-wizard-anterior {
    background: #fff !important;
    border: 1px solid #cfc7bc !important;
    color: #111827 !important;
}

.ga-proyecto-ingreso-root-v2 .btn-wizard-siguiente,
.ga-proyecto-ingreso-root-v2 .btn-proyecto-guardar {
    background: #d6a541 !important;
    border: 1px solid #d6a541 !important;
    color: #fff !important;
}

.ga-proyecto-ingreso-root-v2 .btn-wizard-siguiente:hover,
.ga-proyecto-ingreso-root-v2 .btn-proyecto-guardar:hover {
    background: #c6922d !important;
    border-color: #c6922d !important;
    color: #fff !important;
    transform: none !important;
}

@media (max-width: 820px) {
    .ga-proyecto-dialog-v2,
    .ga-proyecto-ingreso-root-v2 .modal-dialog {
        width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    .ga-proyecto-topbar-v2 {
        height: auto;
        min-height: 56px;
        padding: 12px 16px;
        align-items: flex-start;
        flex-direction: column;
    }

    .ga-proyecto-actions-v2 {
        width: 100%;
    }

    .ga-proyecto-top-btn-v2 {
        flex: 1;
    }

    .ga-proyecto-layout-v2 {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .ga-proyecto-side-pane-v2 {
        padding: 22px 18px !important;
        border-right: 0 !important;
        border-bottom: 1px solid #e0d5c7 !important;
    }

    .ga-proyecto-main-pane-v2 {
        padding: 22px 18px !important;
    }

    .ga-proyecto-grid-v2 {
        grid-template-columns: 1fr;
    }

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

    .ga-proyecto-footer-v2,
    .ga-proyecto-ingreso-root-v2 .modal-footer {
        height: auto;
        padding: 12px 16px !important;
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .ga-proyecto-footer-actions-v2 {
        width: 100%;
    }

    .ga-proyecto-footer-v2 .btn,
    .ga-proyecto-ingreso-root-v2 .modal-footer .btn {
        flex: 1;
        min-width: 0 !important;
    }

    .ga-proyecto-ingreso-root-v2 .wizard-steps {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    .ga-proyecto-ingreso-root-v2 .wizard-step {
        padding: 18px !important;
    }
}
/* =========================================================
   GraduApp — Modales extra proyecto v2
   Cambio de plantilla + vista previa, alineados al estilo limpio
   ========================================================= */

/* ------------------------------
   Cambio de plantilla
   ------------------------------ */
#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-dialog {
    width: min(1160px, calc(100vw - 34px)) !important;
    max-width: 1160px !important;
    margin: 18px auto !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-modal {
    border: 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #f7f2ea !important;
    box-shadow: 0 26px 80px rgba(17, 24, 39, .28) !important;
}

.ga-template-v2-topbar,
.ga-preview-v2-topbar {
    min-height: 54px;
    padding: 0 16px 0 24px;
    background: #ffffff;
    border-bottom: 1px solid #e4d8c8;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.ga-template-v2-topbar:before,
.ga-preview-v2-topbar:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--ga-gold, #c6922d), transparent);
}

.ga-template-v2-topbar,
.ga-preview-v2-topbar {
    position: relative;
}

.ga-template-v2-breadcrumb,
.ga-preview-v2-breadcrumb {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: #9b8d7d;
    font-size: 11px;
    font-weight: 500;
}

.ga-template-v2-breadcrumb i,
.ga-preview-v2-breadcrumb i {
    color: #c6922d;
    font-size: 10px;
}

.ga-template-v2-breadcrumb strong,
.ga-preview-v2-breadcrumb strong {
    color: #1f2937;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ga-template-v2-actions,
.ga-preview-v2-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
}

.ga-template-v2-close,
.ga-preview-v2-close {
    width: 34px;
    height: 34px;
    border-radius: 7px;
    border: 1px solid #d9cec0;
    background: #fff;
    color: #9b8d7d;
    font-size: 22px;
    font-weight: 500;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all .16s ease;
}

.ga-template-v2-close:hover,
.ga-preview-v2-close:hover {
    color: #1f2937;
    border-color: #c6922d;
    background: #fff8ea;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-body {
    padding: 0 !important;
    background: #f7f2ea !important;
}

.ga-template-v2-layout {
    display: grid;
    grid-template-columns: 310px minmax(0, 1fr);
    min-height: 560px;
}

.ga-template-v2-side {
    padding: 28px 28px 24px !important;
    background: #fbf7ef !important;
    border-right: 1px solid #e0d5c7;
}

.ga-template-v2-main {
    min-width: 0;
    padding: 28px 30px 24px !important;
    background: #f7f2ea !important;
}

.ga-template-v2-label,
.ga-preview-v2-label {
    display: block;
    margin: 0 0 14px !important;
    color: #9d9388 !important;
    font-size: 9.8px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.ga-template-v2-intro,
.ga-preview-v2-intro {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 18px;
}

.ga-template-v2-icon,
.ga-preview-v2-icon {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,146,45,.11);
    color: #b57e18;
    font-size: 18px;
}

.ga-template-v2-intro h3,
.ga-preview-v2-intro h3 {
    margin: 1px 0 7px;
    color: #1f2937;
    font-size: 23px;
    font-weight: 500;
    line-height: 1.15;
}

.ga-template-v2-intro p,
.ga-preview-v2-intro p {
    margin: 0;
    color: #756b5d;
    font-size: 12.5px;
    font-weight: 400;
    line-height: 1.5;
}

.ga-template-v2-summary {
    display: grid;
    gap: 9px;
    margin-bottom: 16px;
}

.ga-template-v2-summary > div {
    padding: 11px 12px;
    border: 1px solid #e4d8ca;
    background: rgba(255,255,255,.58);
    border-radius: 8px;
}

.ga-template-v2-summary .two-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 0;
    border: 0;
    background: transparent;
}

.ga-template-v2-summary .two-cols > div {
    padding: 11px 12px;
    border: 1px solid #e4d8ca;
    background: rgba(255,255,255,.58);
    border-radius: 8px;
}

.ga-template-v2-summary span {
    display: block;
    margin-bottom: 4px;
    color: #a69b90;
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.ga-template-v2-summary strong {
    display: block;
    color: #2d2117;
    font-size: 12.5px;
    font-weight: 500;
    line-height: 1.35;
    word-break: break-word;
}

.ga-template-v2-note {
    display: grid;
    grid-template-columns: 24px minmax(0,1fr);
    gap: 10px;
    padding: 13px 14px;
    margin: 0 0 14px;
    border-radius: 9px;
    background: #fff8e8;
    border: 1px solid #e8cf99;
    color: #6f4f13;
}

.ga-template-v2-note.is-locked {
    background: #fff1ef;
    border-color: #efc8c2;
    color: #8b2f36;
}

.ga-template-v2-note i {
    margin-top: 2px;
    color: #c6922d;
}

.ga-template-v2-note.is-locked i {
    color: #8b2f36;
}

.ga-template-v2-note strong {
    display: block;
    margin: 0 0 3px;
    color: inherit;
    font-size: 12.5px;
    font-weight: 600;
}

.ga-template-v2-note span {
    display: block;
    color: inherit;
    opacity: .78;
    font-size: 11.8px;
    font-weight: 400;
    line-height: 1.42;
}

.ga-template-v2-checks,
.ga-preview-v2-checks {
    display: grid;
    gap: 9px;
}

.ga-template-v2-checks > div,
.ga-preview-v2-checks > div {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr);
    gap: 9px;
    align-items: start;
    padding: 10px 11px;
    border-radius: 8px;
    background: rgba(255,255,255,.56);
    border: 1px solid #e4d8ca;
    color: #726759;
    font-size: 11.8px;
    line-height: 1.35;
}

.ga-template-v2-checks i,
.ga-preview-v2-checks i {
    color: #668d2a;
    font-size: 12px;
    margin-top: 2px;
}

.ga-template-v2-main-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-end;
    margin: 0 0 18px;
}

.ga-template-v2-main-head span {
    display: block;
    margin-bottom: 4px;
    color: #9d9388;
    font-size: 9.8px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.ga-template-v2-main-head strong {
    display: block;
    color: #1f2937;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.15;
}

.ga-template-v2-main-head small {
    color: #85796b;
    font-size: 11.8px;
    line-height: 1.35;
}

.ga-template-v2-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 0 !important;
}

.ga-template-v2-col {
    min-width: 0;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-card,
#modal-cambiar-plantilla.ga-template-v2-root .ga-template-change-card {
    position: relative;
    width: 100%;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid #ddd2c4 !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    text-align: left;
    cursor: pointer;
    overflow: hidden;
    box-shadow: 0 8px 20px rgba(17,24,39,.045) !important;
    transition: all .16s ease !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-card:hover {
    border-color: #c6922d !important;
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(198,146,45,.13) !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-card.active {
    border-color: #c6922d !important;
    box-shadow: 0 0 0 3px rgba(198,146,45,.13), 0 12px 24px rgba(198,146,45,.13) !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-card.is-current {
    cursor: not-allowed;
    opacity: .68;
    background: #f5f2ed !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-card.is-current:hover {
    transform: none;
    border-color: #ddd2c4 !important;
    box-shadow: 0 8px 20px rgba(17,24,39,.045) !important;
}

.ga-template-v2-card-check {
    position: absolute;
    z-index: 3;
    top: 10px;
    left: 10px;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #c6922d;
    color: #fff;
    opacity: 0;
    transform: scale(.88);
    transition: all .16s ease;
}

.ga-template-v2-card.active .ga-template-v2-card-check {
    opacity: 1;
    transform: scale(1);
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-thumb,
#modal-cambiar-plantilla.ga-template-v2-root .ga-template-change-thumb {
    width: 100%;
    height: 170px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #eee8dd !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-change-thumb-vertical {
    height: 210px !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-thumb img {
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    object-fit: cover;
    display: block;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-change-thumb-vertical img {
    object-fit: contain;
    background: #eee8dd;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-current-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(31,41,55,.88);
    color: #fff;
    font-size: 10px;
    font-style: normal;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.ga-template-v2-card-body {
    display: block;
    padding: 12px 13px 13px;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-change-title {
    display: block;
    margin: 0 0 8px !important;
    color: #1f2937 !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    line-height: 1.25;
    text-align: left !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-card-meta,
#modal-cambiar-plantilla.ga-template-v2-root .ga-template-change-meta {
    display: flex !important;
    flex-wrap: wrap;
    gap: 5px;
    margin: 0 !important;
    text-align: left !important;
    color: inherit !important;
}

.ga-template-v2-card-meta em {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 3px 7px;
    border-radius: 999px;
    background: #f6f2eb;
    border: 1px solid #e4d8ca;
    color: #766b5d;
    font-size: 10.5px;
    font-style: normal;
    font-weight: 500;
    line-height: 1.2;
    text-transform: none;
}

.ga-template-v2-empty {
    min-height: 280px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 28px;
    border: 1px dashed #d9cdbc;
    background: rgba(255,255,255,.58);
    color: #85796b;
    text-align: center;
    border-radius: 9px;
}

.ga-template-v2-empty i {
    color: #c6922d;
    font-size: 30px;
}

.ga-template-v2-empty strong {
    color: #1f2937;
    font-size: 15px;
    font-weight: 600;
}

.ga-template-v2-empty span {
    max-width: 420px;
    font-size: 12.5px;
    line-height: 1.45;
}

.ga-template-v2-empty.is-warning i,
.ga-template-v2-empty.is-warning strong {
    color: #8b2f36;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-footer {
    min-height: 56px;
    padding: 10px 20px !important;
    border-top: 1px solid #e4d8c8 !important;
    background: #ffffff !important;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.ga-template-v2-status,
.ga-preview-v2-status {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: #85796b;
    font-size: 11.5px;
    font-weight: 400;
}

.ga-template-v2-status > span,
.ga-preview-v2-status > span {
    width: 5px;
    height: 5px;
    border-radius: 999px;
    background: #c6922d;
}

.ga-template-v2-status.is-dirty {
    color: #7a5918;
    font-weight: 500;
}

.ga-template-v2-footer-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-footer .btn,
#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-footer .btn {
    height: 40px !important;
    min-width: 118px !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 18px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-footer .btn-default,
#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-footer .btn-default {
    color: #5f6774 !important;
    background: #fff !important;
    border: 1px solid #d8d0c6 !important;
    box-shadow: none !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-footer .btn-primary {
    color: #fff !important;
    background: linear-gradient(135deg, #c6922d, #d9b35b) !important;
    border: 0 !important;
    box-shadow: 0 8px 18px rgba(198,146,45,.20) !important;
}

#modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-footer .btn-primary:disabled {
    opacity: .45;
    cursor: not-allowed;
    box-shadow: none !important;
}

/* ------------------------------
   Vista previa
   ------------------------------ */
#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-dialog {
    width: min(1280px, calc(100vw - 28px)) !important;
    max-width: 1280px !important;
    margin: 14px auto !important;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-modal {
    min-height: min(760px, calc(100vh - 28px));
    max-height: calc(100vh - 28px);
    border: 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: #f7f2ea !important;
    box-shadow: 0 30px 90px rgba(17,24,39,.32) !important;
    display: flex;
    flex-direction: column;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-body {
    flex: 1 1 auto;
    min-height: 0;
    padding: 0 !important;
    background: #f7f2ea !important;
    overflow: hidden;
}

.ga-preview-v2-layout {
    height: 100%;
    min-height: 0;
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
}

.ga-preview-v2-side {
    min-height: 0;
    padding: 28px 28px 24px !important;
    background: #fbf7ef !important;
    border-right: 1px solid #e0d5c7;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.ga-preview-v2-main {
    min-width: 0;
    min-height: 0;
    padding: 28px 30px 22px !important;
    background: #f7f2ea !important;
    display: flex;
    flex-direction: column;
}

.ga-preview-v2-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 0 0 16px;
}

.ga-preview-v2-pills em {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 4px 8px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #e4d8ca;
    color: #766b5d;
    font-size: 10.8px;
    font-style: normal;
    font-weight: 500;
    line-height: 1.2;
}

.ga-preview-v2-quality {
    min-height: 0;
    margin-top: 14px;
    overflow: auto;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-quality-warning {
    margin: 0 !important;
    padding: 13px 14px !important;
    border-radius: 8px !important;
    background: #fff8e8 !important;
    border: 1px solid #e8cf99 !important;
    color: #6f4f13 !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
    box-shadow: none !important;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-quality-warning[style*="display:none"],
#modal-cuadro-preview.ga-preview-v2-root .ga-preview-quality-warning[style*="display: none"] {
    display: none !important;
}

.ga-preview-v2-main-head {
    flex: 0 0 auto;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 14px;
    margin: 0 0 14px;
}

.ga-preview-v2-main-head span {
    color: #1f2937;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.ga-preview-v2-main-head small {
    color: #85796b;
    font-size: 11.8px;
    line-height: 1.35;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-stage,
#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-stage {
    position: relative;
    flex: 1 1 auto;
    min-height: 420px;
    max-height: none;
    padding: 18px !important;
    border-radius: 9px !important;
    overflow: auto !important;
    background:
        radial-gradient(circle at center, rgba(198,146,45,.08), transparent 45%),
        linear-gradient(135deg, #151515 0%, #2a2a2a 100%) !important;
    border: 1px solid rgba(198,146,45,.18) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#modal-cuadro-preview.ga-preview-v2-root #cuadro-preview-img,
#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: calc(100vh - 250px) !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin: 0 auto !important;
    border-radius: 6px !important;
    background: #fff !important;
    box-shadow: 0 22px 52px rgba(0,0,0,.32) !important;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-stage.is-template-fit #cuadro-preview-img {
    aspect-ratio: var(--ga-template-aspect, auto) !important;
    width: min(100%, calc((100vh - 250px) * var(--ga-template-ratio, 1.3))) !important;
    max-height: calc(100vh - 250px) !important;
    object-fit: cover !important;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-stage.is-template-fit.is-logo-fit #cuadro-preview-img {
    object-fit: contain !important;
    padding: 16px;
    background: rgba(255,255,255,.92) !important;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-loader {
    width: min(340px, 90%);
    padding: 22px 24px;
    border-radius: 9px;
    background: rgba(255,255,255,.94);
    border: 1px solid rgba(198,146,45,.22);
    color: #1f2937;
    text-align: center;
    box-shadow: 0 18px 44px rgba(0,0,0,.20);
}

.ga-preview-v2-loader-icon {
    width: 44px;
    height: 44px;
    margin: 0 auto 10px;
    border-radius: 12px;
    background: rgba(198,146,45,.12);
    border: 1px solid rgba(198,146,45,.28);
    color: #c6922d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-loader strong {
    display: block;
    margin: 0 0 5px;
    color: #1f2937;
    font-size: 14px;
    font-weight: 600;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-loader span {
    display: block;
    color: #756b5d;
    font-size: 12px;
    line-height: 1.4;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-error {
    max-width: 520px;
    padding: 14px 16px;
    border-radius: 8px;
    background: #fde8ea;
    border: 1px solid #f0bfc4;
    color: #8b2f36;
    text-align: center;
    font-size: 12.5px;
    font-weight: 500;
}

.ga-preview-v2-caption {
    flex: 0 0 auto;
    min-height: 38px;
    margin-top: 12px;
    padding: 10px 13px;
    border-radius: 8px;
    background: #fff;
    border: 1px solid #e4d8ca;
    color: #756b5d;
    font-size: 11.8px;
    line-height: 1.35;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.ga-preview-v2-caption i {
    color: #c6922d;
}

#modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-footer {
    min-height: 56px;
    padding: 10px 20px !important;
    border-top: 1px solid #e4d8c8 !important;
    background: #ffffff !important;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

@media (max-width: 991px) {
    #modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-dialog,
    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-dialog {
        width: calc(100vw - 18px) !important;
        max-width: calc(100vw - 18px) !important;
        margin: 9px auto !important;
    }

    #modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-modal,
    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-modal {
        max-height: calc(100vh - 18px);
        overflow: auto !important;
    }

    .ga-template-v2-layout,
    .ga-preview-v2-layout {
        grid-template-columns: 1fr;
        min-height: 0;
        height: auto;
    }

    .ga-template-v2-side,
    .ga-preview-v2-side {
        border-right: 0;
        border-bottom: 1px solid #e0d5c7;
        overflow: visible;
    }

    .ga-template-v2-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-body {
        overflow: auto;
    }

    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-stage,
    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-stage {
        min-height: 360px;
    }

    #modal-cuadro-preview.ga-preview-v2-root #cuadro-preview-img,
    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-img {
        max-height: 58vh !important;
    }
}

@media (max-width: 640px) {
    .ga-template-v2-topbar,
    .ga-preview-v2-topbar {
        padding-left: 16px;
    }

    .ga-template-v2-side,
    .ga-template-v2-main,
    .ga-preview-v2-side,
    .ga-preview-v2-main {
        padding: 20px 16px !important;
    }

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

    .ga-template-v2-main-head,
    .ga-preview-v2-main-head,
    #modal-cambiar-plantilla.ga-template-v2-root .ga-template-v2-footer,
    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .ga-template-v2-footer-actions {
        width: 100%;
    }

    .ga-template-v2-footer-actions .btn,
    #modal-cuadro-preview.ga-preview-v2-root .ga-preview-v2-footer .btn {
        flex: 1 1 auto;
        width: 100%;
    }

    .ga-template-v2-summary .two-cols {
        grid-template-columns: 1fr;
    }
}
/* =========================================================
   GraduApp — Fix header modal Nuevo Proyecto
   Corrige orden visual: título a la izquierda, cerrar a la derecha
   ========================================================= */

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header {
    justify-content: flex-start !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .modal-title {
    order: 1 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    text-align: left !important;
    display: flex !important;
    align-items: center !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .close {
    order: 2 !important;
    flex: 0 0 34px !important;
    margin-left: auto !important;
    position: static !important;
    transform: none !important;
}

.ga-proyecto-ingreso-root-v2 .modal-header.graduapp-header .small {
    order: 3 !important;
    display: none !important;
}


/* =========================================================
   GraduApp — Fix menú sistema en móvil
   Corrige navbar colapsable en dashboard/proyectos/detalle.
   ========================================================= */
@media (max-width: 768px) {
    body.ga-dashboard-v2 .navbar.navbar-graduapp,
    body.ga-proyectos-v4 .navbar.navbar-graduapp,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp,
    body.main-bg-no .navbar.navbar-graduapp {
        height: auto !important;
        min-height: 46px !important;
        line-height: normal !important;
        overflow: visible !important;
        z-index: 1100 !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-header,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-header,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-header,
    body.main-bg-no .navbar.navbar-graduapp .navbar-header {
        height: 46px !important;
        min-height: 46px !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-brand,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-brand,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-brand,
    body.main-bg-no .navbar.navbar-graduapp .navbar-brand,
    body.ga-dashboard-v2 .navbar.navbar-graduapp .ga-navbar-mobile-toggle,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .ga-navbar-mobile-toggle,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .ga-navbar-mobile-toggle,
    body.main-bg-no .navbar.navbar-graduapp .ga-navbar-mobile-toggle {
        height: 46px !important;
        min-height: 46px !important;
        line-height: 46px !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
        display: flex !important;
        align-items: center !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse,
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse {
        clear: both !important;
        width: 100% !important;
        max-height: calc(100vh - 46px) !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        background: #111820 !important;
        border-top: 1px solid rgba(255,255,255,.08) !important;
        border-bottom: 1px solid rgba(198,146,45,.45) !important;
        box-shadow: 0 18px 36px rgba(0,0,0,.28) !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse.collapse:not(.in),
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse.collapse:not(.in),
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse.collapse:not(.in),
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse.collapse:not(.in) {
        display: none !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse.collapse.in,
    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse.collapsing,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse.collapse.in,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse.collapsing,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse.collapse.in,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse.collapsing,
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse.collapse.in,
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse.collapsing {
        display: block !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse .navbar-nav,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse .navbar-nav,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse .navbar-nav,
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse .navbar-nav {
        float: none !important;
        margin: 0 !important;
        padding: 8px 0 !important;
        width: 100% !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li,
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li {
        float: none !important;
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li > a,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li > a,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li > a,
    body.main-bg-no .navbar.navbar-graduapp .navbar-collapse .navbar-nav > li > a {
        width: 100% !important;
        height: 44px !important;
        min-height: 44px !important;
        line-height: 44px !important;
        padding: 0 20px !important;
        display: flex !important;
        justify-content: flex-start !important;
        align-items: center !important;
        gap: 9px !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .navbar-right,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .navbar-right,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .navbar-right,
    body.main-bg-no .navbar.navbar-graduapp .navbar-right {
        float: none !important;
        margin: 0 !important;
    }

    body.ga-dashboard-v2 .navbar.navbar-graduapp .dropdown-user .dropdown-menu,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .dropdown-user .dropdown-menu,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .dropdown-user .dropdown-menu,
    body.main-bg-no .navbar.navbar-graduapp .dropdown-user .dropdown-menu,
    body.ga-dashboard-v2 .navbar.navbar-graduapp .ga-navbar-admin-dropdown,
    body.ga-proyectos-v4 .navbar.navbar-graduapp .ga-navbar-admin-dropdown,
    body.ga-proyecto-detalle-v2 .navbar.navbar-graduapp .ga-navbar-admin-dropdown,
    body.main-bg-no .navbar.navbar-graduapp .ga-navbar-admin-dropdown {
        position: static !important;
        float: none !important;
        width: 100% !important;
        min-width: 0 !important;
        margin: 0 !important;
        border-radius: 0 !important;
        border-left: 0 !important;
        border-right: 0 !important;
        background: #141922 !important;
        box-shadow: none !important;
    }
}

/* =========================================================
   Landing IA pública - Crear cuadro con IA
   ========================================================= */
.ga-landing-ia-page {
  margin: 0;
  min-height: 100vh;
  font-family: 'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:
    radial-gradient(circle at 10% 0%, rgba(255,112,174,.20), transparent 28%),
    radial-gradient(circle at 88% 6%, rgba(103,91,255,.22), transparent 28%),
    #fbf7ff;
  color: #17182f;
}

.ga-landing-ia-page * { box-sizing: border-box; }

.ga-landing-ia-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px clamp(18px, 4vw, 52px);
  backdrop-filter: blur(16px);
  background: rgba(251,247,255,.78);
  border-bottom: 1px solid rgba(111,91,255,.10);
}

.ga-landing-ia-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #16182d;
  text-decoration: none !important;
}

.ga-landing-ia-brand span {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: #fff;
  font-weight: 900;
  background: linear-gradient(135deg, #6f5bff, #ff70ae);
  box-shadow: 0 12px 28px rgba(111,91,255,.25);
}

.ga-landing-ia-brand strong {
  font-size: 18px;
  font-weight: 900;
}

.ga-landing-ia-nav nav {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ga-landing-ia-nav nav a {
  color: #4e496a;
  text-decoration: none !important;
  font-size: 13px;
  font-weight: 800;
  padding: 9px 12px;
  border-radius: 999px;
  transition: .2s ease;
}

.ga-landing-ia-nav nav a:hover {
  color: #6f5bff;
  background: rgba(111,91,255,.08);
}

.ga-landing-ia-hero,
.ga-landing-ia-how,
.ga-landing-ia-builder,
.ga-landing-ia-result,
.ga-landing-ia-pricing {
  width: min(1180px, calc(100vw - 36px));
  margin-left: auto;
  margin-right: auto;
}

.ga-landing-ia-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .7fr);
  gap: 30px;
  align-items: center;
  padding: 52px 0 34px;
}

.ga-landing-ia-kicker,
.ga-landing-ia-section-head span,
.ga-landing-ia-builder-copy > span,
.ga-landing-ia-result-copy > span {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(111,91,255,.10);
  color: #6f5bff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.ga-landing-ia-hero h1 {
  max-width: 720px;
  margin: 0;
  color: #111428;
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(42px, 5vw, 76px);
  line-height: .95;
  letter-spacing: -.04em;
}

.ga-landing-ia-hero p {
  max-width: 680px;
  margin: 20px 0 0;
  color: #5f5a79;
  font-size: 17px;
  line-height: 1.72;
}

.ga-landing-ia-actions,
.ga-landing-ia-result-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.ga-landing-ia-btn,
.ga-landing-ia-generate,
.ga-landing-ia-lead-form button {
  min-height: 50px;
  border: 0;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 0 20px;
  font-weight: 900;
  font-size: 14px;
  text-decoration: none !important;
  transition: .2s ease;
  cursor: pointer;
}

.ga-landing-ia-btn.primary,
.ga-landing-ia-generate,
.ga-landing-ia-lead-form button {
  background: linear-gradient(135deg, #6f5bff 0%, #ff70ae 100%);
  color: #fff !important;
  box-shadow: 0 16px 34px rgba(111,91,255,.26);
}

.ga-landing-ia-btn.primary:hover,
.ga-landing-ia-generate:hover,
.ga-landing-ia-lead-form button:hover {
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 20px 42px rgba(111,91,255,.34);
}

.ga-landing-ia-btn.ghost {
  background: #fff;
  color: #4a4569 !important;
  border: 1px solid rgba(111,91,255,.14);
}

.ga-landing-ia-btn.ghost:hover {
  color: #6f5bff !important;
  border-color: rgba(111,91,255,.28);
  transform: translateY(-1px);
}

.ga-landing-ia-proof {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 22px;
}

.ga-landing-ia-proof span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 12px;
  border-radius: 999px;
  background: #fff;
  color: #514b6d;
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 8px 20px rgba(47,35,88,.06);
}

.ga-landing-ia-phone {
  border-radius: 34px;
  padding: 16px;
  background: #111428;
  box-shadow: 0 28px 70px rgba(22,24,50,.26);
  transform: rotate(2deg);
}

.ga-landing-ia-phone-top {
  display: flex;
  gap: 6px;
  padding: 2px 0 12px;
}

.ga-landing-ia-phone-top span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255,255,255,.22);
}

.ga-landing-ia-poster {
  position: relative;
  min-height: 430px;
  border-radius: 26px;
  overflow: hidden;
  padding: 28px;
  color: #fff;
  background: linear-gradient(145deg, #3b2aff 0%, #ff4d9b 55%, #ffd36b 100%);
}

.ga-landing-ia-poster .mock-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(8px);
  opacity: .75;
}

.ga-landing-ia-poster .mock-glow.one {
  width: 150px;
  height: 150px;
  right: -30px;
  top: 24px;
  background: rgba(255,255,255,.35);
}

.ga-landing-ia-poster .mock-glow.two {
  width: 180px;
  height: 180px;
  left: -44px;
  bottom: 20px;
  background: rgba(108,255,222,.24);
}

.mock-photo-row {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 110px;
}

.mock-photo-row span {
  height: 95px;
  border-radius: 22px;
  background: rgba(255,255,255,.28);
  border: 1px solid rgba(255,255,255,.30);
}

.ga-landing-ia-poster strong {
  position: relative;
  z-index: 1;
  display: block;
  margin-top: 28px;
  font-size: 32px;
  line-height: 1;
  font-weight: 900;
}

.ga-landing-ia-poster small {
  position: relative;
  z-index: 1;
  display: block;
  margin-top: 8px;
  font-size: 15px;
  font-weight: 800;
  color: rgba(255,255,255,.80);
}

.ga-landing-ia-phone-caption {
  padding: 16px 6px 4px;
}

.ga-landing-ia-phone-caption strong {
  display: block;
  color: #fff;
  font-size: 16px;
}

.ga-landing-ia-phone-caption span {
  display: block;
  color: rgba(255,255,255,.58);
  margin-top: 4px;
  line-height: 1.5;
}

.ga-landing-ia-how,
.ga-landing-ia-builder,
.ga-landing-ia-result,
.ga-landing-ia-pricing {
  padding: 52px 0;
}

.ga-landing-ia-section-head {
  text-align: center;
  margin-bottom: 24px;
}

.ga-landing-ia-section-head h2,
.ga-landing-ia-builder-copy h2,
.ga-landing-ia-result-copy h2 {
  margin: 0;
  color: #15172e;
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.05;
  letter-spacing: -.03em;
}

.ga-landing-ia-how-grid,
.ga-landing-ia-price-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.ga-landing-ia-how-grid article,
.ga-landing-ia-price-grid article,
.ga-landing-ia-form,
.ga-landing-ia-result,
.ga-landing-ia-alert-soft {
  background: #fff;
  border: 1px solid rgba(111,91,255,.12);
  border-radius: 28px;
  box-shadow: 0 18px 42px rgba(47,35,88,.06);
}

.ga-landing-ia-how-grid article,
.ga-landing-ia-price-grid article {
  padding: 24px;
}

.ga-landing-ia-how-grid article i {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  color: #fff;
  background: linear-gradient(135deg, #6f5bff, #ff70ae);
  font-size: 22px;
  margin-bottom: 16px;
}

.ga-landing-ia-how-grid article strong,
.ga-landing-ia-price-grid article h3 {
  display: block;
  color: #17182f;
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 8px;
}

.ga-landing-ia-how-grid article p,
.ga-landing-ia-price-grid article p,
.ga-landing-ia-builder-copy p,
.ga-landing-ia-result-copy p {
  color: #625d7c;
  line-height: 1.68;
  margin: 0;
}

.ga-landing-ia-builder,
.ga-landing-ia-result {
  display: grid;
  grid-template-columns: minmax(0, .75fr) minmax(0, 1.15fr);
  gap: 22px;
  align-items: start;
}

.ga-landing-ia-builder-copy {
  position: sticky;
  top: 96px;
}

.ga-landing-ia-alert-soft {
  display: flex;
  gap: 12px;
  padding: 16px;
  margin-top: 22px;
  background: #fffaf0;
  border-color: rgba(198,146,45,.24);
}

.ga-landing-ia-alert-soft i {
  color: #c6922d;
  font-size: 22px;
}

.ga-landing-ia-alert-soft strong {
  display: block;
  color: #463710;
  margin-bottom: 4px;
}

.ga-landing-ia-alert-soft small {
  color: #735d20;
  line-height: 1.5;
}

.ga-landing-ia-form {
  padding: 24px;
}

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

.ga-landing-ia-form .field.wide,
.ga-landing-ia-form .field.full {
  grid-column: 1 / -1;
}

.ga-landing-ia-form label:not(.ga-landing-ia-upload):not(.ga-landing-ia-check) {
  display: block;
  color: #81799a;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 7px;
}

.ga-landing-ia-form input[type="text"],
.ga-landing-ia-form input[type="number"],
.ga-landing-ia-form select,
.ga-landing-ia-form textarea,
.ga-landing-ia-lead-form input {
  width: 100%;
  border: 1px solid rgba(111,91,255,.16);
  border-radius: 16px;
  background: #fbf9ff;
  color: #17182f;
  min-height: 48px;
  padding: 0 14px;
  outline: none;
  box-shadow: none;
}

.ga-landing-ia-form textarea {
  padding-top: 12px;
  min-height: 94px;
  resize: vertical;
}

.ga-landing-ia-form input:focus,
.ga-landing-ia-form select:focus,
.ga-landing-ia-form textarea:focus,
.ga-landing-ia-lead-form input:focus {
  border-color: #8a73ff;
  box-shadow: 0 0 0 4px rgba(111,91,255,.10);
  background: #fff;
}

.ga-landing-ia-upload {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  min-height: 172px;
  padding: 20px;
  margin: 16px 0;
  border-radius: 24px;
  border: 1px dashed rgba(111,91,255,.32);
  background: linear-gradient(135deg, #f1f4ff, #fff5fb);
  cursor: pointer;
  overflow: hidden;
}

.ga-landing-ia-upload input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.ga-landing-ia-upload i {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  color: #fff;
  background: linear-gradient(135deg, #6f5bff, #ff70ae);
  font-size: 22px;
  margin-bottom: 14px;
}

.ga-landing-ia-upload strong {
  display: block;
  color: #16182e;
  font-size: 18px;
  font-weight: 900;
}

.ga-landing-ia-upload small {
  display: block;
  color: #635d7c;
  margin-top: 5px;
}

.ga-landing-ia-upload.has-file {
  border-color: #6f5bff;
  box-shadow: 0 16px 32px rgba(111,91,255,.10);
}

.ga-landing-ia-style-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 9px;
  margin-bottom: 16px;
}

.ga-landing-ia-style-grid label {
  position: relative;
  border: 1px solid rgba(111,91,255,.14);
  background: #fff;
  color: #544e72;
  border-radius: 16px;
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  cursor: pointer;
}

.ga-landing-ia-style-grid input {
  position: absolute;
  opacity: 0;
}

.ga-landing-ia-style-grid label.active {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, #6f5bff, #ff70ae);
  box-shadow: 0 10px 22px rgba(111,91,255,.22);
}

.ga-landing-ia-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 18px 0;
  color: #625d7c;
  line-height: 1.55;
}

.ga-landing-ia-check input {
  margin-top: 4px;
  accent-color: #6f5bff;
}

.ga-landing-ia-generate {
  width: 100%;
}

.ga-landing-ia-generate.is-loading,
.ga-landing-ia-lead-form button.is-loading {
  opacity: .72;
  pointer-events: none;
}

.ga-landing-ia-result {
  padding: 24px;
  grid-template-columns: minmax(0, .75fr) minmax(0, 1.15fr);
}

.ga-landing-ia-lead-form {
  display: grid;
  gap: 10px;
  margin-top: 20px;
}

.ga-landing-ia-result-preview {
  border-radius: 24px;
  overflow: hidden;
  background: #eee8ff;
  border: 1px solid rgba(111,91,255,.14);
}

.ga-landing-ia-result-preview img {
  display: block;
  width: 100%;
  height: auto;
}

.ga-landing-ia-price-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ga-landing-ia-price-grid article span {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  color: #6f5bff;
  background: rgba(111,91,255,.10);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
  margin-bottom: 12px;
}

.ga-landing-ia-price-grid article strong {
  display: block;
  color: #17182f;
  margin-top: 14px;
  font-size: 16px;
}

.ga-landing-ia-price-grid article.featured {
  background: linear-gradient(135deg, #17182f, #2b2353);
}

.ga-landing-ia-price-grid article.featured h3,
.ga-landing-ia-price-grid article.featured strong {
  color: #fff;
}

.ga-landing-ia-price-grid article.featured p {
  color: rgba(255,255,255,.72);
}

.ga-landing-ia-loader {
  min-width: 300px;
  padding: 22px 24px;
  border-radius: 24px;
  background: #fff;
  color: #17182f;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  box-shadow: 0 24px 70px rgba(0,0,0,.18);
}

.ga-landing-ia-loader i {
  font-size: 28px;
  color: #6f5bff;
}

.ga-landing-ia-loader strong {
  font-size: 18px;
}

.ga-landing-ia-loader span {
  color: #625d7c;
  font-size: 13px;
}

@media (max-width: 980px) {
  .ga-landing-ia-hero,
  .ga-landing-ia-builder,
  .ga-landing-ia-result {
    grid-template-columns: 1fr;
  }
  .ga-landing-ia-builder-copy {
    position: static;
  }
  .ga-landing-ia-how-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .ga-landing-ia-nav {
    align-items: flex-start;
    flex-direction: column;
  }
  .ga-landing-ia-nav nav {
    width: 100%;
  }
  .ga-landing-ia-form-grid,
  .ga-landing-ia-style-grid,
  .ga-landing-ia-price-grid {
    grid-template-columns: 1fr;
  }
  .ga-landing-ia-phone {
    transform: none;
  }
}
