/* ================================================================
   Diócesis – Eventos  |  Frontend Styles
   Paleta: Carmesí litúrgico (#8B1A1A), Oro (#C9A84C), Marfil (#FAF7F2)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,600;0,700;1,400&family=Lato:wght@300;400;700&display=swap');

:root {
    --de-crimson:  #8B1A1A;
    --de-gold:     #C9A84C;
    --de-ivory:    #FAF7F2;
    --de-dark:     #1C0F0F;
    --de-gray:     #6B6B6B;
    --de-light:    #F3EDE3;
    --de-radius:   10px;
    --de-shadow:   0 4px 24px rgba(28,15,15,.10);
    --de-accent:   #8B1A1A;
}

/* ── UTILITIES ── */
.de-empty {
    display:flex; flex-direction:column; align-items:center;
    gap:10px; padding:48px; text-align:center; color:var(--de-gray);
}
.de-empty span { font-size:2.5rem; }
.de-empty p    { font-family:'EB Garamond',serif; font-size:1.1rem; }

.de-badge {
    display:inline-flex; align-items:center; gap:5px;
    font-family:'Lato',sans-serif; font-size:11px; font-weight:700;
    text-transform:uppercase; letter-spacing:.07em;
    padding:3px 10px; border-radius:20px;
}
.de-badge--presencial { background:#e8f5e9; color:#2e7d32; }
.de-badge--virtual    { background:#e3f2fd; color:#1565c0; }
.de-badge--hibrido    { background:#fff3e0; color:#e65100; }

.de-btn {
    display:inline-flex; align-items:center; gap:7px;
    font-family:'Lato',sans-serif; font-size:.82rem; font-weight:700;
    text-transform:uppercase; letter-spacing:.06em;
    padding:10px 22px; border-radius:4px;
    text-decoration:none; cursor:pointer; border:none;
    transition:all .2s ease;
}
.de-btn--primary {
    background:var(--de-crimson); color:#fff;
}
.de-btn--primary:hover { filter:brightness(1.15); transform:translateY(-1px); color:#fff; }
.de-btn--secondary {
    background:transparent; color:var(--de-crimson);
    border:2px solid var(--de-crimson);
}
.de-btn--secondary:hover { background:var(--de-crimson); color:#fff; }
.de-btn--outline-white {
    background:transparent; color:#fff; border:2px solid rgba(255,255,255,.7);
}
.de-btn--outline-white:hover { background:rgba(255,255,255,.15); color:#fff; }
.de-btn--lg { padding:14px 30px; font-size:.9rem; }

/* ── FILTROS ── */
.de-filters {
    display:flex; flex-wrap:wrap; gap:8px;
    margin-bottom:28px;
}
.de-filter-btn {
    font-family:'Lato',sans-serif; font-size:12px; font-weight:700;
    text-transform:uppercase; letter-spacing:.07em;
    padding:7px 18px; border-radius:30px; cursor:pointer;
    border:2px solid #ddd; background:#fff; color:var(--de-gray);
    transition:all .2s;
}
.de-filter-btn:hover, .de-filter-btn.active {
    border-color:var(--de-accent); background:var(--de-accent); color:#fff;
}

/* ── GRID ── */
.de-grid {
    display:grid; gap:24px;
}
.de-grid--cols-1 { grid-template-columns:1fr; }
.de-grid--cols-2 { grid-template-columns:repeat(2,1fr); }
.de-grid--cols-3 { grid-template-columns:repeat(3,1fr); }
.de-grid--cols-4 { grid-template-columns:repeat(4,1fr); }

@media (max-width:1024px) {
    .de-grid--cols-4, .de-grid--cols-3 { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px) {
    .de-grid { grid-template-columns:1fr !important; }
}

/* ── CARD ── */
.de-card {
    background:#fff; border-radius:var(--de-radius);
    overflow:hidden; display:flex; flex-direction:column;
    box-shadow:var(--de-shadow); font-family:'Lato',sans-serif;
    transition:transform .25s, box-shadow .25s;
    border-top:4px solid var(--de-accent);
}
.de-card:hover { transform:translateY(-5px); box-shadow:0 12px 36px rgba(28,15,15,.16); }

.de-card__thumb {
    position:relative; overflow:hidden; aspect-ratio:16/9;
}
.de-card__thumb img {
    width:100%; height:100%; object-fit:cover; display:block;
    transition:transform .4s;
}
.de-card:hover .de-card__thumb img { transform:scale(1.05); }
.de-card__tipo {
    position:absolute; top:12px; left:12px;
    background:var(--de-crimson); color:#fff;
    font-size:11px; font-weight:700; text-transform:uppercase;
    letter-spacing:.06em; padding:4px 12px; border-radius:20px; z-index:2;
}
.de-card__tipo--inline {
    position:static; display:inline-block; margin-bottom:10px;
}

.de-card__body {
    padding:0; flex:1; display:flex;
}

/* Date box */
.de-card__date-box {
    flex:0 0 72px; display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    padding:16px 0; border-right:1px solid #f0e8e0;
    background:var(--de-ivory);
}
.de-card__weekday {
    font-size:10px; font-weight:700; text-transform:uppercase;
    letter-spacing:.1em; color:var(--de-gray);
}
.de-card__day {
    font-family:'EB Garamond',serif; font-size:2.2rem;
    font-weight:700; line-height:1; color:var(--de-crimson);
}
.de-card__month {
    font-size:11px; font-weight:700; text-transform:uppercase;
    letter-spacing:.08em; color:var(--de-gray);
}

.de-card__content { flex:1; padding:16px 18px; display:flex; flex-direction:column; }

.de-card__title {
    font-family:'EB Garamond',serif; font-size:1.15rem;
    font-weight:700; line-height:1.35; margin:0 0 10px; color:var(--de-dark);
}
.de-card__title a { color:inherit; text-decoration:none; }
.de-card__title a:hover { color:var(--de-accent); }

.de-card__meta {
    display:flex; flex-wrap:wrap; gap:8px 14px;
    font-size:12px; color:var(--de-gray); margin-bottom:10px;
}
.de-card__meta-item { display:inline-flex; align-items:center; gap:4px; }
.de-card__meta-item svg { flex-shrink:0; }
.de-card__costo { color:var(--de-crimson); font-weight:700; }

.de-card__excerpt {
    font-size:.875rem; color:#555; line-height:1.65;
    margin:0 0 14px; flex:1;
}
.de-card__actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:auto; padding-top:12px; }

/* ── IMMERSIVE STYLE ── */
.de-style-immersive .de-card {
    min-height:280px; border-top:none; position:relative;
}
.de-style-immersive .de-card__thumb {
    position:absolute; inset:0; aspect-ratio:unset;
}
.de-style-immersive .de-card__thumb::after {
    content:''; position:absolute; inset:0;
    background:linear-gradient(to top, rgba(28,15,15,.9) 40%, rgba(28,15,15,.2));
}
.de-style-immersive .de-card__body {
    position:relative; z-index:2; flex-direction:column;
}
.de-style-immersive .de-card__date-box {
    background:transparent; border:none; flex-direction:row;
    gap:6px; padding:16px 16px 0;
}
.de-style-immersive .de-card__weekday,
.de-style-immersive .de-card__month { color:rgba(255,255,255,.6); }
.de-style-immersive .de-card__day   { font-size:1.6rem; }
.de-style-immersive .de-card__content { padding:8px 16px 16px; }
.de-style-immersive .de-card__title { color:#fff; }
.de-style-immersive .de-card__meta-item,
.de-style-immersive .de-card__excerpt { color:rgba(255,255,255,.75); }

/* ── COMPACT STYLE ── */
.de-style-compact .de-card { flex-direction:row; }
.de-style-compact .de-card__thumb { flex:0 0 130px; aspect-ratio:unset; }
.de-style-compact .de-card__body  { flex-direction:row; }
.de-style-compact .de-card__date-box { flex:0 0 60px; }
.de-style-compact .de-card__day   { font-size:1.7rem; }

/* ── TIMELINE STYLE ── */
.de-style-timeline .de-grid { position:relative; }
.de-style-timeline .de-grid::before {
    content:''; position:absolute; left:35px; top:0; bottom:0; width:2px;
    background:linear-gradient(to bottom, var(--de-accent), transparent);
    pointer-events:none;
}
.de-style-timeline .de-card {
    flex-direction:row; border-top:none;
    border-left:4px solid var(--de-accent);
    margin-left:16px;
}

/* ── CALENDAR ── */
.de-calendar-wrap { font-family:'Lato',sans-serif; }

.de-cal { display:grid; gap:0; border-radius:var(--de-radius); overflow:hidden; box-shadow:var(--de-shadow); }
.de-cal--with-list { grid-template-columns:1fr 280px; }
@media (max-width:768px) { .de-cal--with-list { grid-template-columns:1fr; } }

.de-cal__main { background:#fff; padding:24px; }
.de-cal__header {
    display:flex; align-items:center; justify-content:space-between;
    margin-bottom:20px;
}
.de-cal__month-title {
    font-family:'EB Garamond',serif; font-size:1.4rem;
    font-weight:700; color:var(--de-dark); margin:0;
}
.de-cal__nav {
    background:none; border:1px solid #e0d4c8; border-radius:6px;
    width:36px; height:36px; display:flex; align-items:center;
    justify-content:center; cursor:pointer; color:var(--de-gray);
    transition:all .2s;
}
.de-cal__nav:hover { background:var(--de-accent); border-color:var(--de-accent); color:#fff; }

.de-cal__grid {
    display:grid; grid-template-columns:repeat(7,1fr); gap:4px;
}
.de-cal__dow {
    text-align:center; font-size:11px; font-weight:700;
    text-transform:uppercase; letter-spacing:.08em;
    color:var(--de-gray); padding:6px 0;
}
.de-cal__cell {
    aspect-ratio:1; display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:3px;
    border-radius:6px; cursor:default; position:relative;
    transition:background .15s;
}
.de-cal__cell--has-event { cursor:pointer; }
.de-cal__cell--has-event:hover { background:var(--de-light); }
.de-cal__cell--today { background:var(--de-ivory); }
.de-cal__cell--today .de-cal__num { color:var(--de-accent); font-weight:700; }
.de-cal__cell--empty { opacity:.2; }
.de-cal__num { font-size:.85rem; line-height:1; }
.de-cal__dot {
    width:6px; height:6px; border-radius:50%;
    background:var(--de-accent);
}
.de-cal__count {
    position:absolute; top:2px; right:4px;
    font-size:9px; font-weight:700; color:var(--de-accent);
}

/* Popup */
.de-cal__popup {
    background:#fff; border-radius:8px;
    box-shadow:0 8px 32px rgba(0,0,0,.15);
    padding:14px; max-width:240px;
    position:absolute; z-index:100;
    font-size:.85rem;
}
.de-cal__popup-item { padding:6px 0; border-bottom:1px solid #f0e8e0; }
.de-cal__popup-item:last-child { border:none; }
.de-cal__popup-item a { color:var(--de-dark); text-decoration:none; font-weight:600; }
.de-cal__popup-item small { display:block; color:var(--de-gray); margin-top:2px; }

/* Sidebar */
.de-cal__sidebar { background:var(--de-ivory); padding:24px; border-left:1px solid #e8ddd0; }
.de-cal__sidebar-title {
    font-family:'EB Garamond',serif; font-size:1.1rem; font-weight:700;
    color:var(--de-dark); margin:0 0 16px;
    display:flex; align-items:center; gap:8px;
}
.de-cal__event-list { list-style:none; margin:0; padding:0; }
.de-cal__event-item {
    display:flex; gap:10px; padding:10px 0;
    border-bottom:1px solid #e0d4c8;
}
.de-cal__event-item:last-child { border:none; }
.de-cal__event-dot {
    flex:0 0 10px; height:10px; border-radius:50%;
    background:var(--de-accent); margin-top:4px;
}
.de-cal__event-info a {
    font-weight:700; color:var(--de-dark); font-size:.875rem;
    text-decoration:none; display:block; line-height:1.3;
}
.de-cal__event-info a:hover { color:var(--de-accent); }
.de-cal__event-info small { display:block; color:var(--de-gray); font-size:11px; margin-top:2px; }
.de-cal__event-lugar { color:var(--de-crimson) !important; }
.de-cal__no-events { color:var(--de-gray); font-style:italic; font-size:.875rem; }

/* ── COUNTDOWN ── */
.de-countdown {
    position:relative; background-size:cover; background-position:center;
    border-radius:var(--de-radius); overflow:hidden;
    font-family:'Lato',sans-serif; min-height:320px;
    display:flex; align-items:center; justify-content:center;
}
.de-countdown--minimal { min-height:180px; }
.de-countdown--banner  { min-height:160px; }

.de-countdown__overlay {
    position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(28,15,15,.80), rgba(60,20,20,.75));
}
.de-countdown__inner {
    position:relative; z-index:2;
    display:flex; flex-direction:column; align-items:center;
    gap:20px; padding:40px 32px; text-align:center; width:100%;
}
.de-countdown--banner .de-countdown__inner {
    flex-direction:row; justify-content:space-between;
    flex-wrap:wrap; gap:16px;
}

.de-countdown__icono { font-size:2.5rem; }
.de-countdown__title {
    font-family:'EB Garamond',serif; font-size:1.8rem;
    font-weight:700; color:#fff; margin:0; line-height:1.2;
}
.de-countdown--banner .de-countdown__title { font-size:1.3rem; }
.de-countdown__fecha, .de-countdown__lugar {
    display:flex; align-items:center; gap:6px;
    color:rgba(255,255,255,.75); font-size:.875rem; margin:0;
}
.de-countdown__info { display:flex; flex-direction:column; gap:6px; align-items:center; }
.de-countdown--banner .de-countdown__info { align-items:flex-start; text-align:left; }

.de-countdown__timer {
    display:flex; align-items:center; gap:8px;
}
.de-countdown__unit { display:flex; flex-direction:column; align-items:center; }
.de-countdown__num {
    font-family:'EB Garamond',serif; font-size:3rem; font-weight:700;
    color:var(--de-gold); line-height:1;
    text-shadow:0 2px 8px rgba(0,0,0,.4);
    min-width:72px; text-align:center;
}
.de-countdown--minimal .de-countdown__num { font-size:2.2rem; min-width:56px; }
.de-countdown--banner  .de-countdown__num { font-size:2rem;   min-width:52px; }
.de-countdown__label {
    font-size:10px; font-weight:700; text-transform:uppercase;
    letter-spacing:.12em; color:rgba(255,255,255,.6);
}
.de-countdown__sep {
    font-family:'EB Garamond',serif; font-size:2.5rem;
    color:var(--de-gold); align-self:flex-start; margin-top:4px;
}
.de-countdown__ended {
    font-family:'EB Garamond',serif; font-size:1.5rem;
    color:var(--de-gold); font-style:italic;
}

/* ── FEATURED ── */
.de-featured {
    display:grid; border-radius:var(--de-radius); overflow:hidden;
    box-shadow:var(--de-shadow); font-family:'Lato',sans-serif;
}
.de-featured--hero    { grid-template-columns:1fr 300px; }
.de-featured--split   { grid-template-columns:1fr 1fr; align-items:stretch; }
.de-featured--magazine { grid-template-columns:1fr; }

@media (max-width:900px) {
    .de-featured--hero, .de-featured--split { grid-template-columns:1fr; }
}

.de-featured__main {
    position:relative; background-size:cover; background-position:center;
    background-color:var(--de-dark); min-height:500px;
    display:flex; flex-direction:column; justify-content:flex-end;
}
.de-featured__overlay {
    position:absolute; inset:0;
    background:linear-gradient(to top, rgba(28,15,15,.88) 40%, rgba(28,15,15,.2));
}
.de-featured__content {
    position:relative; z-index:2; padding:36px 32px 30px;
    display:flex; flex-direction:column; gap:10px;
}
.de-featured__tipo {
    display:inline-block; background:var(--de-crimson); color:#fff;
    font-size:11px; font-weight:700; text-transform:uppercase;
    letter-spacing:.07em; padding:4px 14px; border-radius:20px;
    align-self:flex-start;
}
.de-featured__title {
    font-family:'EB Garamond',serif; font-size:2rem;
    font-weight:700; color:#fff; margin:0; line-height:1.3;
}
.de-featured__title a { color:inherit; text-decoration:none; }
.de-featured__title a:hover { text-decoration:underline; }
.de-featured__excerpt {
    color:rgba(255,255,255,.8); font-size:.9rem; line-height:1.65; margin:0;
}
.de-featured__meta {
    display:flex; flex-wrap:wrap; gap:12px;
    color:rgba(255,255,255,.7); font-size:.82rem;
}
.de-featured__meta span { display:inline-flex; align-items:center; gap:5px; }
.de-featured__actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:4px; }

/* Mini countdown */
.de-featured__mini-countdown {
    display:flex; align-items:center; gap:6px;
    background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,.15); border-radius:8px;
    padding:10px 18px; align-self:flex-start;
}
.de-featured__mc-unit { display:flex; flex-direction:column; align-items:center; min-width:36px; }
.de-featured__mc-num {
    font-family:'EB Garamond',serif; font-size:1.5rem; font-weight:700;
    color:var(--de-gold); line-height:1;
}
.de-featured__mc-unit span:last-child { font-size:9px; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.1em; }
.de-featured__mc-sep { color:var(--de-gold); font-size:1.2rem; align-self:flex-start; margin-top:2px; }

/* Hero sidebar */
.de-featured__sidebar { background:var(--de-ivory); display:flex; flex-direction:column; }
.de-featured__sidebar-item {
    display:flex; gap:12px; padding:16px 18px;
    border-bottom:1px solid #e0d4c8; transition:background .2s;
    align-items:flex-start;
}
.de-featured__sidebar-item:hover { background:#ede4d6; }
.de-featured__sidebar-item:last-child { border:none; }
.de-featured__sidebar-thumb {
    flex:0 0 80px; height:64px; border-radius:6px;
    overflow:hidden; display:block;
}
.de-featured__sidebar-thumb img { width:100%; height:100%; object-fit:cover; }
.de-featured__sidebar-body { flex:1; }
.de-featured__sidebar-tipo {
    display:block; font-size:11px; font-weight:700;
    text-transform:uppercase; letter-spacing:.06em; margin-bottom:4px;
}
.de-featured__sidebar-body h5 {
    font-family:'EB Garamond',serif; font-size:.95rem;
    font-weight:700; margin:0 0 4px; line-height:1.35;
}
.de-featured__sidebar-body h5 a { color:var(--de-dark); text-decoration:none; }
.de-featured__sidebar-body h5 a:hover { color:var(--de-accent); }
.de-featured__sidebar-body small { display:block; color:var(--de-gray); font-size:11px; }
.de-featured__sidebar-lugar { color:var(--de-crimson) !important; }

/* Split body */
.de-featured--split .de-featured__main { min-height:420px; }
.de-featured__split-body {
    background:#fff; display:flex; flex-direction:column;
    justify-content:center; padding:40px 36px; gap:14px;
}
.de-featured__split-body .de-featured__title { color:var(--de-dark); font-size:1.6rem; }
.de-featured__split-body .de-featured__title a { color:var(--de-dark); }
.de-featured__split-body .de-featured__excerpt { color:#555; }
.de-featured__split-body .de-featured__meta { color:var(--de-gray); }

/* Magazine */
.de-featured__magazine-grid {
    display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr));
}
.de-featured__mag-item {
    position:relative; background-size:cover; background-position:center;
    background-color:var(--de-dark); min-height:220px;
    display:flex; flex-direction:column; justify-content:flex-end;
    transition:transform .3s;
}
.de-featured__mag-item:hover { z-index:2; transform:scale(1.02); }
.de-featured__mag-item .de-featured__content { padding:20px; gap:6px; }
.de-featured__mag-item h4 { font-family:'EB Garamond',serif; font-size:1rem; color:#fff; margin:0; }
.de-featured__mag-item h4 a { color:inherit; text-decoration:none; }
.de-featured__mag-item small { color:rgba(255,255,255,.6); font-size:11px; }
