/* BC Editorial — front styles v3.5 */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Inter:wght@300;400;500;600&display=swap");

.bred {
	--bred-fg: #1a1714;
	--bred-muted: #6b6661;
	--bred-border: #e8e6e2;
	--bred-mist: #f3f4f6;
	--bred-sand: #f3e8dc;
	--bred-coral: #d96a44;
	--bred-coral-fg: #fff;
	--bred-display: "Cormorant Garamond", Georgia, serif;
	--bred-sans: "Inter", system-ui, sans-serif;
	--bred-gap: 24px;
	--bred-radius: 0px;
	--bred-img-h: 360px;
	--bred-max: 1200px;

	max-width: var(--bred-max);
	margin: 0 auto;
	padding: 0 1.5rem;
	color: var(--bred-fg);
	font-family: var(--bred-sans);
	font-weight: 300;
	line-height: 1.55;
	box-sizing: border-box;
}
.bred *, .bred *::before, .bred *::after { box-sizing: border-box; }
.bred a { color: inherit; text-decoration: none; }

.bred__tagline { text-align: center; font-weight: 500; margin: 0 0 2rem; font-size: 0.9rem; }

.bred__h3 {
	font-family: var(--bred-display);
	font-weight: 500;
	letter-spacing: -0.01em;
	margin: 0;
	font-size: clamp(1.2rem, 1.8vw, 1.5rem);
}
.bred__excerpt { color: var(--bred-muted); font-size: 0.9rem; margin: 0.6rem 0 0; }

/* Layout containers */
.bred__flow--free { display: flex; flex-wrap: wrap; gap: var(--bred-gap); align-items: stretch; }
.bred__flow--grid { display: grid; gap: var(--bred-gap); grid-auto-rows: minmax(180px, auto); align-items: stretch; }

.bred__b { display: block; min-width: 0; position: relative; overflow: hidden; }
.bred__b-img {
	display: block; width: 100%; height: var(--bred-img-h);
	object-fit: cover; border-radius: var(--bred-radius);
	transition: transform .55s ease;
}
.bred__b:hover .bred__b-img { transform: scale(1.04); }
.bred__img-fallback { background: var(--bred-mist); }
.bred__b-body { padding-top: 1rem; }
.bred__b-caption { font-size: .8rem; color: var(--bred-muted); padding: .5rem 0 0; }
.bred__b-embed { width: 100%; height: var(--bred-img-h); border: 0; border-radius: var(--bred-radius); }
.bred__b-embed iframe, .bred__b-embed video { width: 100%; height: 100%; border: 0; }

/* Tags */
.bred__b-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: .5rem; }
.bred__b-tag {
	font-size: .68rem; letter-spacing: .06em; text-transform: uppercase;
	padding: 3px 8px; background: var(--bred-mist); color: var(--bred-fg);
	border-radius: 999px;
}

/* Hover meta layer (reading time, share) */
.bred__b-hover {
	position: absolute; top: 10px; right: 10px;
	display: flex; gap: 6px; align-items: center;
	opacity: 0; transform: translateY(-6px);
	transition: opacity .25s ease, transform .25s ease;
	z-index: 3;
}
.bred__b:hover .bred__b-hover, .bred__b:focus-within .bred__b-hover {
	opacity: 1; transform: translateY(0);
}
.bred__b-meta-item {
	background: rgba(0,0,0,.65); color:#fff; font-size:.72rem;
	padding: 4px 9px; border-radius: 999px; backdrop-filter: blur(4px);
}
.bred__b-share {
	background: rgba(0,0,0,.65); color:#fff; border: 0; cursor: pointer;
	width: 30px; height: 30px; border-radius: 999px;
	display: inline-flex; align-items: center; justify-content: center;
	backdrop-filter: blur(4px); transition: background .2s;
}
.bred__b-share:hover { background: var(--bred-coral); }

/* Post overlay */
.bred__b--overlay { position: relative; min-height: 0; }
/* Ensure the overlay block stretches to fill its grid/flex cell, never overflows it */
.bred__b--overlay {
	display: block;
	height: 100%;
	align-self: stretch;
	overflow: hidden !important;
	background: #111;
}
.bred__b--overlay::after {
	content:""; position:absolute; inset:0; pointer-events:none;
	background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.65) 100%);
	border-radius: var(--bred-radius);
}
.bred__b--overlay .bred__b-img {
	position: absolute; inset: 0;
	width: 100%; height: 100% !important;
	min-height: 100%;
	max-height: 100%;
	display: block;
}
.bred__b--overlay .bred__b-overlay-content {
	position: absolute; left: 1.25rem; right: 1.25rem; bottom: 1.25rem;
	color: #fff; z-index: 2;
}
.bred__b--overlay .bred__b-overlay-title {
	font-size: clamp(1.2rem, 2vw, 1.6rem);
	font-family: var(--bred-display); font-weight: 500;
	text-shadow: 0 2px 12px rgba(0,0,0,.4); margin: 0;
}
.bred__b--overlay .bred__b-overlay-excerpt {
	font-size: .85rem; margin: .4rem 0 0; opacity: .9;
}
.bred__b--overlay .bred__b-tags .bred__b-tag {
	background: rgba(255,255,255,.18); color: #fff; backdrop-filter: blur(4px);
}

