/* ==========================================================================
   Editorial Posts — Front-end Layouts v1.2
   ========================================================================== */

.ep-section-wrapper { display: flex; flex-direction: column; }

.ep-section {
    --ep-columns: 3;
    --ep-gap: 1.5rem;
    --ep-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
    --ep-color-text: #1a1a1a;
    --ep-color-muted: #6b6b6b;
    --ep-color-border: #e5e5e5;
    --ep-color-accent: #1a1a1a;
    font-family: var(--ep-font);
    color: var(--ep-color-text);
    margin-bottom: 2.5rem;
}

.ep-section-title {
    font-size: 1.5rem; font-weight: 400; letter-spacing: -0.01em;
    margin: 0 0 1.25rem 0; padding-bottom: 0.65rem; border-bottom: 1px solid var(--ep-color-border);
}

/* ── Archive Link ── */
.ep-archive-link {
    display: flex; justify-content: flex-end; margin-top: 0.75rem;
}
.ep-archive-link a {
    font-size: 0.82rem; font-weight: 500; color: var(--ep-color-muted);
    text-decoration: none; transition: color 0.2s;
}
.ep-archive-link a:hover { color: var(--ep-color-text); }

.ep-empty { padding: 3rem; text-align: center; color: var(--ep-color-muted); border: 1px dashed var(--ep-color-border); }

/* ── Shared ── */
.ep-card a, .ep-list-item a, .ep-mosaic a, .ep-compact a, .ep-overlay__link, .ep-banner__link, .ep-sidebar-item a { text-decoration: none; color: inherit; }

