@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;500;700&family=Prompt:wght@300;400;600;700&display=swap');
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Open Sans';
}




/* Header Styles */
.header-top {
    display: flex; 
    justify-content: space-between;
    background-color: #232222;
    opacity: 0.9;
    padding: 10px 20px;
    border-bottom: 2px solid #424242;
}

.header-info {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: #fff;
    justify-content: space-between;
    margin: 0px 40px;
}

.header-info span {
    display: flex;
    align-items: center;
    gap: 5px;
}

.social-icons {
    margin-left: 0px;
}


.more {
    display: flex;
    justify-content: space-between;
}

.social-icons a {
    color: #fff;
    margin: 0 5px;
    font-size: 16px;
    text-decoration: none;
}

.social-icons a:hover {
    color: #a0ec09;
}

.call-button {
    color: #fff;
    text-decoration: none;
}

.call-button:hover {
    color: #a0ec09; /* Cambia el color al pasar el mouse */
}

.user-options {
    display: flex;
    text-align: right;
}

.user-options a {
    margin-left: 7px;
    margin-right: 10px;
    color: #fff !important;
    text-decoration: none;
}

.user-options a.profile:hover {
    color: #a0ec09 !important;
}

.user-options a:hover {
    color: #a0ec09;
}



/**************************************************************
/************ L O G I N       *********************************/

#contenedor-login {
    height: 100vh;
    background:#c0c0c0;
    display: flex;
    justify-content: center;
    align-items: center;
}

#contenedor-login .presentacion {
    width: 100%;
    max-width: 1000px;
    height: 550px;
    display: flex;
    border: 1px solid #c0c0c0;
}

#contenedor-login .presentacion .titulo {
    width: 50%;
    background: linear-gradient(#5e8b04, #a0ec09);
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    color: #fff;
}

#contenedor-login .presentacion .titulo h1 {
    font-size: 60px;
}

#contenedor-login .presentacion .titulo p {
    font-size: 18px;
    font-weight: bold;
}

#contenedor-login .presentacion .contenedor-formulario {
    width: 50%;
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}

#contenedor-login .presentacion .contenedor-formulario .form-login {
    width: 375px;
    padding: 40px 20px;
    border: 1px solid #c0c0c0;
}

#contenedor-login .presentacion .contenedor-formulario .form-login .input-login {
    display: block;
    width: 100%;
    margin: 20px 0;
    padding: 7px;
    border: 1px solid #c0c0c0;
}

#contenedor-login .presentacion .contenedor-formulario .form-login .btn {
    display: block;
    width: 100%;
    border: none;
    background-color: #77b300;
    padding: 7px;
    color: #fff;
    cursor: pointer;
}

#contenedor-login .presentacion .contenedor-formulario .form-login .btn:hover {
    background-color: #5e8b04;
}

.msj-error-input {
    font-size: 12px;
    color: darkred;
}


/**************************************************************
/*** ESTILO GENERALES DEL ADMIN     *********************************/

html,
body {
    height: 100%;
    background-color: #333;
}

header {
    top: 0;
    left: 0;
    width: 100%;
    height: 90px;
    padding: 20px 10px;
    color: #fff;
    background-color: #333;
    position: fixed;
    z-index: 99;
}

header h2 {
    font-size: 14px;
    font-style: italic;
}

#contenedor-admin {
    width: 100%;
    height: 100%;
    background-color: #fff;
}

.contenedor-menu {
    position: fixed;
    left: 0;
    top: 80px;
    width: 250px;
    padding: 15px;
    background-color:  #333;
    color: #fff;
    height: 100%;
}

.contenedor-menu h2 {
    font-size: 16px;
    margin: 10px 15px;
}

.contenedor-menu nav ul {
    list-style: none;
}

.contenedor-menu nav ul li {
    padding-left: 15px;
    border-radius: 0 15px 15px 0;
    overflow: hidden;
}

.contenedor-menu nav ul li i {
    font-size: 16px;
    width: 16px !important;
    color: #fff;
    margin-right: 5px !important;
}