/* Card */
.bred__b--card { display: flex; flex-direction: column; }

/* Quote */
.bred__b--quote {
	background: var(--bred-coral); color: var(--bred-coral-fg);
	padding: 2.5rem; margin: 0;
	display: flex; flex-direction: column; justify-content: center;
	border-radius: var(--bred-radius);
}
.bred__b--quote p {
	font-family: var(--bred-display);
	font-size: 1.5rem; font-style: italic; margin: 0;
	font-weight: 500;
}
.bred__b--quote cite { margin-top: 1.25rem; font-style: normal; font-size: 0.85rem; display:block; opacity:.85; }

/* Pillar */
.bred__b--pillar {
	background: var(--bred-mist);
	padding: 2rem;
	border-radius: var(--bred-radius);
}
.bred__b--linked { transition: transform .25s ease, box-shadow .25s ease; }
.bred__b--linked:hover { transform: translateY(-3px); box-shadow: 0 12px 30px -12px rgba(0,0,0,.18); }

/* Media */
.bred__b--media { padding: 0; margin: 0; }
.bred__b--media video { width:100%; height: var(--bred-img-h); object-fit: cover; border-radius: var(--bred-radius); }

/* Media caption overlay */
.bred__b--media-overlay { position: relative; overflow: hidden; }
.bred__b--media-overlay::after {
	content:""; position:absolute; inset:0; pointer-events:none;
	background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.7) 100%);
	border-radius: var(--bred-radius);
}
.bred__b-caption--overlay {
	position: absolute; left: 1rem; right: 1rem; bottom: 1rem;
	color:#fff; padding: 0; z-index: 2;
	font-size: .9rem; line-height: 1.35;
	text-shadow: 0 2px 12px rgba(0,0,0,.4);
}

.bred__b--empty {
	background: #f9f9f9; border: 1px dashed var(--bred-border);
	padding: 1.5rem; text-align: center; color: var(--bred-muted);
}
.bred-empty {
	text-align: center; padding: 3rem 1rem; color: var(--bred-muted);
	font-family: var(--bred-sans); border: 1px dashed var(--bred-border);
}

/* Animations (lightweight, GPU only) */
@keyframes bredFadeUp {
	from { opacity: 0; transform: translateY(14px); }
	to   { opacity: 1; transform: translateY(0); }
}
.bred__b--in {
	animation: bredFadeUp .55s ease both;
}
.bred__b--lazy { display: none; }
.bred__b--lazy.bred__b--in { display: block; }
.bred__b--lazy.bred__b--card.bred__b--in { display: flex; }

@media (prefers-reduced-motion: reduce) {
	.bred__b--in { animation: none; }
	.bred__b:hover .bred__b-img { transform: none; }
}

/* Responsive */
@media (max-width: 900px) {
	.bred__flow--grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
	.bred__flow--grid > .bred__b { grid-column: span 1 !important; grid-row: span 1 !important; }
}
@media (max-width: 640px) {
	.bred { padding: 0 1rem; }
	.bred__flow--free > .bred__b {
		flex: 0 0 100% !important;
		max-width: 100% !important;
	}
	.bred__flow--grid { grid-template-columns: 1fr !important; }
	.bred__b--quote { padding: 1.5rem; }
	.bred__b--quote p { font-size: 1.2rem; }
	.bred__b-img, .bred__b--media video, .bred__b-embed { height: auto; min-height: 220px; aspect-ratio: 16/10; }
}

/* Share toast */
.bred-toast {
	position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%);
	background: #111; color: #fff; padding: 10px 16px; border-radius: 999px;
	font-family: var(--bred-sans, system-ui); font-size: 13px; z-index: 99999;
	box-shadow: 0 12px 30px -10px rgba(0,0,0,.4);
	animation: bredFadeUp .25s ease both;
}

/* ===== v3.1 additions ===== */

