/* Global Styles */

/*
body {
	margin: 0px;
}
*/

body {
	background: #f7f7f7;
	font-family: Arial, sans-serif;
}

/* Columna de servicios */
.services-column ul {
	list-style: none;
	padding-left: 0;
}

.services-column li {
	margin-bottom: 12px;
	font-size: 1.15rem;
	display: flex;
	align-items: center;
}

.services-column li i {
	margin-right: 10px;
	font-size: 1.2rem;
}

.services-column a {
	color: #ffd166;
	text-decoration: none;
	font-weight: bold;
}

.services-column a:hover {
	text-decoration: underline;
}


/* Cards de eventos */
.event-card {
	background: #fff;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 25px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
	text-align: center;
}

.event-card img {
	width: 100%;
	border-radius: 10px;
	margin-bottom: 15px;
}


/* Botón principal */
.main-btn {
	background: #06d6a0;
	padding: 5px 12px;
	border-radius: 50px;
	color: #fff;
	margin: 5px;
	font-size: 1.1rem;
	transition: 0.3s;
	font-weight: bold;
	text-transform: inherit;
}

.main-btn:hover {
	background: #05b88a;
	transform: scale(1.05);
	color: #fff;
}


/* Botón flotante */
.floating-contact {
	position: fixed;
	bottom: 25px;
	right: 125px;
	background: #ef476f;
	color: #fff;
	padding: 15px 25px;
	border-radius: 50px;
	font-size: 1.2rem;
	font-weight: bold;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
	z-index: 9999;
	transition: 0.3s;
}

.floating-contact:hover {
	background: #d6365c;
	transform: scale(1.07);
	color: #fff;
	text-decoration: none;
}

td {
	font: 11px Arial, Helvetica, sans-serif;
	color: #faf5f5;
}

a {
	color: #006666;
	font-weight: bold;
	text-decoration: none;
}

a:hover {
	color: #FFBA00;
}

/* ID Styles */

#navigation a {
	font: 10px Arial, Helvetica, sans-serif;
	color: #26354A;
	text-decoration: none;
	letter-spacing: .1em;
	line-height: 16px;
	display: block;
	padding: 0px 10px;
	border-right: 1px solid #FF6600;
}

#navigation a:hover {
	color: #ffffff;
	background: #FF6600;
}

#background td {
	background: url("mm_bg_header.gif");
}

#padding {
	padding: 14px;
}

/* Calendar Styles */

#calendar td {
	border: 1px solid #26354A;
}

#noborder td {
	border: 0px;
}

#calheader td {
	font-weight: bold;
	color: #ffffff;
}

/* Class Styles */

.logo {
	font: 24px Times New Roman, Times, serif;
	color: #FFFFFF;
	;
	letter-spacing: .3em;
	line-height: 26px;
}

.tagline {
	font: 14px Arial, Helvetica, sans-serif;
	color: #D3DCE6;
	line-height: 16px;
}

.bodyText {
	font: 16px Arial, Helvetica, sans-serif;
	line-height: 14px;
	color: rgb(249, 251, 253);
	letter-spacing: .1em;
	padding: 10px;

}

.detailText {
	font: 14px Arial, Helvetica, sans-serif;
	line-height: 14px;
	color: #FFFFFF;
	letter-spacing: .1em;
	padding: 10px;
}

.detailText_black {
	font: 14px Arial, Helvetica, sans-serif;
	line-height: 14px;
	color: #000000;
	letter-spacing: .1em;
	padding: 10px;
}

.detailText_italic {
	font: 14px Arial, Helvetica, sans-serif, italic;
	line-height: 16px;
	color: rgb(245, 246, 247);
	letter-spacing: .1em;
}

.pageName {
	font: 109px Arial, Helvetica, sans-serif;
	color: #FFFFFF;
	letter-spacing: .1em;
	line-height: 20px;
}

.pageNameBlackColor {
	font: 109px Arial, Helvetica, sans-serif;
	color: #000000;
	letter-spacing: .1em;
	line-height: 20px;
}

.pageSubtitle {
	font: 18px Arial, Helvetica, sans-serif;
	color: rgb(127, 133, 156);
	line-height: 10px;
}

.subHeader {
	font: bold 18px Arial, Helvetica, sans-serif;
	color: #f7f7f8;
	font-weight: bold;
	line-height: 25px;
	letter-spacing: .1em;
}

