/*
TEMPLATE FOR MEDIA QUERIES
	@media screen and (min-width:1180px) {}
	@media screen and (min-width:880px) and (max-width:1179px) {}
	@media screen and (max-width:879px) {}

INDEX
	- MIRACLES
*/

/*-----------------------------------------------------------  MIRACLES ------------------------*/
@media screen and (min-width: 1180px) {
	.sip-top div.sip-content:nth-child(odd) div.txt h2::after { max-width: 550px; right: 350px; }

	.sip-top div.sip-content:nth-child(even) div.txt h2::after { max-width: 650px; left: 250px; }

	.sip-top > div.sip-content:nth-child(odd) img {
		float: left;
		margin-right: 50px;
	}

	.sip-top > div.sip-content:nth-child(even) img {
		float: right;
		margin-left: 40px;
	}

	.sip-top > div.sip-content:nth-child(even) div.txt { margin-left: 100px; }
}

@media screen and (min-width: 880px) and (max-width: 1179px) {
	.sip-top div.sip-content:nth-child(odd) div.txt h2::after { max-width: 510px; right: 50px; }

	.sip-top div.sip-content:nth-child(even) div.txt h2::after { max-width: 390px; left: 170px; }

	.sip-top > div.sip-content:nth-child(odd) img {
		float: left;
		margin-right: 50px;
	}

	.sip-top > div.sip-content:nth-child(even) img {
		float: right;
		margin-left: 40px;
	}

	.sip-top > div.sip-content:nth-child(even) div.txt { margin-left: 100px; }
}

@media screen and (min-width: 701px) and (max-width: 879px) {
	.sip-top div.sip-content div.txt h2 {
		position: relative;
		font-size: 1.5em !important;
	}

	.sip-top > div.sip-content:nth-child(odd) img {
		float: left;
		margin-right: 30px;
	}

	.sip-top > div.sip-content:nth-child(even) img {
		float: right;
		margin-left: 20px;
	}

	.sip-top > div.sip-content:nth-child(even) div.txt { margin-left: 100px; }
}

@media screen and (max-width: 700px) {
	.sip-top div.sip-content div.txt h2 { position: relative; }

	.sip-top > div.sip-content img {
		display: block;
		margin: 10px auto 0;
	}
}

.sip-top div.sip-content { margin: 40px auto; }

.sip-top div.sip-content div.txt {
	max-width: 670px;
	/* margin: 0 auto; */
	/* height: 580px; */
	overflow-y: auto;
}

.sip-top div.sip-content div.txt h2 {
	margin-top: 45px;
	margin-bottom: 35px;
	color: var(--color_pl3);
	font-size: 1.8em;
}

.sip-top div.sip-content div.txt h2::after {
	content: " ";
	display: block;
	height: 2px;
	background: var(--color_pl3);
	margin-bottom: 10px;
	position: absolute;
	z-index: 10;
	margin-top: 15px;
	width: 100%;
}

.sip-top > div.sip-content img { max-width: 317px; width: 100%; filter: saturate(0); }

/*-----------------------------------------------------------  SWIPER --------------------------*/
@media screen and (min-width: 1180px) {
	#miracles #swiper-miracles .swiper-button-prev,
	#miracles #swiper-miracles .swiper-button-next {
		opacity: 0;
	}

	#miracles #swiper-miracles:hover .swiper-button-prev,
	#miracles #swiper-miracles:hover .swiper-button-next {
		opacity: 1;
	}
}

#miracles .content { padding-bottom: 0; }

#miracles #swiper-miracles .swiper-scrollbar { display:  none; }

#miracles #swiper-miracles .swiper-button-prev,
#miracles #swiper-miracles .swiper-button-next {
	transition: all 0.2s linear;
	background-color: rgba(255,255,255,0.8);
	/* border: 1px solid var(--gray3); */
	padding: 20px;
	background-size: 20px;
	background-blend-mode: multiply;
}

#miracles #swiper-miracles .swiper-button-prev:hover,
#miracles #swiper-miracles .swiper-button-next:hover {
	background-color: rgba(14, 29, 59, 0.5);
	transition: all 0.2s linear;
}

#miracles #swiper-miracles {
	overflow: hidden;
}

/* #miracles #swiper-miracles .swiper-slide {
	width: 254px !important;
} */

.swiper-slide dl {
	max-width: 265px;
	width: 98%;
	max-height: 265px;
	height: 98%;
	/* float: left; */
	margin: 0 auto 7px;
	position: relative;
	overflow: hidden;
}

.swiper-slide dl dt img { width: 100%; }