.contenedor-menu nav ul hr {
    margin: 18px 0;
    border: none;
    border-top: 1px solid;
    color: #aaa;
}

.contenedor-menu nav ul li a {
    display: inline-block;
    width: 100%;
    color: #fff;
    text-decoration: none;
    font-size: 12px;
    padding: 7px 0;
}


/* Estilos para la sección de búsqueda */

/* Estilos para la sección de búsqueda */
.buscador {
    background: rgba(255, 255, 255, 0.8); /* Fondo semitransparente */
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra */
    max-width: 800px;
    margin: 20px auto; /* Centrar y añadir margen superior e inferior */
    text-align: center; /* Centrar el texto */
}

.buscador h2 {
    margin-bottom: 20px;
    font-size: 24px;
    color: #333;
}

.buscador form {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.buscador select,
.buscador input[type="radio"],
.buscador button {
    padding: 10px;
    font-size: 16px;
    border: 1px solid #ccc;
    border-radius: 5px;
    transition: all 0.3s ease;
}

.buscador select:hover,
.buscador input[type="radio"]:hover,
.buscador button:hover {
    border-color: #777;
}

.buscador input[type="radio"] {
    margin: 0 10px;
}

.buscador button {
    background-color: #e74c3c;
    color: #fff;
    border: none;
    cursor: pointer;
    padding: 10px 20px;
}

.buscador button:hover {
    background-color: #c0392b;
}

/* Estilos para los resultados de búsqueda */
.contenedor-busqueda {
    margin-top: 30px;
}

.contenedor-busqueda h3 {
    text-align: center;
    font-size: 20px;
    margin-bottom: 20px;
}

.resultado {
    display: flex;
    align-items: center;
    padding: 15px;
    border: 1px solid #ddd;
    border-radius: 5px;
    margin-bottom: 15px;
    transition: background-color 0.3s;
}

.resultado:hover {
    background-color: #f9f9f9;
    cursor: pointer;
}

.contenedor-imagen {
    flex: 1;
    margin-right: 15px;
}

.contenedor-imagen img {
    max-width: 100%;
    border-radius: 5px;
}

.info {
    flex: 2;
}

.info .titulo {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 10px;
}

.info p {
    font-size: 14px;
    margin-bottom: 10px;
}

.detalles {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}

.dato1 {
    flex: 1 1 100px;
}

.dato1 .header {
    font-weight: bold;
    font-size: 14px;
}

.dato1 .texto {
    font-size: 14px;
}



.pagina-activa,
.pagina-activa a {
    background:linear-gradient(to right, #5e8b04,#77b300);
    color: #fff !important;
}
.pagina-activa i{
    color: #fff !important;
}

.contenedor-menu nav ul li a:hover {
    text-decoration: underline;
}

.contenedor-principal {
    position: relative;
    height: 100%;
    /*z-index: -99;*/
    margin-left: 250px;
    background-color: #333;
}


/**************************************************************
/*** ESTILOS DEL DASHBOARD     *********************************/

#dashboard {
    background-color: #333;
    padding: 100px;
    height: 100%;
    width: 100%;
}

#dashboard h2 {
    margin-bottom: 10px;
}

#dashboard>hr {
    margin-bottom: 40px;
}

#dashboard .contenedor-cajas-info {
    display: flex;
    justify-content: space-around;
    background-color: #fff;
    padding: 40px 20px;
    border: 1px solid #aaa;
    border-radius: 5px;
}

#dashboard .contenedor-cajas-info .caja-info {
    background-color: #d8e9d8;
    width: 200px;
    border: 1px solid #aaa;
    text-align: center;
    color: #444;
    margin-right: 30px;
    transition: transform .5s;
}
#dashboard .contenedor-cajas-info .propiedades{
    background-color: #dcf1ed;
}
#dashboard .contenedor-cajas-info .tipo{
    background-color: #f6ede3;
}
#dashboard .contenedor-cajas-info .paises{
    background-color: #f5ecf0;
}
#dashboard .contenedor-cajas-info .ciudades{
    background-color: #e6ebf5;
}