.ep-card__image, .ep-list-item__image, .ep-mosaic__image, .ep-compact__image,
.ep-overlay__image, .ep-banner__image, .ep-sidebar-item__image { overflow: hidden; background: #f0f0f0; }

.ep-card__image img, .ep-list-item__image img, .ep-mosaic__image img, .ep-compact__image img,
.ep-overlay__image img, .ep-banner__image img, .ep-sidebar-item__image img {
    width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease;
}

.ep-card:hover img, .ep-list-item:hover img, .ep-mosaic__item:hover img,
.ep-overlay__item:hover img, .ep-banner:hover img { transform: scale(1.03); }

.ep-card__category, .ep-overlay__category, .ep-banner__category {
    display: inline-block; font-size: 0.68rem; font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.08em; color: var(--ep-color-accent); margin-bottom: 0.35rem;
}

.ep-card__title a:hover, .ep-list-item__title a:hover, .ep-mosaic__title a:hover,
.ep-compact__title a:hover, .ep-sidebar-item__title a:hover { opacity: 0.7; }

.ep-card__excerpt, .ep-list-item__excerpt, .ep-mosaic__excerpt, .ep-banner__excerpt {
    font-size: 0.88rem; line-height: 1.5; color: var(--ep-color-muted); margin: 0.35rem 0 0;
}

.ep-card__meta { display: flex; align-items: center; gap: 0.3rem; font-size: 0.76rem; color: var(--ep-color-muted); margin-top: 0.5rem; }
.ep-card__sep { opacity: 0.4; }


/* ── Simple Grid ── */
.ep-grid { display: grid; grid-template-columns: repeat(var(--ep-columns), 1fr); gap: var(--ep-gap); }
.ep-grid .ep-card__image { aspect-ratio: 16 / 10; }
.ep-grid .ep-card__title { font-size: 1.02rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-grid .ep-card__content { padding: 0.65rem 0 0; }


/* ── Hero + Grid ── */
.ep-hero { margin-bottom: var(--ep-gap); }
.ep-hero .ep-card__image { aspect-ratio: 21 / 9; }
.ep-hero .ep-card__title { font-size: 1.65rem; font-weight: 700; line-height: 1.2; letter-spacing: -0.02em; margin: 0; }
.ep-hero .ep-card__content { padding: 0.85rem 0 0; }
.ep-hero .ep-card__excerpt { font-size: 1rem; max-width: 65ch; }


/* ── Text List ── */
.ep-text-list { display: flex; flex-direction: column; }
.ep-list-item { display: flex; gap: 1.15rem; padding: 1.1rem 0; border-bottom: 1px solid var(--ep-color-border); }
.ep-list-item:first-child { padding-top: 0; }
.ep-list-item:last-child { border-bottom: none; }
.ep-list-item__image { flex-shrink: 0; width: 170px; aspect-ratio: 3 / 2; }
.ep-list-item__content { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.ep-list-item__title { font-size: 1.02rem; font-weight: 600; line-height: 1.3; margin: 0; }


/* ── Magazine Mosaic ── */
.ep-mosaic { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--ep-gap); }
.ep-mosaic__item--featured { grid-column: span 2; }
.ep-mosaic__image { aspect-ratio: 16 / 10; }
.ep-mosaic__item--featured .ep-mosaic__image { aspect-ratio: 16 / 9; }
.ep-mosaic__content { padding: 0.65rem 0 0; }
.ep-mosaic__title { font-size: 0.92rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-mosaic__item--featured .ep-mosaic__title { font-size: 1.25rem; }


/* ── Compact Cards ── */
.ep-compact { display: grid; grid-template-columns: repeat(var(--ep-columns), 1fr); gap: 0; }
.ep-compact__item { display: flex; gap: 0.7rem; padding: 0.7rem 0; border-bottom: 1px solid var(--ep-color-border); }
.ep-compact__image { flex-shrink: 0; width: 60px; height: 60px; border-radius: 4px; }
.ep-compact__content { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.ep-compact__title { font-size: 0.85rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-compact__date { font-size: 0.7rem; color: var(--ep-color-muted); margin-top: 0.15rem; }


/* ── Overlay Grid ── */
.ep-overlay-grid { display: grid; grid-template-columns: repeat(var(--ep-columns), 1fr); gap: var(--ep-gap); }
.ep-overlay__item--large { grid-column: span 2; grid-row: span 2; }
.ep-overlay__link { display: block; position: relative; overflow: hidden; border-radius: 4px; height: 100%; min-height: 200px; }
.ep-overlay__image { position: absolute; inset: 0; }
.ep-overlay__image--placeholder { background: linear-gradient(135deg, #333 0%, #555 100%); }
.ep-overlay__image::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.1) 60%, transparent 100%); }
.ep-overlay__content { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.25rem; z-index: 1; color: #fff; }
.ep-overlay__category { color: rgba(255,255,255,0.85); font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.3rem; }
.ep-overlay__title { font-size: 1rem; font-weight: 600; line-height: 1.25; margin: 0; color: #fff; }
.ep-overlay__item--large .ep-overlay__title { font-size: 1.5rem; }
.ep-overlay__date { font-size: 0.7rem; color: rgba(255,255,255,0.7); margin-top: 0.3rem; display: block; }
.ep-overlay__item:hover .ep-overlay__image img { transform: scale(1.05); }


/* ── Full Banner ── */
.ep-banner__link { display: block; position: relative; overflow: hidden; border-radius: 4px; }
.ep-banner__image { aspect-ratio: 21 / 7; min-height: 260px; position: relative; }
.ep-banner__image::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.05) 60%, transparent 100%); }
.ep-banner__content { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem; z-index: 1; color: #fff; max-width: 720px; }
.ep-banner__category { color: rgba(255,255,255,0.9); background: rgba(255,255,255,0.15); padding: 0.15rem 0.5rem; border-radius: 3px; font-size: 0.65rem; }
.ep-banner__title { font-size: 2rem; font-weight: 700; line-height: 1.15; letter-spacing: -0.02em; margin: 0.5rem 0 0; color: #fff; }
.ep-banner__excerpt { color: rgba(255,255,255,0.85); font-size: 0.95rem; margin: 0.5rem 0 0; }
.ep-banner .ep-card__meta { color: rgba(255,255,255,0.65); }
.ep-banner:hover .ep-banner__image img { transform: scale(1.03); }


/* ── Split Layouts ── */
.ep-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--ep-gap); align-items: start; }
.ep-split__left, .ep-split__right { min-width: 0; }

/* Split: Hero + Sidebar */
.ep-split--hero-side { grid-template-columns: 3fr 2fr; }
.ep-split--hero-side .ep-split__left--hero .ep-card__image { aspect-ratio: 4 / 3; }
.ep-split--hero-side .ep-split__left--hero .ep-card__title { font-size: 1.4rem; font-weight: 700; line-height: 1.2; margin: 0; }
.ep-split--hero-side .ep-split__left--hero .ep-card__content { padding: 0.85rem 0 0; }

.ep-sidebar-item { display: flex; gap: 0.75rem; padding: 0.65rem 0; border-bottom: 1px solid var(--ep-color-border); }
.ep-sidebar-item:first-child { padding-top: 0; }
.ep-sidebar-item:last-child { border-bottom: none; }
.ep-sidebar-item__image { flex-shrink: 0; width: 72px; height: 72px; border-radius: 4px; }
.ep-sidebar-item__content { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.ep-sidebar-item__title { font-size: 0.88rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-sidebar-item__date { font-size: 0.7rem; color: var(--ep-color-muted); margin-top: 0.15rem; }

/* Split: List + Grid */
.ep-layout-split-list-grid .ep-split { grid-template-columns: 3fr 2fr; }
.ep-layout-split-list-grid .ep-list-item__image { width: 140px; }


/* ── Numbered List ── */
.ep-numbered { display: flex; flex-direction: column; }

.ep-numbered__item {
    display: flex; gap: 1rem; padding: 1rem 0;
    border-bottom: 1px solid var(--ep-color-border); align-items: flex-start;
}
.ep-numbered__item:first-child { padding-top: 0; }
.ep-numbered__item:last-child { border-bottom: none; }

.ep-numbered__rank {
    flex-shrink: 0; font-size: 2rem; font-weight: 800; line-height: 1;
    color: var(--ep-color-border); width: 2.5rem; text-align: center;
    font-variant-numeric: tabular-nums; padding-top: 0.15rem;
}

.ep-numbered__image-link { flex-shrink: 0; }
.ep-numbered__image { width: 130px; aspect-ratio: 3 / 2; border-radius: 4px; overflow: hidden; }
.ep-numbered__image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.ep-numbered__item:hover .ep-numbered__image img { transform: scale(1.03); }

.ep-numbered__content { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.ep-numbered__title { font-size: 1rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-numbered__title a { text-decoration: none; color: inherit; }
.ep-numbered__title a:hover { opacity: 0.7; }


/* ── Quote Highlight ── */
.ep-quote { margin-bottom: var(--ep-gap); }

.ep-quote__link {
    display: block; text-decoration: none; color: inherit;
    padding: 2rem; border: 1px solid var(--ep-color-border); border-radius: 4px;
    transition: border-color 0.2s;
}
.ep-quote__link:hover { border-color: var(--ep-color-accent); }

.ep-quote__block { text-align: center; }

.ep-quote__mark {
    display: inline; font-size: 2.5rem; font-weight: 300; line-height: 1;
    color: var(--ep-color-border); vertical-align: middle;
}

.ep-quote__title {
    display: inline; font-size: 1.5rem; font-weight: 600; line-height: 1.35;
    letter-spacing: -0.01em; color: var(--ep-color-text);
}

.ep-quote__excerpt {
    text-align: center; font-size: 0.92rem; color: var(--ep-color-muted);
    margin: 0.75rem auto 0; max-width: 55ch; line-height: 1.5;
}

.ep-quote__meta {
    display: flex; justify-content: center; gap: 0.5rem;
    font-size: 0.78rem; color: var(--ep-color-muted); margin-top: 0.75rem;
}
.ep-quote__author { font-weight: 600; }


/* ── Ticker ── */
.ep-ticker { overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; }

.ep-ticker__track {
    display: flex; gap: var(--ep-gap); padding-bottom: 0.5rem;
    min-width: min-content;
}

.ep-ticker__item {
    display: flex; gap: 0.65rem; text-decoration: none; color: inherit;
    flex-shrink: 0; width: 260px; padding: 0.75rem; border: 1px solid var(--ep-color-border);
    border-radius: 4px; transition: border-color 0.2s;
}
.ep-ticker__item:hover { border-color: var(--ep-color-accent); }

.ep-ticker__image { flex-shrink: 0; width: 56px; height: 56px; border-radius: 4px; overflow: hidden; }
.ep-ticker__image img { width: 100%; height: 100%; object-fit: cover; display: block; }

.ep-ticker__content { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.ep-ticker__title { font-size: 0.82rem; font-weight: 600; line-height: 1.3; margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ep-ticker__date { font-size: 0.68rem; color: var(--ep-color-muted); margin-top: 0.2rem; }

/* Scrollbar styling */
.ep-ticker::-webkit-scrollbar { height: 4px; }
.ep-ticker::-webkit-scrollbar-track { background: transparent; }
.ep-ticker::-webkit-scrollbar-thumb { background: var(--ep-color-border); border-radius: 2px; }
.ep-ticker::-webkit-scrollbar-thumb:hover { background: #bbb; }


/* ── Alternating ── */
.ep-alternating { display: flex; flex-direction: column; gap: var(--ep-gap); }

.ep-alt-item {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--ep-gap); align-items: center;
}

.ep-alt-item--reverse .ep-alt-item__image-link { order: 2; }
.ep-alt-item--reverse .ep-alt-item__content { order: 1; }

.ep-alt-item__image { aspect-ratio: 16 / 10; border-radius: 4px; overflow: hidden; }
.ep-alt-item__image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.ep-alt-item:hover .ep-alt-item__image img { transform: scale(1.03); }

.ep-alt-item__content { padding: 0 0.5rem; }
.ep-alt-item__title { font-size: 1.25rem; font-weight: 700; line-height: 1.25; letter-spacing: -0.01em; margin: 0; }
.ep-alt-item__title a { text-decoration: none; color: inherit; }
.ep-alt-item__title a:hover { opacity: 0.7; }


/* ── Mini Grid ── */
.ep-mini-grid {
    display: grid; grid-template-columns: repeat(var(--ep-columns), 1fr); gap: 0;
}

.ep-mini__item { border-bottom: 1px solid var(--ep-color-border); }
.ep-mini__item a {
    display: block; padding: 0.6rem 0.25rem; text-decoration: none; color: inherit;
    transition: background 0.15s;
}
.ep-mini__item a:hover { background: #fafafa; }
.ep-mini__title { font-size: 0.88rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-mini__date { font-size: 0.68rem; color: var(--ep-color-muted); margin-top: 0.15rem; display: block; }


/* ── Featured + 2 Side ── */
.ep-feat-plus {
    display: grid; grid-template-columns: 3fr 2fr; gap: var(--ep-gap); align-items: stretch;
}

.ep-feat-plus__main .ep-card__image { aspect-ratio: 4 / 3; height: 100%; }
.ep-feat-plus__main .ep-card { height: 100%; display: flex; flex-direction: column; }
.ep-feat-plus__main .ep-card__image-link { flex: 1; }
.ep-feat-plus__main .ep-card__title { font-size: 1.4rem; font-weight: 700; line-height: 1.2; margin: 0; }
.ep-feat-plus__main .ep-card__content { padding: 0.85rem 0 0; }

.ep-feat-plus__side { display: flex; flex-direction: column; gap: var(--ep-gap); }
.ep-feat-plus__side .ep-card__image { aspect-ratio: 16 / 9; }
.ep-feat-plus__side .ep-card__title { font-size: 0.95rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-feat-plus__side .ep-card__content { padding: 0.5rem 0 0; }


/* ── Horizontal Cards (scrollable row) ── */
.ep-cards-row {
    display: flex; gap: var(--ep-gap); overflow-x: auto; overflow-y: hidden;
    -webkit-overflow-scrolling: touch; padding-bottom: 0.5rem; scroll-snap-type: x mandatory;
}

.ep-hcard {
    flex-shrink: 0; width: 280px; scroll-snap-align: start;
    border: 1px solid var(--ep-color-border); border-radius: 6px; overflow: hidden;
    transition: border-color 0.2s;
}
.ep-hcard:hover { border-color: var(--ep-color-accent); }

.ep-hcard__image { aspect-ratio: 16 / 10; overflow: hidden; }
.ep-hcard__image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.ep-hcard:hover .ep-hcard__image img { transform: scale(1.03); }

.ep-hcard__content { padding: 0.75rem; }
.ep-hcard__title { font-size: 0.9rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-hcard__title a { text-decoration: none; color: inherit; }
.ep-hcard__title a:hover { opacity: 0.7; }

.ep-cards-row::-webkit-scrollbar { height: 4px; }
.ep-cards-row::-webkit-scrollbar-track { background: transparent; }
.ep-cards-row::-webkit-scrollbar-thumb { background: var(--ep-color-border); border-radius: 2px; }


/* ── Timeline ── */
.ep-timeline { position: relative; padding-left: 2rem; }

.ep-timeline::before {
    content: ''; position: absolute; left: 0.5rem; top: 0; bottom: 0;
    width: 2px; background: var(--ep-color-border);
}

.ep-timeline__item { position: relative; margin-bottom: var(--ep-gap); }
.ep-timeline__item:last-child { margin-bottom: 0; }

.ep-timeline__dot {
    position: absolute; left: -1.65rem; top: 0.35rem;
    width: 10px; height: 10px; border-radius: 50%;
    background: var(--ep-color-accent); border: 2px solid #fff;
    box-shadow: 0 0 0 2px var(--ep-color-border);
}

.ep-timeline__card { display: flex; gap: 1rem; }

.ep-timeline__image { flex-shrink: 0; width: 140px; aspect-ratio: 3 / 2; border-radius: 4px; overflow: hidden; }
.ep-timeline__image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.ep-timeline__item:hover .ep-timeline__image img { transform: scale(1.03); }

.ep-timeline__content { flex: 1; min-width: 0; }
.ep-timeline__date { font-size: 0.72rem; font-weight: 600; color: var(--ep-color-muted); text-transform: uppercase; letter-spacing: 0.04em; display: block; margin-bottom: 0.2rem; }
.ep-timeline__title { font-size: 1.02rem; font-weight: 600; line-height: 1.3; margin: 0; }
.ep-timeline__title a { text-decoration: none; color: inherit; }
.ep-timeline__title a:hover { opacity: 0.7; }


/* ── Stacked Headlines ── */
.ep-stacked { display: flex; flex-direction: column; }

.ep-stacked__item { border-bottom: 1px solid var(--ep-color-border); }
.ep-stacked__item:last-child { border-bottom: none; }

.ep-stacked__link {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1.25rem; padding: 1rem 0; text-decoration: none; color: inherit;
    transition: opacity 0.15s;
}
.ep-stacked__link:hover { opacity: 0.75; }

.ep-stacked__text { flex: 1; min-width: 0; }

.ep-stacked__title {
    font-size: 1.35rem; font-weight: 700; line-height: 1.2;
    letter-spacing: -0.02em; margin: 0;
}

.ep-stacked__thumb {
    flex-shrink: 0; width: 80px; height: 80px; border-radius: 4px;
    overflow: hidden;
}
.ep-stacked__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }


/* ── Responsive ── */
@media (max-width: 768px) {
    .ep-section { --ep-columns: 1; }
    .ep-grid, .ep-mosaic, .ep-overlay-grid, .ep-mini-grid { grid-template-columns: 1fr; }
    .ep-mosaic__item--featured, .ep-overlay__item--large { grid-column: span 1; grid-row: span 1; }
    .ep-split, .ep-split--hero-side, .ep-layout-split-list-grid .ep-split { grid-template-columns: 1fr; }
    .ep-feat-plus { grid-template-columns: 1fr; }
    .ep-alt-item { grid-template-columns: 1fr; }
    .ep-alt-item--reverse .ep-alt-item__image-link { order: 0; }
    .ep-alt-item--reverse .ep-alt-item__content { order: 0; }
    .ep-list-item__image { width: 110px; }
    .ep-numbered__image { width: 90px; }
    .ep-numbered__rank { font-size: 1.5rem; width: 2rem; }
    .ep-hero .ep-card__title { font-size: 1.3rem; }
    .ep-hero .ep-card__image { aspect-ratio: 16 / 10; }
    .ep-banner__title { font-size: 1.3rem; }
    .ep-banner__image { aspect-ratio: 16 / 9; min-height: 200px; }
    .ep-banner__content { padding: 1.25rem; }
    .ep-ticker__item { width: 220px; }
    .ep-hcard { width: 240px; }
    .ep-timeline__image { width: 100px; }
    .ep-stacked__title { font-size: 1.1rem; }
    .ep-stacked__thumb { width: 64px; height: 64px; }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .ep-section { --ep-columns: 2; }
    .ep-grid, .ep-overlay-grid, .ep-mini-grid { grid-template-columns: repeat(2, 1fr); }
    .ep-mosaic { grid-template-columns: repeat(2, 1fr); }
    .ep-mosaic__item--featured { grid-column: span 1; }
    .ep-overlay__item--large { grid-column: span 2; grid-row: span 1; }
    .ep-feat-plus { grid-template-columns: 1fr 1fr; }
}
