body {
    display: flex;
    justify-content: flex-start;
    /* Alinear al inicio horizontalmente */
    align-items: flex-start;
    /* Alinear al inicio verticalmente */
    padding: 20px;
    margin: 0;
    background-color: #f0f4f8;
    font-family: Arial, sans-serif;
    color: #333;
}

.container {
    background-color: #fff;
    padding: 20px;
    border-radius: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    width: 100%;
}

h1,
h2 {
    font-size: 1.5em;
    margin-bottom: 1em;
    color: #333;
}

label {
    display: block;
    font-weight: bold;
    margin-top: 10px;
    color: #666;
    font-size: 0.9em; /* Tamaño uniforme para todos los labels */
}

input[type="text"],
input[type="number"],
input[type="date"] {
    width: 100%;
    padding: 8px;
    margin-top: 5px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 1em;
    box-sizing: border-box;
}

button {
    background-color: #4CAF50;
    color: white;
    padding: 10px;
    margin-top: 10px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1em;
    width: 100%;
    transition: background-color 0.3s;
}

button:hover {
    background-color: #45a049;
}

#priceDisplay {
    margin-top: 10px;
    font-size: 1.2em;
    font-weight: bold;
    padding: 10px;
    border-radius: 8px;
    background-color: #e6f4ea;
    color: #2196F3;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
    text-align: center;
}

@media (max-width: 768px) {
    .main-container {
        flex-direction: column; /* Apila las columnas verticalmente */
        gap: 20px; /* Reduce el espacio entre contenedores */
    }
    .left-column,
    .right-column {
        width: 100%; /* Asegura que ocupen todo el ancho disponible */
        max-width: none; /* Elimina restricciones de ancho */
    }
}


.result-container {
    /* Hereda las mismas propiedades de los otros contenedores */
    background-color: #fff;
    padding: 20px; /* Igual que los otros contenedores */
    border-radius: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    width: 100%; /* Ocupa todo el ancho disponible */
    max-width: 350px; /* Igual al contenedor principal */
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-top: 20px;
    font-size: 0.9em; /* Tamaño general más pequeño */
}


.result-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
}

.result-item {
    flex: 1;
    text-align: center;
    display: flex;
    flex-direction: column; /* Labels arriba de los valores */
    align-items: center;
    gap: 5px;
}

.result-item label {
    font-size: 0.9em; /* Mismo tamaño que los labels generales */
    font-weight: bold;
    color: #666;
    margin-bottom: 5px; /* Espacio uniforme debajo del label */
}

.result-box {
    display: inline-block;
    padding: 6px 10px; /* Reduce el padding para coincidir con los inputs */
    font-size: 0.9em; /* Tamaño igual al de los inputs */
    font-weight: bold;
    color: #4CAF50;
    background-color: #e6f4ea;
    border: 1px solid #ccc; /* Igual al borde de los inputs */
    border-radius: 8px; /* Borde redondeado similar */
    box-shadow: none; /* Sin sombra para mantener consistencia */
}


/* MAX PROFIT específico */
.result-item.max-profit {
    width: 100%; /* Ocupa todo el ancho */
    text-align: center; /* Centra el contenido */
    font-size: 1.2em; /* Tamaño de fuente más grande */
}

.result-item.max-profit .result-box {
    display: block; /* Asegura que ocupe toda la línea */
    width: calc(100% - 30px); /* Reducir ancho para incluir márgenes */
    margin: 0 auto; /* Centrar horizontalmente */
    padding: 10px 15px; /* Más espacio dentro de la caja */
    font-size: 1.2em; /* Tamaño de texto más grande */
    font-weight: bold;
    border-radius: 8px; /* Bordes redondeados */
    color: #fff; /* Texto blanco para mejor visibilidad */
}

/* Fondo verde para valores positivos */
.result-item.max-profit .result-box.positive {
    background-color: #4CAF50;
    border: 1px solid #388E3C;
}

/* Fondo rojo para valores negativos */
.result-item.max-profit .result-box.negative {
    background-color: #F44336;
    border: 1px solid #D32F2F;
}

.main-container {
    display: flex;
    gap: 60px; /* Espacio entre la columna izquierda y derecha */
    align-items: flex-start; /* Alinear elementos al inicio verticalmente */
    width: 100%; /* Ocupa todo el ancho disponible */
    box-sizing: border-box; /* Asegura que el padding no rompa el diseño */
}

/* Columna izquierda */
.left-column {
    display: flex;
    flex-direction: column;
    gap: 20px; /* Espacio entre los contenedores */
    max-width: 350px; /* Mantener ancho máximo para la columna izquierda */
    width: 100%; /* Asegurar que se adapte dentro del espacio asignado */
    flex-shrink: 0; /* Evita que se reduzca si falta espacio */
}

/* Columna derecha con el gráfico */
.right-column {
    flex: 1; /* Ocupar el resto del espacio disponible */
    height: 800px; /* Ajustar automáticamente a la altura del contenido */
    box-sizing: border-box; /* Maneja bordes y paddings correctamente */
}

.tradingview-widget-container {
    height: 600px; /* Establecer un alto fijo */
    width: 100%;
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    overflow: hidden;
}

.tradingview-widget-container__widget {
    height: 100%; /* El widget debe ocupar el 100% del contenedor */
    width: 100%; /* Mantiene el ancho completo */
}


/* Estilo base para los contenedores personalizados en la columna izquierda */
.custom-container {
    background-color: #fff;
    padding: 20px;
    border-radius: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    margin-bottom: 20px;
    width: 100%;  /* Se asegura de ocupar el 100% del ancho de la columna */
  }
  
  /* Si deseas fijar un ancho máximo (por ejemplo, para que sean iguales a un ancho predeterminado) */
  .left-column .custom-container {
    max-width: 450px;  /* Ajusta este valor según lo requieras */
  }