#e6ebf5
#dashboard .contenedor-cajas-info .caja-info:hover {
    transform: scale(1.1);
}

#dashboard .contenedor-cajas-info .caja-info p {
    font-size: 13px;
    font-weight: bold;
    padding: 10px 0;
}

#dashboard .contenedor-cajas-info .caja-info .dato {
    display: block;
    font-size: 24px;
    font-weight: bold;
    padding: 20px 0;
}

#dashboard .contenedor-cajas-info .caja-info a {
    display: block;
    color: #333;
    padding: 10px 0;
}

.btn-accion {
    background-color: #77b300;
    border: none;
    display: inline-block;
    padding: 10px 20px;
    font-weight: bold;
    color: #fff;
    cursor: pointer;
}

.btn-accion:hover {
    background-color: #111;
}

.checkbox-group {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 columnas en una sola fila */
    gap: 10px; /* Espacio entre elementos */
    padding: 15px 20px; /* Espaciado interno */
    border: 2px solid #dadce0; /* Borde suave */
    border-radius: 12px; /* Bordes redondeados */
    background-color: #f8f9fa; /* Fondo claro tipo Google Forms */
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); /* Sombra suave */
}

.checkbox-group input[type="radio"] {
    appearance: none; /* Elimina el estilo por defecto */
    width: 18px;
    height: 18px;
    border: 2px solid #5f6368; /* Borde gris oscuro */
    border-radius: 50%; /* Circular */
    outline: none;
    cursor: pointer;
    transition: 0.3s;
}

.checkbox-group input[type="radio"]:checked {
    background-color: #4285f4; /* Azul característico de Google */
    border-color: #4285f4;
}

.checkbox-group label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-weight: 500; /* Estilo moderno */
    color: #202124; /* Texto oscuro para mejor legibilidad */
}



/********************************************************************
/*** ESTILOS DE NUEVA PROPIEDAD     *********************************/

#nueva-propiedad {
    background-color: #333;
    padding: 60px 40px 20px;
}

#nueva-propiedad form,
#actualizar-propiedad form {
    background-color: #333;
    padding: 20px;
    border: 1px solid #232222;
    border-radius: 5px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

#nueva-propiedad label,
#actualizar-propiedad label {
    display: block;
    width: 100%;
    margin-bottom: 5px;
    font-weight: bold;
    font-size: 16px;
    color: #fff;
}

#nueva-propiedad .fila-una-columna,
#actualizar-propiedad .fila-una-columna {
    width: 100%;
    margin: 20px 0;
}

#nueva-propiedad .input-entrada-texto,
#actualizar-propiedad .input-entrada-texto,
#configuracion .input-entrada-texto {
    width: 100%;
    border: 1px solid #aaa;
    background-color: #424242;
    padding: 10px;
}

.input-entrada-texto {
    color: #fff;
}

#nueva-propiedad .fila,
#actualizar-propiedad .fila {
    width: 100%;
    display: flex;
    justify-content: space-between;
    margin: 20px 0
}

#nueva-propiedad .fila .box,
#actualizar-propiedad .fila .box {
    width: 30%;
}

#nueva-propiedad .btn-fotos,
#actualizar-propiedad .btn-fotos {
    width: 200px;
    background-color: rgb(6, 104, 81);
    border-radius: 50px;
    padding: 5px;
    cursor: pointer;
    color: #fff;
    font-weight: bold;
    font-size: 12px;
    text-align: center;
}

#nueva-propiedad .contenedor-foto-principal,
#actualizar-propiedad .contenedor-foto-principal {
    display: block;
    max-width: 600px;
    margin: -10px 0;
}

#nueva-propiedad .contenedor-foto-principal img,
#actualizar-propiedad .contenedor-foto-principal img {
    width: 100%;
}

#nueva-propiedad .contenedor-foto-galeria,
#actualizar-propiedad .contenedor-foto-galeria {
    display: inline-block;
    max-width: 300px;
    margin-top: 10px;
    margin-left: 10px;
}

#nueva-propiedad .foto-galeria,
#actualizar-propiedad .foto-galeria {
    width: 100%;
}