.swiper-slide dl .miracles-infos-swiper {
	background: rgba(0,0,0,0.6);
	padding: 3px 0 20px;
	height: 50px;
	position: absolute;
	text-align: center;
	width: 100%;
	color: white;
	bottom: -65px;
	transition: all 0.2s ease-in-out;
}

.swiper-slide dl:hover .miracles-infos-swiper {
	bottom: 0;
	transition: all 0.2s ease-in-out;
}

.swiper-slide dl .miracles-infos-swiper::before {
	content: " ";
	background: url(http://www.stbernadetteusa.org/ctm/31257/projects/BernadetteUSA/gallery/2022/02/yellow-flower.png) no-repeat center;
	background-size: 15px;
	width: 15px;
	height: 13px;
	display: block;
	margin: 0 auto;
	position: relative;
	top: -10px;
}

.swiper-slide dl dd.name { font-size: 14px; }
.swiper-slide dl dd.loc-date {
	font-size: 13px;
}
/* .swiper-slide dl dd.date { bottom: 15px; } */

.sp-block {
	max-width: 265px;
	width: 98%;
	height: 50px;
	margin-left: auto;
	margin-right: auto;
}

.sp-block-top { margin-bottom: 7px; }
.sp-block-middle { margin-bottom: 7px; }
.sp-block-bottom { margin-top: 7px; }

.sp-block-gray { background: #e8e8e8; }
.sp-block-yellow { background: var(--color_pl3); }
.sp-block-blue { background: var(--color_p); }

/* Container geral */
#milagresContainer {
	font-family: 'Arial', sans-serif;
	margin-top: 20px;
	padding: 0 15px;
}

/* Título da lista */
h3 {
	color: var(--color3000); /* Cor original do seu H3 */
	margin-bottom: 20px;
	font-size: 1.8em;
	font-weight: 600;
	border-bottom: 2px solid #e9ecef; /* Linha sutil de separação */
	padding-bottom: 10px;
}

/* Lista de milagres */
.milagre-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid; 
	gap: 10px;
}

/* Item individual do milagre */
.milagre-item {
	display: flex;
	align-items: center;
	background: #ffffff; 
	padding: 15px 20px;
	border-radius: 8px; 
	border-left: 5px solid var(--color2000); 
	transition: all 0.3s ease;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);
}

.milagre-item:hover {
	transform: translateY(-2px); /* Efeito de elevação */
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
	background-color: #f8f9fa;
}

.miracle-id {
	font-weight: 700;
	color: var(--color4000); 
	margin-right: 20px;
	min-width: 40px; 
	text-align: right;
}

.miracle-name {
	flex-grow: 1;
	font-size: 1.1em;
	color: var(--color3000); 
	font-weight: 500;
}

/* Botão editar */
.editBtn {
	background-color: transparent;
	color: var(--color2000); 
	border: 1px solid var(--color2000); 
	padding: 8px 12px;
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.2s;
	margin-left: 15px;

}

.editBtn:hover {
	background-color: var(--color1000);
	color: white; 
	border-color: var(--color1000);
}

/* Botão cadastrar novo */
.new-btn {
	margin-top: 25px;
	background-color: blue;
	color: white;
	border: none;
	padding: 12px 20px;
	border-radius: 8px;
	cursor: pointer;
	font-size: 1em;
	font-weight: 600;
	transition: background 0.2s;
	display: inline-flex;
	align-items: center;
	box-shadow: 0 4px 6px rgba(40, 167, 69, 0.2); /* Sombra mais sutil */
}

.new-btn:hover {
	background-color: #7cac61; 
}

.editBtn i {
	margin: 0;
}
.new-btn i {
	margin-right: 8px; 
}









/*-----------------------------------------------------------  MIRACLE WIDGET -------------------*/

:root {
    --mw-red:     #d9534f;
    --mw-navy:    #1b3060;
    --mw-orange:  #e8971a;
    --mw-border:  #d4d4d4;
    --mw-text:    #555;
    --mw-divider: #e6e6e6;
    --mw-bg:      #fff;
    --mw-dd-border: #e6e6e6;
}

/* ---- Card ---- */
#miraclesWidget {
    font-family: Arial, sans-serif;
    max-width: 650px;
    width: 100%;
    margin: 20px auto;
    padding: 22px 24px 26px;
    border-radius: 8px;
    box-shadow: 0 2px 22px rgba(0, 0, 0, 0.10);
    background-color: var(--mw-bg);
    box-sizing: border-box;
}

/* ---- Header row ---- */
.miracle-header-container {
    display: flex;
    align-items: stretch;
    gap: 10px;
    margin-bottom: 22px;
}