.subHeader1 {
	font: bold 18px Arial, Helvetica, sans-serif;
	color: #f7f7f8;
	font-weight: bold;
	line-height: 20px;
	letter-spacing: .1em;
}

.navText {
	font: 14px Arial, Helvetica, sans-serif;
	color: #FFFFFF;
	;
	letter-spacing: .1em;
	line-height: 16px;
}

.calendarText {
	font: 11px Arial, Helvetica, sans-serif;
	color: #26354A;
	letter-spacing: .1em;
}

.Estilo1 {
	color: #FF0000
}

.Estilo6 {
	color: #000000;
	padding: 10px;
}

.Estilo8 {
	color: #000000;
	padding: 10px;
	background: rgb(238, 184, 140)
}

.Estilo7 {
	color: #FFFFFF
}

.Estilo3 {
	color: #FF0000;
	font-size: 12px;
}

.Estilo9 {
	font-size: 12px
}

.Estilo11 {
	color: #000099;
	padding: 10px;
	background: darkgrey
}

.Estilo12 {
	font-size: 36px
}

.Estilo13 {
	color: #0000FF;
	font-weight: bold;
}

.Estilo14 {
	color: #FFFFFF
}

.background-report-l1 {
	color: #99e4dde1;
	background-color: #006666;
}

.background-report-l2 {
	color: hsl(55, 22%, 47%)
}

.italicText {
	color: #003399;
	font: Arial, Helvetica, sans-serif;
	font-style: italic;
}

.sidebarText {
	font: 11px Arial, Helvetica, sans-serif;
	color: #FFBA00;
	letter-spacing: .1em;
	line-height: 18px;
}

.fineline {
	border-bottom: 1px solid #D3CAA9;
	margin-bottom: 12px;
}

.background-line2 {
	background-color: darkgray;
}

.picture-container {
	/* any display: block; element */
	position: relative;
	height: 0;
	padding-bottom: 100%;
	/* of parent width */
}

.picture-content {
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}