#nueva-propiedad hr {
    margin: 25px 0;
    border: none;
    height: 2px;
    background-color: #77b300;
    opacity: 0.5;
}

#map-container {
    margin-top: 5px;
    background-color: #f5f5f5;
}

.gm-style iframe + div {
    border: none!important;
}

.gm-control-active.gm-fullscreen-control {
    margin-top: 5px;
    margin-right: 5px;
}


/********************************************************************
/*** LISTDO DE PROPIEDADES     *********************************/

#listado-propiedades {
    background-color: #424242;
    padding: 20px;
}

#listado-propiedades .contenedor-tabla {
    background-color: #333;
    padding: 20px;
    border-radius: 5px;
    margin-top: 15px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

#listado-propiedades table {
    margin-top: 20px;
    border-collapse: collapse;
    text-align: left;
}

#listado-propiedades table tr {
    border: 1px solid #ccc;
    font-size: 12px;
    padding: 5px;
    background-color: #333;
    color: #fff;
}

#listado-propiedades table th {
    background-color: #424242;
}


#listado-propiedades table td,
th {
    padding: 10px;
}

#listado-propiedades table th {
    background-color: #77b300;
    color: #fff;
}

#listado-propiedades table .form-acciones {
    display: inline-block;
    margin-right: 15px;
}

#listado-propiedades table .form-acciones input {
    border: none;
    background-color: transparent;
    color: #78B300;
    cursor: pointer;
    text-decoration: underline;
    margin-bottom: 5px;
}

#listado-propiedades table .btn-eliminar {
    font-size: 14px;
    text-decoration: none;
    background-color: transparent;
    color: #c0392b;
    cursor: pointer;
}

#listado-propiedades table .btn-eliminar:hover {
    text-decoration: underline;
}

#listado-propiedades table .form-acciones input:hover {
    text-decoration: underline;
}

#listado-propiedades table {
    width: 100%;
    table-layout: auto !important;
}

#listado-propiedades table tr:nth-child(odd) {
    background: #424242;
}


/*los siguientes estilos pertenecen a la ventan modal que se abre cuando
    se elimina una propiedad */

.modal {
    display: none;
    /* Hidden by default */
    position: fixed;
    /* Stay in place */
    z-index: 1;
    /* Sit on top */
    left: 0;
    top: 0;
    width: 100%;
    /* Full width */
    height: 100%;
    /* Full height */
    overflow: auto;
    /* Enable scroll if needed */
    background-color: rgb(0, 0, 0);
    /* Fallback color */
    background-color: rgba(0, 0, 0, 0.4);
    /* Black w/ opacity */
}


/* Modal Content/Box */

.modal-content {
    color: #fff;
    font-size: 18px;
    background-color: #333;
    margin: 15% auto;
    padding: 10px;
    padding-top: 35px;
    width: 450px;
    height: 170px;
    text-align: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.modal-content button {
    font-size: 18px;
    padding: 5px 10px;
    margin-top: 20px;
    background-color: #232222;
    color: #fff;
    cursor: pointer;


}


/* The Close Button */

.close {
    color: #aaa;
    float: right;
    font-size: 28px;
    margin-top: -30px;
    font-weight: bold;
}


.close:hover,
.close:focus {
    color: black;
    text-decoration: none;
    cursor: pointer;
}


/********************************************************************
/***  DETALLE PROPIEDADES     *********************************/

#detalle-propiedad {
    background-color: #fff;
    padding: 60px;
}

#detalle-propiedad .contenedor-tabla {
    background-color: #fff;
    padding: 20px;
    border: 1px solid #aaa;
    border-radius: 5px;
    margin-top: 15px;
}

#detalle-propiedad .descripcion {
    width: 100%;
    margin-top: 5px;
    border-collapse: collapse;
    text-align: left;
}

#detalle-propiedad .descripcion td {
    padding: 10px;
    border: 1px solid #ccc;
}

#detalle-propiedad .descripcion tr:nth-child(odd) {
    background: #dedede;
}