/* Hide internal scrollbar but keep scrolling */
.bred__b--noscrollbar { scrollbar-width: none; -ms-overflow-style: none; }
.bred__b--noscrollbar::-webkit-scrollbar { width: 0; height: 0; display: none; }

/* When block has fixed height, make image fill it nicely */
.bred__b[style*="height:"] .bred__b-img,
.bred__b[style*="height:"] .bred__b-embed {
	height: 100%;
	min-height: 100%;
}
/* Overlay blocks must always clip image, never scroll */
.bred__b--overlay[style*="height:"],
.bred__b--overlay[style*="min-height:"] { overflow: hidden !important; }

/* Overlay forces white text by default; user can still override per-card */
.bred__b--overlay { color: #fff; }
.bred__b--overlay .bred__b-overlay-content,
.bred__b--overlay .bred__b-overlay-title,
.bred__b--overlay .bred__b-overlay-excerpt { color: inherit; }

/* Card text uses block color (custom or inherited) */
.bred__b--card { color: inherit; }
.bred__b--card .bred__h3,
.bred__b--card .bred__excerpt { color: inherit; }

/* ============ MODAL READER ============ */
.bred-modal {
	position: fixed; inset: 0; z-index: 100000;
	display: flex; align-items: center; justify-content: center;
	background: rgba(10,8,6,.65);
	backdrop-filter: blur(6px);
	animation: bredFadeIn .25s ease both;
	font-family: var(--bred-sans, system-ui);
	color: var(--bred-fg, #1a1714);
}
@keyframes bredFadeIn { from{opacity:0} to{opacity:1} }
.bred-modal__panel {
	background: #fff;
	width: min(960px, 92vw);
	max-height: 92vh;
	border-radius: 12px;
	overflow: hidden;
	display: flex; flex-direction: column;
	box-shadow: 0 30px 80px -20px rgba(0,0,0,.5);
	animation: bredZoomIn .3s cubic-bezier(.22,.9,.3,1) both;
}
@keyframes bredZoomIn { from{transform:scale(.96);opacity:0} to{transform:scale(1);opacity:1} }
.bred-modal__close {
	position: absolute; top: 16px; right: 16px;
	width: 40px; height: 40px; border-radius: 999px;
	background: rgba(0,0,0,.55); color: #fff; border: 0;
	cursor: pointer; font-size: 22px; line-height: 1;
	display: inline-flex; align-items: center; justify-content: center;
	z-index: 5;
}
.bred-modal__close:hover { background: var(--bred-coral, #d96a44); }
.bred-modal__hero {
	width: 100%; height: 320px; object-fit: cover;
	display: block; flex: none;
}
.bred-modal__scroll {
	overflow: auto; padding: 28px 36px 36px;
	scroll-behavior: smooth;
}
.bred-modal__scroll::-webkit-scrollbar { width: 8px; }
.bred-modal__scroll::-webkit-scrollbar-thumb { background: #ddd; border-radius: 8px; }
.bred-modal__meta {
	display: flex; gap: 12px; flex-wrap: wrap;
	font-size: 12px; color: var(--bred-muted, #6b6661);
	text-transform: uppercase; letter-spacing: .06em;
	margin-bottom: 12px;
}
.bred-modal__title {
	font-family: var(--bred-display); font-weight: 500;
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	line-height: 1.15; margin: 0 0 18px;
	letter-spacing: -0.01em;
}
.bred-modal__content {
	font-family: var(--bred-sans);
	font-size: 1rem; line-height: 1.7;
}
.bred-modal__content p { margin: 0 0 1em; }
.bred-modal__content img { max-width: 100%; height: auto; border-radius: 6px; }
.bred-modal__content h2,
.bred-modal__content h3 { font-family: var(--bred-display); font-weight: 500; margin-top: 1.6em; }

.bred-modal__share {
	display: flex; gap: 8px; flex-wrap: wrap;
	padding: 14px 0; border-top: 1px solid var(--bred-border);
	margin-top: 24px;
}
.bred-modal__share-btn {
	display: inline-flex; align-items: center; gap: 6px;
	background: var(--bred-mist, #f3f4f6); color: var(--bred-fg);
	padding: 8px 14px; border-radius: 999px; border: 0;
	font-size: 13px; cursor: pointer; text-decoration: none;
	transition: background .2s;
}
.bred-modal__share-btn:hover { background: var(--bred-coral, #d96a44); color: #fff; }

.bred-modal__related {
	border-top: 1px solid var(--bred-border);
	padding-top: 18px; margin-top: 12px;
}
.bred-modal__related h4 {
	font-size: 12px; text-transform: uppercase; letter-spacing: .08em;
	color: var(--bred-muted); margin: 0 0 12px; font-weight: 600;
}
.bred-modal__related-list {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 12px;
}
.bred-modal__related-item {
	cursor: pointer; background: none; border: 0; padding: 0; text-align: left;
	color: inherit; font-family: inherit;
}
.bred-modal__related-thumb {
	width: 100%; aspect-ratio: 4/3; object-fit: cover;
	border-radius: 6px; background: var(--bred-mist);
	transition: transform .3s ease;
}
.bred-modal__related-item:hover .bred-modal__related-thumb { transform: scale(1.04); }
.bred-modal__related-title {
	font-size: 12px; line-height: 1.35; margin: 6px 0 0;
	color: var(--bred-fg);
}

/* Modal presets */
.bred-modal--magazine .bred-modal__panel { max-width: 1100px; width: 96vw; }
.bred-modal--magazine .bred-modal__hero  { height: 460px; }
.bred-modal--magazine .bred-modal__scroll{ padding: 40px 60px 50px; }
.bred-modal--magazine .bred-modal__title { font-size: clamp(2rem, 4vw, 3.2rem); }

.bred-modal--minimal .bred-modal__panel { max-width: 720px; border-radius: 4px; }
.bred-modal--minimal .bred-modal__hero  { display: none; }
.bred-modal--minimal .bred-modal__scroll{ padding: 48px 40px; }

.bred-modal--drawer { align-items: stretch; justify-content: flex-end; }
.bred-modal--drawer .bred-modal__panel {
	height: 100vh; max-height: 100vh; width: min(560px, 100vw);
	border-radius: 0;
	animation: bredSlideIn .35s cubic-bezier(.22,.9,.3,1) both;
}
@keyframes bredSlideIn { from{transform:translateX(40px);opacity:0} to{transform:translateX(0);opacity:1} }
.bred-modal--drawer .bred-modal__hero { height: 240px; }

/* Drawer left */
.bred-modal--drawer-left { align-items: stretch; justify-content: flex-start; }
.bred-modal--drawer-left .bred-modal__panel {
	height: 100vh; max-height: 100vh; width: min(560px, 100vw);
	border-radius: 0;
	animation: bredSlideInLeft .35s cubic-bezier(.22,.9,.3,1) both;
}
@keyframes bredSlideInLeft { from{transform:translateX(-40px);opacity:0} to{transform:translateX(0);opacity:1} }
.bred-modal--drawer-left .bred-modal__hero { height: 240px; }

/* Split presets — image on one side, content on the other */
.bred-modal--split-left .bred-modal__panel,
.bred-modal--split-right .bred-modal__panel {
	max-width: 1100px; width: 96vw;
	display: grid; grid-template-columns: 1fr 1fr; gap: 0;
	max-height: 92vh; overflow: hidden;
}
.bred-modal--split-left .bred-modal__panel { direction: ltr; }
.bred-modal--split-left .bred-modal__hero  { order: 0; height: 100%; max-height: 92vh; width: 100%; }
.bred-modal--split-left .bred-modal__scroll{ order: 1; max-height: 92vh; padding: 36px 40px; }
.bred-modal--split-right .bred-modal__hero { order: 1; height: 100%; max-height: 92vh; width: 100%; }
.bred-modal--split-right .bred-modal__scroll{ order: 0; max-height: 92vh; padding: 36px 40px; }
@media (max-width: 820px) {
	.bred-modal--split-left .bred-modal__panel,
	.bred-modal--split-right .bred-modal__panel {
		grid-template-columns: 1fr; max-height: 94vh;
	}
	.bred-modal--split-left .bred-modal__hero,
	.bred-modal--split-right .bred-modal__hero { height: 220px; max-height: 220px; }
}

@media (max-width: 640px) {
	.bred-modal__panel { width: 96vw; max-height: 94vh; }
	.bred-modal__hero  { height: 200px; }
	.bred-modal__scroll{ padding: 20px 18px 28px; }
	.bred-modal--drawer .bred-modal__panel { width: 100vw; }
}

/* v3.6 — group block (vertical stack inside a grid cell) */
.bred__b--group{padding:0 !important;background:transparent !important;display:flex;flex-direction:column;min-height:0;}
.bred__b-group-inner{width:100%;height:100%;}
.bred__b-group-cell{min-height:0;display:flex;}
.bred__b-group-cell > .bred__b{width:100%;flex:1 1 auto;min-height:0;}
@media (max-width:600px){
  .bred__b--group .bred__b-group-inner{grid-template-rows:none !important;display:flex !important;flex-direction:column;}
}