/* FOOTER ELEGANTE */
.footer-modern {
	background: linear-gradient(135deg, #072b41 0%, #0a3d58 100%);
	color: #fff;
	padding: 50px 0 30px;
	font-family: 'Montserrat', sans-serif;
}

.footer-logo {
	height: 80px;
	margin-bottom: 20px;
}

.footer-title {
	font-size: 1.2rem;
	font-weight: 600;
	margin-top: 15px;
	color: #d9e6ef;
	letter-spacing: 0.5px;
}

.footer-text {
	font-size: 0.95rem;
	line-height: 1.5;
}

.footer-links {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-links li {
	margin-bottom: 8px;
}

.footer-links a {
	color: #e8f3fa;
	text-decoration: none;
	transition: 0.3s;
	font-size: 0.95rem;
}

.footer-links a:hover {
	color: #ffd37a;
	padding-left: 5px;
}

/* SOCIALS */
.footer-socials {
	margin-top: 10px;
}

.social-circle {
	display: inline-flex;
	width: 40px;
	height: 40px;
	background: #ffffff22;
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	margin-right: 10px;
	transition: 0.3s;
	font-size: 1.2rem;
	color: #fff;
}

.social-circle:hover {
	background: #ffd37a;
	color: #072b41;
}

/* BOTTOM */
.footer-bottom {
	text-align: center;
	margin-top: 30px;
}

.copyright {
	font-size: 0.85rem;
	color: #dce6ed;
}


/* CONTENEDOR GENERAL */
.services-column {
	margin-top: 15px;
}

/* CARD GENERAL */
.service-tag {
	border: 1px solid #dcdcdc;
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 12px;
	background: #f9fafc;
	transition: 0.3s ease;
}

/* EFECTO AL PASAR EL RATÓN */
.service-tag:hover {
	background: #eef2f5;
	border-color: #cfcfcf;
	transform: translateY(-2px);
}

/* ETIQUETA PREMIUM (el título) */
.tag-title-premium {
	display: block;
	font-weight: 700;
	font-size: 1rem;
	color: #0a3d62;
	margin-bottom: 6px;
	letter-spacing: 0.3px;
}

/* DESCRIPCIÓN */
.tag-desc {
	margin: 0;
	font-size: 0.9rem;
	color: #444;
	line-height: 1.45;
}

/* Hace el menú full-width y flotante */
.elegant-menu {
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	background: linear-gradient(90deg, #0a3d62 0%, #3c6382 100%);
	transition: all 0.35s ease;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

/* Compensar el espacio bajo un navbar fijo */
body {
	padding-top: 95px;
}

/* Separación del nombre respecto al logo */
.brand-title {
	color: #fff;
	font-size: 1.7rem;
	font-weight: bold;
	margin-left: 18px;
	/* separación extra */
	letter-spacing: 1px;
	transition: 0.3s;
}

/* Estilo cuando el menú se vuelve compacto */
.elegant-menu.shrink {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	background: linear-gradient(90deg, #082f4f 0%, #34556b 100%);
}

.elegant-menu.shrink img {
	height: 38px !important;
}

.elegant-menu.shrink .brand-title {
	font-size: 1.4rem;
	margin-left: 12px;
}

.elegant-menu {
	background: linear-gradient(90deg, #0a3d62 0%, #3c6382 100%);
	transition: all 0.35s ease;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}


/* Menú compacto al hacer scroll */
.elegant-menu.shrink {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	background: linear-gradient(90deg, #082f4f 0%, #34556b 100%);
}

.elegant-menu.shrink img {
	height: 38px !important;
}


/* Hover animado elegante */
.navbar-nav .nav-link {
	position: relative;
	padding: 8px 14px;
	transition: 0.3s;
}

.navbar-nav .nav-link::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -4px;
	width: 0;
	height: 2px;
	background: #f8c291;
	transition: 0.3s;
}

.navbar-nav .nav-link:hover::after {
	width: 60%;
	left: 20%;
}


/* Íconos del menú */
.menu-icon {
	margin-right: 6px;
	font-size: 1.2rem;
}


/* Botón Osta Lippu premium */
.btn-premium {
	background: #e67e22;
	color: #fff !important;
	padding: 10px 22px;
	border-radius: 25px;
	font-weight: bold;
	margin-left: 18px;
	transition: 0.3s;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.btn-premium:hover {
	background: #cf711b;
	transform: translateY(-2px);
}

/* Timeline general */
.timelines-container {
    margin-top: 40px;
}

/* Imagen evento */
.event-image {
    border-radius: 14px;
    box-shadow: 0 8px 20px rgba(0,0,0,0.15);
    margin-top: 12px;
}

/* Fecha */
.mbr-timeline-date {
    font-weight: 700;
    color: #0a3d62;
}

/* Texto */
.timeline-text-content {
    padding: 10px 20px;
}

/* Ubicación */
.event-location {
    font-weight: 600;
    color: #555;
    margin-bottom: 10px;
}

/* Botones reutilizando estilo */
.btn-premium {
    margin: 6px;
    border-radius: 25px;
    padding: 10px 22px;
    font-weight: 600;
}

/* estilo elegante del enlace de leer texte extendido en Konsertit.php */
.read-more-link {
    display: inline-block;
    margin-top: 6px;
    font-weight: 600;
    color: #0a3d62;
    cursor: pointer;
    text-decoration: underline;
    transition: 0.2s;
}

.read-more-link:hover {
    color: #1e6091;
}

.mbr-timeline-text {
    text-align: left;
    white-space: pre-line;
}

/* Estilo para la tarjeta de registro de clientes */
.registration-card {
    max-width: 920px;
    background: #fff;
    border-radius: 20px;
    padding: 40px;
    box-shadow: 0 15px 40px rgba(0,0,0,.15);
}

.form-control {
    border-radius: 12px;
    padding: 12px;
}

.btn-premium, .btn-premium-outline {
    background: linear-gradient(90deg,#e67e22,#f39c12);
    color:#fff;
    border:none;
    border-radius:30px;
    padding:14px;
    font-size:1.1rem;
    font-weight:600;
}

.step-indicator {
    text-align:center;
    color:#888;
}


.section-title {
    margin-top: 35px;
    margin-bottom: 15px;
    font-weight: 600;
    color: #0a3d62;
}

.form-label {
    font-weight: 500;
    margin-bottom: 6px;
}

.required {
    color: #e74c3c;
}

.form-error {
    color: #e74c3c;
    font-size: 0.85rem;
    margin-top: 4px;
}


.form-hint {
    display: block;
    margin-top: 6px;
    font-size: 0.85rem;
    color: #e67e22;
}

.form-group {
    margin-top: 30px;
}

.btn-premium {
    background: linear-gradient(135deg, #ff7a18, #ff9f43);
    color: #fff;
    font-size: 1.1rem;
    font-weight: 600;
    padding: 14px;
    border: none;
    border-radius: 8px;
    transition: all 0.3s ease;
    cursor: pointer;
}

/* ESTADO DESHABILITADO */
.btn-premium:disabled {
    background: #cccccc;
    color: #666;
    cursor: not-allowed;
    box-shadow: none;
    opacity: 0.7;
}

/* ESTADO ACTIVO */
.btn-premium:not(:disabled):hover {
    background: linear-gradient(135deg, #ff6a00, #ff8f00);
    box-shadow: 0 6px 16px rgba(0,0,0,0.2);
}


textarea.form-control {
    resize: vertical;
    min-height: 90px;
}


/* opc. de menu de inscripción */
.option-switch {
    display: flex;
    gap: 10px;
    margin: 30px 0;
}

.option-card {
    flex: 1;
    cursor: pointer;
    border: 2px solid #ddd;
    border-radius: 14px;
    padding: 20px;
    transition: all 0.3s ease;
    position: relative;
    background: #fff;
}

.option-card input {
    position: absolute;
    opacity: 0;
}

.option-content h5 {
    margin: 0;
    font-weight: 700;
    font-size: 1.1rem;
}

.option-content p {
    margin: 5px 0 0;
    font-size: 0.95rem;
    color: #777;
}

.option-card:hover {
    border-color: #c39d63;
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}

.option-card input:checked + .option-content {
    color: #1e8449;
}

.option-card input:checked {
    pointer-events: none;
}

.option-card input:checked ~ .option-content::after {
    content: "✓";
    position: absolute;
    top: 15px;
    right: 20px;
    font-size: 1.5rem;
    color: #27ae60;
}

/* opcion simple de inscripción */
.option-simple label {
    display: block;
    padding: 7px 10px;
    border: 1px solid #ddd;
    border-radius: 10px;
    margin-bottom: 6px;
    cursor: pointer;
}

.option-simple input {
    margin-right: 10px;
}

.option-simple span {
    display: block;
    font-size: 0.85rem;
    color: #777;
    margin-left: 10px;
}


/* Mensaje de envio exitoso - mostar en pantlla */

.alert-success-premium {
    background: linear-gradient(135deg, #0a3d62, #3c6382);
    color: #fff;
    padding: 22px 26px;
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.3);
    margin: 20px 0 30px;
    animation: fadeSlideIn 0.6s ease;
}

.alert-success-premium h4 {
    margin-bottom: 10px;
    font-weight: 700;
    font-size: 1.3rem;
}

.alert-success-premium p {
    margin: 0;
    line-height: 1.5;
    opacity: 0.95;
}

.alert-success-premium-inscripted {
    background: linear-gradient(135deg, #f39c12, #f39c12);
    
    padding: 22px 26px;
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.3);
    margin: 20px 0 30px;
    animation: fadeSlideIn 0.6s ease;
}

.alert-success-premium-inscripted h4 {
    margin-bottom: 10px;
    font-weight: 700;
    font-size: 1.3rem;
}

.alert-success-premium-inscripted p {
    margin: 0;
    line-height: 1.5;
    opacity: 0.95;
}


.alert-success-premium-error {
    background: linear-gradient(135deg, #FF0000, #FF0000);
    color:#FFFFFF;
    padding: 22px 26px;
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.3);
    margin: 20px 0 30px;
    animation: fadeSlideIn 0.6s ease;
}

.alert-success-premium-error h4 {
    margin-bottom: 10px;
    font-weight: 700;
    font-size: 1.3rem;
}

.alert-success-premium-error p {
    margin: 0;
    line-height: 1.5;
    opacity: 0.95;
}



@keyframes fadeSlideIn {
    from {
        opacity: 0;
        transform: translateY(-12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


/* Tickets */
.ticket-list {
    margin-top: 15px;
}

.ticket-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
    border-bottom: 1px solid #eee;
}

.ticket-info strong {
    font-size: 1rem;
}

.ticket-info span {
    display: block;
    font-size: 0.9rem;
    color: #777;
}

.ticket-counter {
    display: flex;
    align-items: center;
    gap: 8px;
}

.ticket-counter button {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: none;
    background: #f4b400;
    color: #fff;
    font-size: 1.4rem;
    cursor: pointer;
}

.ticket-counter button:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.ticket-counter input {
    width: 40px;
    text-align: center;
    border: none;
    background: transparent;
    font-size: 1rem;
}

.ticket-summary {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    padding: 15px;
    background: #fafafa;
    border-radius: 10px;
    font-size: 1.1rem;
}

.btn-premium:disabled {
    background: #ccc;
    cursor: not-allowed;
}


/* Cambio de contraseña */
.password-card {
    max-width: 480px;
    margin: 40px auto;
    padding: 30px;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
}

.form-error {
    color: #d93025;
    font-size: 14px;
}

.required {
    color: #ff6633;
}

.form-hint {
    font-size: 14px;
    color: #666;
}


/* report scroll */
.report-scroll-full {
  width: 100%;
  max-width: 100vw;
  overflow-x: auto;
  overflow-y: visible;
  padding: 1rem;
}

/* Para tablas anchas */
.report-scroll-full table {
  min-width: 1200px;
  border-collapse: collapse;
  white-space: nowrap;
}

/* Scroll elegante */
.report-scroll-full::-webkit-scrollbar {
  height: 8px;
}

.report-scroll-full::-webkit-scrollbar-thumb {
  background-color: #ff6600;
  border-radius: 4px;
}

.report-scroll-full::-webkit-scrollbar-track {
  background-color: #f2f2f2;
}


/* Calendar classes */
/* ===== CONTENEDOR ===== */
.section-classes {
    width: 100%;
    overflow-x: auto;            /* scroll horizontal si es necesario */
    margin-top: 2rem;
}

/* ===== TABLA ===== */
.table-scroll {
    width: 100%;
    overflow-x: auto;   /* scroll horizontal */
    overflow-y: auto;   /* scroll vertical si crece */
    max-height: 70vh;   /* evita que empuje la página */
    margin-top: 1rem;
}


.table-classes {
    width: 100%;
    /*min-width: 900px;            /* evita que se rompa en móvil */
	min-width: 1100px; /* fuerza scroll horizontal */
    border-collapse: collapse;
    background-color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    color: #333;
}

/* ===== CABECERA ===== */
.table-classes thead th {
	position: sticky;
    top: 0;
    background-color: #e6e6e6;
    color: #222;
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
    border-bottom: 2px solid #ccc;
    white-space: nowrap;
	z-index: 2;
}

/* ===== FILAS ===== */
.table-classes tbody tr:nth-child(even) {
    background-color: #f9f9f9;
}

.table-classes tbody tr:nth-child(odd) {
    background-color: #ffffff;
}

.table-classes tbody tr:hover {
    background-color: #eef3f7;
}

/* ===== CELDAS ===== */
.table-classes td {
    padding: 8px 12px;
    border-bottom: 1px solid #ddd;
    vertical-align: top;
}

/* ===== COLUMNAS ESPECIALES ===== */
.table-classes .col-date {
    font-weight: 600;
    color: #222;
    white-space: nowrap;
}

.table-classes .col-time {
    font-weight: 600;
    color: #c45500; /* acento Kotisalsa */
    white-space: nowrap;
}

.table-classes .col-event, .col-type, .col-level {
    font-weight: 700;
    color: #333;
    background-color: #fff7f0;
	white-space: nowrap;
}

.table-classes .col-room {
    font-weight: 300;
    color: #333;
    background-color: #fff7f0;
	white-space: nowrap;
}

.table-classes .col-instructor {
    color: #444;
}

.table-classes .col-location {
    color: #555;
    font-size: 13px;
}

.table-classes .col-info {
    color: #666;
    font-size: 13px;
}

/* ===== SEPARADOR POR EVENTO ===== */
.table-classes .event-row td {
    background-color: #333;
    color: #ffffff;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 10px 12px;
}



/* ===== MOBILE ===== */
@media (max-width: 768px) {
    .table-classes {
        font-size: 13px;
    }
}