#detalle-propiedad .descripcion tr td:nth-child(odd) {
    width: 200px;
    font-weight: bold;
}

#detalle-propiedad h2 {
    text-transform: uppercase;
    margin-bottom: 15px;
}

#detalle-propiedad h3 {
    margin-top: 20px;
    margin-bottom: 20px;
    color: #8e342a;
    text-transform: uppercase;
}

#detalle-propiedad .descripcion img {
    max-width: 300px;
}


/********************************************************************
/*** ACTUALIZAR PROPIEDAD     *********************************/


/* para no repetir estilo se pusiero los selectores en la sección de nuevo propiedad */

#actualizar-propiedad {
    background-color: #fff;
    padding: 20px;
}

#actualizar-propiedad hr {
    margin-bottom: 20px;
}

#actualizar-propiedad .btn-cambiar-foto {
    display: inline;
    color: #18ab84;
    cursor: pointer;
    font-weight: normal;
}

#actualizar-propiedad .btn-cambiar-foto:hover {
    text-decoration: underline;
}

#actualizar-propiedad #contenedor-fotos-nuevas .contenedor-foto-galeria {
    display: inline-block;
    max-width: 300px;
    margin-top: 10px;
    margin-left: 10px;
}

#actualizar-propiedad #contenedor-fotos-nuevas .foto-galeria {
    width: 100%;
}


/********************************************************************
/*** NEUVO TIPO DE PROPIEDAD - NUEVO PAIS - NUEVA CIUDAD     *********************************/


/*** ACTUALIZAR TIPO DE PROPIEDAD - ACTUALIZAR PAIS - ACTUALIZAR CIUDAD     *********************************/

#nuevo-tipo-propiedad,
#nuevo-pais,
#nueva-ciudad {
    background-color: #333;
    padding: 20px;
}

#nuevo-tipo-propiedad .box-nuevo-tipo,
#nuevo-pais .box-nuevo-tipo,
#nueva-ciudad .box-nuevo-tipo {
    background-color: #333;
    color: #fff;
    padding: 20px;
    border: 1px solid #aaa;
    border-radius: 5px;
    margin-top: 50px;
}

#nuevo-tipo-propiedad h3,
#nuevo-pais h3,
#nueva-ciudad h3 {
    font-weight: normal;
}

#nuevo-tipo-propiedad .box-nuevo-tipo form,
#nuevo-pais .box-nuevo-tipo form,
#nueva-ciudad .box-nuevo-tipo form {
    max-width: 900px;
    margin: auto;
}

#nuevo-tipo-propiedad .box-nuevo-tipo form input[type=text],
#nuevo-pais .box-nuevo-tipo form input[type=text],
#nueva-ciudad .box-nuevo-tipo form input[type=text] {
    display: block;
    width: 100%;
    max-width: 500px;
    padding: 10px;
    margin: 25px 0;
}

#nuevo-tipo-propiedad hr,
#nuevo-pais hr,
#nueva-ciudad hr {
    margin: 10px 0;
}

#nueva-ciudad select {
    display: block;
    width: 200px;
    background-color: #fff;
    padding: 10px;
}


/********************************************************************
/*** LISTADO TIPO PROPIEDADES     *********************************/

#listado-tipos-propiedades {
    background-color: #333;
    padding: 20px;
    margin-top: 110px;
    color: #fff;
}

#listado-tipos-propiedades .contenedor-tabla,
#listado-paises .contenedor-tabla,
#listado-ciudades .contenedor-tabla {
    background-color: #333;
    padding: 20px;
    border: 1px solid #aaa;
    border-radius: 5px;
    margin-top: 15px;
}

#listado-paises {
    margin-top: 120px;
    background-color: #333;
    color: #fff;
    padding: 20px;
}

.listados {
    margin-top: 20px;
    border-collapse: collapse;
    text-align: left;
    width: 600px;
    max-width: 600px;
}

.listados tr:nth-child(odd) {
    background: #424242;
}

.listados tr {
    border: 1px solid #ccc;
    font-size: 12px;
    padding: 5px;
}