/* Title box wrapper */
.miracle-title-box {
    flex-grow: 1;
    display: flex;
    align-items: stretch;
    cursor: pointer;
    position: relative;
    min-width: 0;
}

/* Red number block */
.miracle-id-number {
    background-color: var(--mw-red);
    color: #fff;
    font-weight: 700;
    font-size: 1.3em;
    min-width: 64px;
    padding: 0 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 4px 0 0 4px;
}

/* Navy name bar */
.miracle-title-box .miracle-name {
    background-color: var(--mw-navy);
    color: #fff;
    font-weight: 700;
    font-size: 1.05em;
    padding: 0 34px 0 16px;
    flex-grow: 1;
    display: flex;
    align-items: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    border-radius: 0 4px 4px 0;
}

/* Small dropdown chevron inside navy bar */
.mw-arrow {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.6em;
    color: rgba(255, 255, 255, 0.5);
    pointer-events: none;
}

/* ---- Nav buttons ---- */
.nav-btn {
    background: var(--mw-bg);
    border: 1px solid var(--mw-border);
    color: #aaa;
    width: 46px;
    min-width: 46px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.9em;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.15s, color 0.15s;
}

.nav-btn:hover:not(:disabled) {
    background: #f0f0f0;
    color: #555;
}

.nav-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* ---- Dropdown list ---- */
.miracle-dropdown-list {
    display: none;
    position: absolute;
    top: calc(100% + 3px);
    left: 0;
    z-index: 200;
    width: 100%;
    max-height: 300px;
    overflow-y: auto;
    list-style: none;
    padding: 0;
    margin: 0;
    background-color: var(--mw-bg);
    border: 1px solid var(--mw-dd-border);
    border-radius: 0 0 4px 4px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.13);
}

.miracle-title-box.open .miracle-dropdown-list { display: block; }

.miracle-dropdown-list li {
    display: flex;
    align-items: center;
    padding: 8px 12px;
    cursor: pointer;
    border-bottom: 1px solid var(--mw-dd-border);
    color: #495057;
    font-size: 0.88em;
    font-weight: normal;
}

.miracle-dropdown-list li:hover  { background-color: #f8f9fa; }
.miracle-dropdown-list li.active { background-color: #edf0f4; font-weight: 600; }

.miracle-dropdown-list .dropdown-id {
    color: #bbb;
    min-width: 28px;
    flex-shrink: 0;
    font-size: 0.85em;
}

.miracle-dropdown-list .dropdown-name {
    flex-grow: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ---- Content area ---- */
.miracle-content {
    display: flex;
    align-items: flex-start;
    gap: 22px;
}

/* Photo */
.miracle-photo-container {
    width: 130px;
    min-width: 130px;
    height: 168px;
    border: 1px solid #ddd;
    overflow: hidden;
    flex-shrink: 0;
    background: #ebebeb;
}

.miracle-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: grayscale(100%);
}

/* Details panel */
.miracle-details {
    flex-grow: 1;
    min-width: 0;
    padding-top: 4px;
}

.miracle-details p { margin: 0; line-height: 1.45; }

/* Person name */
.detail-line.name {
    font-family: 'Playfair Display', Georgia, 'Times New Roman', serif;
    font-size: 1.55em;
    font-weight: 700;
    font-style: italic;
    color: var(--mw-navy);
    margin-bottom: 10px !important;
    line-height: 1.2;
}

/* Divider lines */
.detail-divider {
    border: none;
    border-top: 1px solid var(--mw-divider);
    margin: 10px 0;
}

/* Location row */
.detail-line.location {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: var(--mw-text);
    font-size: 0.92em;
    margin: 8px 0 !important;
}

.detail-line.location i {
    color: var(--mw-orange);
    flex-shrink: 0;
    margin-top: 3px;
}

/* Healing row */
.detail-line.cured-info {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--mw-text);
    font-size: 0.92em;
    margin: 8px 0 !important;
}

.detail-line.cured-info i {
    color: var(--mw-orange);
    flex-shrink: 0;
    margin-right: 5px;
}

.age-separator {
    color: #bbb;
    margin: 0 5px;
}

/* ---- Responsive ---- */
@media screen and (max-width: 520px) {
    #miraclesWidget { padding: 14px; }

    .miracle-photo-container {
        width: 88px;
        min-width: 88px;
        height: 114px;
    }

    .detail-line.name { font-size: 1.2em; }

    .miracle-id-number {
        min-width: 46px;
        font-size: 1.05em;
    }
}