.listados td,
th {
    padding: 10px;
}

.listados th {
    background-color: #77b300;
}

.listados input {
    border: none;
    background-color: transparent;
    color: #18ab84;
    cursor: pointer;
}

.listados input:hover {
    text-decoration: underline;
}


/********************************************************************
/*** CONFIGURACION     *********************************/

#configuracion {
    background-color: #333;
    padding: 20px;
    margin-top: 120px;
}

#configuracion .box-configuracion {
    background-color: #333;
    padding: 20px;
    border: 1px solid #aaa;
    border-radius: 5px;
    margin-top: 15px;
}

#configuracion .box-configuracion h3 {
    margin-bottom: 10px;
}

#configuracion .box-configuracion #personalizada .fila {
    display: flex;
    justify-content: space-between;
}

#configuracion .box-configuracion #personalizada .fila div {
    width: 30%;
    margin: 15px 0;
}

#configuracion label {
    width: 100%;
    display: block;
}

#configuracion .box-configuracion input[type="text"] {
    margin-bottom: 15px;
}

#configuracion .box-configuracion #personalizada {
    display: none;
}



@media only screen and (max-width: 450px) {

    #nueva-propiedad form, #actualizar-propiedad form {
        background-color: #fff;
        padding: 20px;
        border: 1px solid #aaa;
        border-radius: 5px;
        width: 30%;
    }

    #nueva-propiedad {
        background-color: #fff;
        padding: 60px 40px 20px;

    }

    #dashboard .contenedor-cajas-info {
        flex-direction: column;
        align-items: center;
        border: none !important;
    }

}


/* === Grid responsive de charts === */
.dash-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:16px;
}

/* Áreas (desktop) */
.dash-op         { grid-column: span 6; }
.dash-res        { grid-column: span 6; }
.dash-tipos      { grid-column: span 6; }
.dash-creadas    { grid-column: span 6; }
.dash-ciudades   { grid-column: span 6; }
.dash-moneda     { grid-column: span 6; }
.dash-estados-tipo{grid-column: 1 / -1;} /* ancho completo */

@media (max-width: 1100px){
  .dash-op, .dash-res, .dash-tipos, .dash-creadas, .dash-ciudades, .dash-moneda{
    grid-column: span 12;
  }
}

/* Alturas consistentes */
.card canvas{ height: 320px !important; }
.dash-creadas #chartCreadasMes{ height: 280px !important; }
.dash-creadas #chartCreadasSemana{ height: 540px !important; } /* contenido alto, se recorta por scroll */

.dash-card-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;
}

/* Tabs Mes/Semana */
.tabs-creadas{display:flex;gap:6px}
.tabs-creadas .tab-btn{
  padding:6px 10px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;
  color:#fff;font-weight:600;font-size:12px;cursor:pointer;
}
.tabs-creadas .tab-btn.active{background:#e6f0ff;border-color:#b7d0ff}

/* Scroll vertical suave para Semana */
.scroll-y{ max-height: 380px; overflow-y: auto; padding-right: 4px; }
.scroll-y::-webkit-scrollbar{ width:8px }
.scroll-y::-webkit-scrollbar-thumb{ background:#e5e7eb;border-radius:999px }

/* Treemap wrapper para mantener proporciones */
.treemap-wrap{ height: 320px; }

/* Tarjetas (ya tienes .card, afino un poco) */
.card { background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 14px rgba(15,68,139,.06); }
.card h3 { margin:0 0 8px; color:#fff; }


.required {
    color: #ff4444;
}

/* Estilos para los pasos */
.pasos {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
    background: rgba(255,255,255,0.1);
    padding: 15px;
}

.paso {
    flex: 1;
    text-align: center;
    padding: 10px;
    color: #888;
    font-weight: bold;
    border-bottom: 3px solid transparent;
    transition: all 0.3s ease;
    background-color: #333;
    margin: 0 5px;
}

.paso.active {
    color: #fff;
    border-bottom: 3px solid #77b300;
}

.paso.completed {
    color: #77b300;
    border-bottom: 3px solid #77b300;
}

.navegacion-pasos {
    margin-top: 30px;
    text-align: center;
}

.navegacion-pasos .btn-accion {
    margin: 0 10px;
    display: inline-block;
}

/* Estilos para checkboxes */
.fila .box label {
    color: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: normal;
}

.fila .box input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;
}



.btn-actualizar{
  background:#77b300;color:#fff;border:none;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:700;
}
.dropdown-actualizar .dropdown-menu{
  display:none; position:absolute; top:110%; left:0; min-width:240px; background:#fff; border:1px solid #e5e7eb;
  border-radius:8px; box-shadow:0 8px 24px rgba(0,0,0,.12); z-index:10;
}
.dropdown-actualizar .dropdown-menu a{
  display:block; padding:10px 12px; color:#374151; text-decoration:none; font-size:.95rem;
}
.dropdown-actualizar .dropdown-menu a:hover{ background:#f3f4f6; }
.dropdown-actualizar.open .dropdown-menu{ display:block; }

.btn-secundario{
  display:inline-block; padding:8px 12px; border:1px solid #cbd5e0; border-radius:8px; color:#2d3748; text-decoration:none;
}
.btn-secundario:hover{ background:#f8fafc; }

.media-item { cursor: move; }
.media-item.dragging { opacity: 0.5; }
.make-principal {
  position:absolute; left:6px; top:6px;
  background:#77b300; border:none; border-radius:4px; padding:2px 6px; cursor:pointer;
}
.lightbox-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.8); display:flex; align-items:center; justify-content:center; z-index:9999;
}
.lightbox-backdrop img{ max-width:90vw; max-height:90vh; }

.tips-hint{
  background:#232222; /* gris oscuro */
  color:#e5e7eb;
  border:1px solid #232222;
  border-radius:8px;
  padding:10px 12px;
  margin-top:20px;
}
.tips-hint summary{
  cursor:pointer;
  list-style:none;
  font-weight:600;
  display:flex;
  align-items:center;
  gap:8px;
}
.tips-hint[open] summary{ margin-bottom:8px; }
.tips-hint ul{ margin:0; padding-left:18px; }
.tips-hint li{ margin:4px 0; }
.tips-hint i{ width:16px; text-align:center; margin-right:6px; }


/* ====== Galería grande y reordenable ====== */
.photos-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); /* más grande */
  gap: 16px;
  margin-top: 12px;
}

.photo-card{
  position: relative;
  background:#111;
  border:1px solid #3b3b3b;
  border-radius:14px;
  overflow:hidden;
  min-height: 200px;              /* alto mayor */
  cursor: grab;                   /* siempre draggable */
  box-shadow: 0 8px 22px rgba(0,0,0,.35);
  transition: transform .08s ease, box-shadow .2s ease;
}
.photo-card:hover{ box-shadow: 0 12px 28px rgba(0,0,0,.45); }
.photo-card:active{ cursor:grabbing; transform: scale(.995); }
.photo-card.dragging{ opacity:.55; }

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

/* Controles (más grandes) */
.photo-actions{
  position:absolute; top:10px; right:10px; display:flex; gap:10px; z-index:3;
}
.photo-btn{
  border:0; border-radius:12px; padding:10px 12px;
  font-weight:800; font-size:14px; cursor:pointer;
  box-shadow: 0 4px 12px rgba(0,0,0,.3);
}
.photo-btn--del{ background:#dc3545; color:#fff; }
.photo-btn--p  { background:#77b300; color:#fff; }

/* Badges */
.badge-order{
  position:absolute; left:10px; top:10px; z-index:3;
  background:rgba(0,0,0,.75); color:#fff;
  font-size:13px; font-weight:800;
  border-radius:999px; padding:5px 10px;
}
.badge-index{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  background:linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.75));
  color:#fff; text-align:center; padding:8px 10px; font-size:14px; font-weight:800;
}

/* Lightbox opcional */
.lightbox-backdrop{ animation: lbIn .12s ease; }
@keyframes lbIn{ from{opacity:0} to{opacity:1} }
