/* =====================================================================
   Weekly Bangla Post NYC — main stylesheet
   Light, dense, traditional Bangla newspaper layout.
   Palette derived from the masthead logo: navy / red / Bangladesh green.
   ===================================================================== */

:root {
	--wbp-navy: #1b2a5e;
	--wbp-navy-dark: #14204a;
	--wbp-red: #cc1640;
	--wbp-red-dark: #a3102f;
	--wbp-green: #009048;
	--wbp-accent: #cc1640;          /* primary accent (red) */
	--wbp-accent-dark: #a3102f;
	--wbp-ink: #15171c;
	--wbp-body: #2a2e35;
	--wbp-muted: #6b7280;
	--wbp-line: #e3e5e9;
	--wbp-line-soft: #eef0f2;
	--wbp-bg: #ffffff;
	--wbp-band: #f4f6f8;
	--wbp-radius: 6px;
	--wbp-shadow: 0 1px 3px rgba(16,24,40,.07), 0 8px 22px rgba(16,24,40,.05);
	--wbp-wrap: 1340px;
	--font-bn: 'SolaimanLipi', 'Noto Sans Bengali', 'Hind Siliguri', system-ui, sans-serif;
	--font-head: 'SolaimanLipi', 'Noto Serif Bengali', 'Noto Sans Bengali', serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0; font-family: var(--font-bn); font-size: 16px; line-height: 1.7;
	color: var(--wbp-body); background: var(--wbp-bg); -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--wbp-accent); text-decoration: none; }
a:hover { color: var(--wbp-accent-dark); }
h1,h2,h3,h4,h5 { font-family: var(--font-head); color: var(--wbp-ink); line-height: 1.32; margin: 0 0 .4em; font-weight: 700; }

.wbp-wrap { max-width: var(--wbp-wrap); margin: 0 auto; padding: 0 24px; }
.wbp-skip { position: absolute; left: -9999px; top: 0; z-index: 1000; background: var(--wbp-accent); color: #fff; padding: 10px 16px; }
.wbp-skip:focus { left: 0; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap; }
.dashicons { font-family: dashicons; vertical-align: middle; }

/* ---------- Top bar ---------- */
.wbp-topbar { background: var(--wbp-navy); color: #c6cce0; font-size: 13.5px; }
.wbp-topbar__inner { display: flex; align-items: center; justify-content: space-between; min-height: 40px; gap: 12px; }
.wbp-topbar__date .dashicons { font-size: 16px; width: 16px; height: 16px; color: #fff; opacity: .8; }
.wbp-topbar__social { display: flex; align-items: center; gap: 4px; }
.wbp-topbar__social a:not(.wbp-topbar__epaper) { color: #c6cce0; display: inline-flex; width: 30px; height: 30px; align-items: center; justify-content: center; border-radius: 50%; transition: .15s; }
.wbp-topbar__social a:not(.wbp-topbar__epaper):hover { background: rgba(255,255,255,.14); color: #fff; }
/* E-paper button (clean pill, not a circle) */
.wbp-topbar__social a.wbp-topbar__epaper,
.wbp-topbar__epaper {
	display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
	width: auto; height: auto; background: var(--wbp-red); color: #fff !important; padding: 7px 16px;
	border-radius: 4px; font-weight: 700; line-height: 1; margin-left: 8px;
}
.wbp-topbar__epaper:hover { background: var(--wbp-red-dark); }
.wbp-topbar__epaper .dashicons { font-size: 16px; width: 16px; height: 16px; }

/* ---------- Masthead ---------- */
.wbp-masthead { background: #fff; border-bottom: 1px solid var(--wbp-line); }
.wbp-masthead__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 20px 24px; }
.wbp-brand { display: flex; align-items: center; }
.wbp-brand__text { display: block; }
.wbp-brand__name { display: block; font-family: var(--font-head); font-size: 38px; font-weight: 700; color: var(--wbp-navy); line-height: 1; }
.wbp-brand__name b { color: var(--wbp-red); }
.wbp-brand__tag { display: block; font-size: 14px; color: var(--wbp-muted); margin-top: 6px; }
.custom-logo, .wbp-brand__logo { max-height: 92px; width: auto; }
.wbp-masthead__ad { flex: 0 0 auto; max-width: 728px; margin-left: auto; }
.wbp-masthead__ad img { margin: 0 auto; }

/* ---------- Nav ---------- */
.wbp-nav { background: var(--wbp-navy); position: sticky; top: 0; z-index: 200; box-shadow: 0 2px 8px rgba(0,0,0,.14); }
.wbp-nav__inner { display: flex; align-items: center; gap: 10px; }
.wbp-menu { display: flex; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; flex: 1; }
.wbp-menu > li { position: relative; }
.wbp-menu > li > a { display: block; color: #fff; padding: 13px 16px; font-weight: 700; font-size: 16px; transition: background .15s; }
.wbp-menu > li > a:hover, .wbp-menu > li.current-menu-item > a, .wbp-menu > li.current-cat > a { background: var(--wbp-red); color: #fff; }
.wbp-menu .menu-item--epaper > a { background: var(--wbp-red); }
.wbp-menu .menu-item--epaper > a:hover { background: var(--wbp-red-dark); }
.wbp-menu ul.sub-menu { position: absolute; top: 100%; left: 0; min-width: 210px; background: #fff; list-style: none; margin: 0; padding: 6px 0; box-shadow: var(--wbp-shadow); border-top: 3px solid var(--wbp-red); opacity: 0; visibility: hidden; transform: translateY(6px); transition: .15s; z-index: 50; }
.wbp-menu li:hover > ul.sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.wbp-menu ul.sub-menu a { display: block; color: var(--wbp-ink); padding: 9px 16px; font-size: 15px; }
.wbp-menu ul.sub-menu a:hover { background: var(--wbp-band); color: var(--wbp-red); }
.wbp-nav__toggle { display: none; background: transparent; border: 0; color: #fff; font-weight: 700; font-size: 16px; padding: 12px 8px; cursor: pointer; align-items: center; gap: 6px; }
.wbp-nav__search { display: flex; align-items: center; background: rgba(255,255,255,.14); border-radius: 4px; overflow: hidden; }
.wbp-nav__search input { border: 0; background: transparent; color: #fff; padding: 8px 14px; width: 160px; outline: none; font-family: var(--font-bn); }
.wbp-nav__search input::placeholder { color: rgba(255,255,255,.75); }
.wbp-nav__search button { border: 0; background: transparent; color: #fff; padding: 8px 12px 8px 4px; cursor: pointer; }

/* ---------- Breaking ticker ---------- */
.wbp-ticker { background: #fff; border-bottom: 1px solid var(--wbp-line); }
.wbp-ticker__inner { display: flex; align-items: center; min-height: 44px; }
.wbp-ticker__label { background: var(--wbp-red); color: #fff; font-weight: 700; padding: 7px 16px; position: relative; flex: 0 0 auto; }
.wbp-ticker__label::after { content: ""; position: absolute; right: -10px; top: 0; border-left: 10px solid var(--wbp-red); border-top: 16px solid transparent; border-bottom: 16px solid transparent; }
.wbp-ticker__viewport { overflow: hidden; flex: 1; margin-left: 18px; }
.wbp-ticker__track { display: flex; gap: 40px; list-style: none; margin: 0; padding: 0; white-space: nowrap; will-change: transform; }
.wbp-ticker__track li a { color: var(--wbp-ink); font-weight: 500; }
.wbp-ticker__track li a:hover { color: var(--wbp-red); }
.wbp-ticker__track li::before { content: "●"; color: var(--wbp-red); font-size: 7px; vertical-align: middle; margin-right: 12px; }

/* ---------- Main ---------- */
.wbp-main { padding: 22px 0 36px; }
.wbp-section { padding: 14px 0; }
.wbp-section--band { background: var(--wbp-band); }

/* ---------- Hero ---------- */
.wbp-hero2__grid { display: grid; grid-template-columns: 1fr 1.85fr 1fr; gap: 26px; align-items: stretch; }
.wbp-hero2__lead { display: flex; flex-direction: column; }
.wbp-hero2__lead .wbp-hero2__media { display: block; border-radius: var(--wbp-radius); overflow: hidden; aspect-ratio: 16/9; }
.wbp-hero2__media img, .wbp-hero2__media .wbp-ph { width: 100%; height: 100%; object-fit: cover; }
.wbp-hero2__body { padding-top: 12px; }
.wbp-hero2__title { font-size: 28px; line-height: 1.28; margin: 8px 0; }
.wbp-hero2__title a { color: var(--wbp-ink); }
.wbp-hero2__title a:hover { color: var(--wbp-red); }
.wbp-hero2__dek { color: var(--wbp-body); margin: 0 0 10px; }
/* Side columns stretch to the lead's height and spread their rows to fill it. */
.wbp-hero2__side { display: flex; flex-direction: column; justify-content: space-between; gap: 14px; }
.wbp-hero2__side .wbp-row { flex: 1 1 0; align-items: center; }
.wbp-hero2__side .wbp-row__media { flex: 0 0 96px; align-self: center; }

/* Hero right column: latest e-paper edition (uses the standard section heading) */
.wbp-hero2__side--epaper { justify-content: flex-start; }
.wbp-hero-epaper { width: 100%; }
.wbp-hero-epaper .wbp-block__head { margin-bottom: 12px; }
.wbp-hero-epaper__cover { position: relative; display: block; line-height: 0; background: var(--wbp-band); overflow: hidden; border: 1px solid var(--wbp-line); border-radius: var(--wbp-radius); box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.wbp-hero-epaper__cover img { width: 100%; height: auto; display: block; transition: transform .35s; }
.wbp-hero-epaper__cover:hover img { transform: scale(1.03); }
.wbp-hero-epaper__date { position: absolute; left: 0; right: 0; bottom: 0; background: rgba(22,24,29,.78); color: #fff; font-size: 12.5px; line-height: 1.4; text-align: center; padding: 5px 8px; }
.wbp-hero-epaper__ph { display: flex; align-items: center; justify-content: center; padding: 70px 0; color: var(--wbp-muted); }
.wbp-hero-epaper__ph .dashicons { font-size: 48px; width: 48px; height: 48px; }

/* Text headline list */
.wbp-tl { list-style: none; margin: 0; padding: 0; }
.wbp-tl__item { padding: 10px 0; border-bottom: 1px solid var(--wbp-line-soft); line-height: 1.45; }
.wbp-tl__item:last-child { border-bottom: 0; }
.wbp-tl__item a { color: var(--wbp-ink); font-weight: 600; font-size: 16px; }
.wbp-tl__item a:hover { color: var(--wbp-red); }
.wbp-tl__item::before { content: ""; display: inline-block; width: 6px; height: 6px; background: var(--wbp-red); margin: 0 9px 2px 0; vertical-align: middle; }

/* Headline row (thumb + title) */
.wbp-row { display: flex; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--wbp-line-soft); }
.wbp-row:last-child { border-bottom: 0; padding-bottom: 0; }
.wbp-row__media { flex: 0 0 92px; border-radius: 5px; overflow: hidden; aspect-ratio: 4/3; }
.wbp-row__media img, .wbp-row__media .wbp-ph { width: 100%; height: 100%; object-fit: cover; }
.wbp-row__title { font-size: 16px; line-height: 1.4; margin: 0; align-self: center; }
.wbp-row__title a { color: var(--wbp-ink); }
.wbp-row__title a:hover { color: var(--wbp-red); }

/* ---------- Category block ---------- */
.wbp-block__head { display: flex; align-items: center; justify-content: space-between; border-bottom: 2px solid var(--wbp-red); margin-bottom: 16px; }
.wbp-block__title { position: relative; font-size: 23px; color: var(--wbp-navy); margin: 0; padding: 6px 0 8px 16px; }
.wbp-block__title::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 6px; height: 66%; background: var(--wbp-red); border-radius: 1px; }
.wbp-block__more { color: var(--wbp-red); font-weight: 700; font-size: 14.5px; white-space: nowrap; }
.wbp-block__more:hover { color: var(--wbp-red-dark); }

/* Overlay card (image bg + title) */
.wbp-ov { position: relative; border-radius: var(--wbp-radius); overflow: hidden; display: block; }
.wbp-ov__media { display: block; position: relative; aspect-ratio: 16/10; }
.wbp-ov--tall .wbp-ov__media { aspect-ratio: 16/9; }
.wbp-ov__media img, .wbp-ov__media .wbp-ph { width: 100%; height: 100%; object-fit: cover; }
.wbp-ov__scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.25) 55%, transparent 100%); }
.wbp-ov__body { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; }
.wbp-ov__body .wbp-chip { background: var(--wbp-red); color: #fff; }
.wbp-ov__title { display: block; font-family: var(--font-head); font-weight: 700; color: #000; line-height: 1.3; margin-top: 8px; font-size: 18px; }
.wbp-ov--tall .wbp-ov__title { font-size: 26px; }

/* Layout 1 — Spotlight */
.wbp-spot { display: grid; grid-template-columns: 1.5fr 1.15fr 1fr; gap: 26px; align-items: start; }
.wbp-spot__mid, .wbp-spot__list { padding-left: 26px; border-left: 1px solid var(--wbp-line); }
.wbp-spot__mid { display: flex; flex-direction: column; gap: 14px; }
.wbp-spot__media { display: block; border-radius: var(--wbp-radius); overflow: hidden; aspect-ratio: 16/10; margin-bottom: 12px; }
.wbp-spot__media img, .wbp-spot__media .wbp-ph { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.wbp-spot__lead:hover .wbp-spot__media img { transform: scale(1.03); }
.wbp-spot__title { font-size: 23px; line-height: 1.3; margin: 0 0 8px; }
.wbp-spot__title a { color: var(--wbp-ink); }
.wbp-spot__title a:hover { color: var(--wbp-red); }
.wbp-spot__dek { color: var(--wbp-body); margin: 0 0 10px; font-size: 15.5px; }

/* Layout 2 — Mosaic */
.wbp-mosaic { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }

/* Layout 3 — Triptych */
.wbp-trip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.wbp-trip__col { position: relative; }
.wbp-trip__col + .wbp-trip__col { padding-left: 30px; border-left: 1px solid var(--wbp-line); }
.wbp-trip__col .wbp-card { margin-bottom: 12px; }
.wbp-trip__col .wbp-card__title { font-size: 19px; }

/* Layout 4 — Magazine */
.wbp-mag { display: grid; grid-template-columns: 1.7fr 1fr; gap: 28px; align-items: start; }
.wbp-mag__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 18px; }
.wbp-mag__aside { display: flex; flex-direction: column; gap: 14px; padding-left: 28px; border-left: 1px solid var(--wbp-line); }
.wbp-mag__aside .wbp-row__media { flex: 0 0 110px; }

/* ---------- Card ---------- */
.wbp-card {
    background: #fff;
    display: flex;
    flex-direction: column;
    border-radius: var(--wbp-radius);
    overflow: hidden;
}
.wbp-card__media { display: block; aspect-ratio: 16/10; overflow: hidden; }
.wbp-card__media img, .wbp-card__media .wbp-ph { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.wbp-card:hover .wbp-card__media img { transform: scale(1.04); }
.wbp-card__body { padding: 15px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.wbp-card__title { font-size: 18px; line-height: 1.34; margin: 0; }
.wbp-card__title a { color: var(--wbp-ink); }
.wbp-card__title a:hover { color: var(--wbp-red); }
.wbp-card__dek { color: var(--wbp-muted); font-size: 14.5px; margin: 0; }

/* ---------- Chips + meta ---------- */
.wbp-chip { align-self: flex-start; display: inline-block; background: rgba(204,22,64,.08); color: var(--wbp-red); font-size: 12.5px; font-weight: 700; padding: 3px 10px; border-radius: 3px; }
.wbp-chip:hover { background: var(--wbp-red); color: #fff; }
.wbp-meta { display: flex; flex-wrap: wrap; gap: 14px; color: var(--wbp-muted); font-size: 12.5px; margin-top: auto; }
.wbp-meta__item { display: inline-flex; align-items: center; gap: 4px; }
.wbp-meta__item + .wbp-meta__item::before { content: ""; width: 3px; height: 3px; background: currentColor; border-radius: 50%; margin-right: 12px; opacity: .6; }
.wbp-meta__author { font-weight: 700; color: var(--wbp-body); }

/* ---------- Placeholder (fallback only) ---------- */
.wbp-ph { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; background: linear-gradient(135deg, hsl(var(--ph-h,210) 45% 40%), hsl(calc(var(--ph-h,210) + 35) 50% 28%)); }
.wbp-ph__mark { font-family: var(--font-head); font-size: clamp(24px,5vw,52px); color: rgba(255,255,255,.9); font-weight: 700; }

/* ---------- Archive / single layout ---------- */
.wbp-layout { display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 40px; padding-top: 24px; padding-bottom: 24px; }
.wbp-content { min-width: 0; }
.wbp-archive__head { border-bottom: 2px solid var(--wbp-red); margin-bottom: 22px; padding-bottom: 8px; }
.wbp-archive__title { font-size: 27px; color: var(--wbp-navy); margin: 0; }
.wbp-archive__title small { display: block; font-size: 14px; font-weight: 400; color: var(--wbp-muted); font-family: var(--font-bn); margin-top: 4px; }
.wbp-empty { padding: 40px; text-align: center; color: var(--wbp-muted); background: var(--wbp-band); border-radius: var(--wbp-radius); }
.wbp-grid { display: grid; gap: 24px; }
.wbp-grid--2 { grid-template-columns: repeat(2,1fr); }
.wbp-grid--3 { grid-template-columns: repeat(3,1fr); }
.wbp-grid--4 { grid-template-columns: repeat(4,1fr); }

/* ---------- Single post ---------- */
.wbp-single { padding: 26px 0 40px; }
.wbp-single__head { margin-bottom: 16px; }
.wbp-single__title { font-size: 36px; line-height: 1.26; margin: 12px 0; color: var(--wbp-ink); }
.wbp-single__dek { font-size: 19px; color: var(--wbp-body); margin: 0 0 14px; }
.wbp-single__byline { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; padding: 12px 0; border-top: 1px solid var(--wbp-line); border-bottom: 1px solid var(--wbp-line); }
.wbp-single__byline img { border-radius: 50%; }
.wbp-single__feature { margin: 22px 0; border-radius: var(--wbp-radius); overflow: hidden; }
.wbp-single__feature figcaption { font-size: 13.5px; color: var(--wbp-muted); padding: 8px 4px; }
.wbp-article { font-size: 18px; line-height: 1.95; color: var(--wbp-body); }
.wbp-article p { margin: 0 0 1.2em; }
.wbp-article h2, .wbp-article h3 { margin: 1.4em 0 .5em; }
.wbp-article a { text-decoration: underline; }
.wbp-article img { border-radius: 6px; margin: 1em 0; }
.wbp-article blockquote { border-right: 4px solid var(--wbp-red); background: var(--wbp-band); margin: 1.2em 0; padding: 14px 18px; }
.wbp-share { display: flex; gap: 8px; align-items: center; margin: 24px 0; flex-wrap: wrap; }
.wbp-share span { font-weight: 700; color: var(--wbp-ink); }
.wbp-share a { display: inline-flex; width: 38px; height: 38px; align-items: center; justify-content: center; border-radius: 50%; background: var(--wbp-band); color: var(--wbp-ink); }
.wbp-share a:hover { background: var(--wbp-red); color: #fff; }
.wbp-tags { margin: 20px 0; }
.wbp-tags a { display: inline-block; font-size: 13.5px; background: var(--wbp-band); padding: 4px 12px; border-radius: 4px; margin: 0 6px 6px 0; color: var(--wbp-body); }
.wbp-tags a:hover { background: var(--wbp-red); color: #fff; }
.wbp-related { margin-top: 36px; }
.wbp-related__title { font-size: 22px; color: var(--wbp-navy); border-bottom: 2px solid var(--wbp-red); padding-bottom: 6px; margin-bottom: 18px; }

/* ---------- Sidebar / widgets ---------- */
.wbp-sidebar .widget, .wbp-sidebar > section { margin-bottom: 28px; }
.widget__title { font-size: 18px; color: var(--wbp-navy); border-right: 4px solid var(--wbp-red); padding-right: 10px; margin-bottom: 14px; }
.wbp-sidebar ul { list-style: none; margin: 0; padding: 0; }
.wbp-sidebar li { padding: 8px 0; border-bottom: 1px solid var(--wbp-line-soft); }
.wbp-li { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--wbp-line-soft); }
.wbp-li:last-child { border-bottom: 0; }
.wbp-li--ranked { align-items: flex-start; }
.wbp-li__rank { font-family: var(--font-head); font-size: 26px; font-weight: 700; color: var(--wbp-red); opacity: .4; flex: 0 0 auto; line-height: 1; min-width: 24px; }
.wbp-li__media { flex: 0 0 92px; border-radius: 5px; overflow: hidden; aspect-ratio: 4/3; }
.wbp-li__media img, .wbp-li__media .wbp-ph { width: 100%; height: 100%; object-fit: cover; }
.wbp-li__title { font-size: 16px; line-height: 1.4; margin: 0; }
.wbp-li__title a { color: var(--wbp-ink); }
.wbp-li__title a:hover { color: var(--wbp-red); }
.wbp-li .wbp-card__meta { margin-top: 4px; }

/* ---------- Pagination ---------- */
.navigation.pagination { margin: 30px 0; }
.navigation.pagination .nav-links { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; }
.navigation.pagination .page-numbers { display: inline-flex; min-width: 40px; height: 40px; align-items: center; justify-content: center; padding: 0 12px; border: 1px solid var(--wbp-line); border-radius: 5px; color: var(--wbp-ink); font-weight: 700; }
.navigation.pagination .page-numbers.current { background: var(--wbp-red); color: #fff; border-color: var(--wbp-red); }
.navigation.pagination a.page-numbers:hover { background: var(--wbp-band); }

/* ---------- Comments ---------- */
.wbp-comments { margin-top: 40px; padding-top: 24px; border-top: 2px solid var(--wbp-line); }
.wbp-comments__title { font-size: 22px; color: var(--wbp-navy); margin-bottom: 20px; }
.comment-list { list-style: none; margin: 0 0 30px; padding: 0; }
.comment-list ol.children { list-style: none; margin: 0; padding: 0 0 0 40px; }
.comment-body { padding: 16px 0; border-bottom: 1px solid var(--wbp-line-soft); }
.comment-author { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.comment-author img { border-radius: 50%; }
.comment-author .fn { font-weight: 700; color: var(--wbp-ink); font-style: normal; }
.comment-author .says { display: none; }
.comment-meta { font-size: 12.5px; color: var(--wbp-muted); }
.comment-meta a { color: var(--wbp-muted); }
.comment-content { margin: 8px 0; }
.comment .reply { font-size: 13.5px; }
.comment .reply a { font-weight: 700; }
.comment-respond { background: var(--wbp-band); border-radius: var(--wbp-radius); padding: 22px 24px; }
.comment-reply-title { font-size: 20px; color: var(--wbp-navy); margin-bottom: 6px; }
.comment-notes, .logged-in-as { font-size: 13.5px; color: var(--wbp-muted); margin-bottom: 14px; }
.comment-form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.comment-form p { margin: 0; }
.comment-form-comment, .comment-form-cookies-consent, .form-submit { grid-column: 1 / -1; }
.comment-form label { display: block; font-weight: 600; font-size: 13.5px; margin-bottom: 5px; color: var(--wbp-ink); }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea {
	width: 100%; padding: 10px 12px; border: 1px solid var(--wbp-line); border-radius: 5px; font-family: var(--font-bn); font-size: 15px; background: #fff; outline: none;
}
.comment-form input:focus, .comment-form textarea:focus { border-color: var(--wbp-red); box-shadow: 0 0 0 2px rgba(204,22,64,.12); }
.comment-form textarea { min-height: 130px; resize: vertical; }
.comment-form-cookies-consent { display: flex; align-items: center; gap: 8px; font-size: 13.5px; }
.comment-form-cookies-consent label { margin: 0; font-weight: 400; }
.form-submit .submit, .wbp-btn {
	background: var(--wbp-red); color: #fff; border: 0; border-radius: 5px; padding: 11px 26px; font-family: var(--font-bn); font-weight: 700; font-size: 16px; cursor: pointer;
}
.form-submit .submit:hover, .wbp-btn:hover { background: var(--wbp-red-dark); }

/* ---------- Search form ---------- */
.wbp-searchform { display: flex; border: 1px solid var(--wbp-line); border-radius: 24px; overflow: hidden; max-width: 340px; margin: 0 auto; }
.wbp-searchform input { border: 0; padding: 10px 16px; flex: 1; outline: none; font-family: var(--font-bn); }
.wbp-searchform button { border: 0; background: var(--wbp-red); color: #fff; padding: 0 18px; cursor: pointer; }

/* ---------- 404 ---------- */
.wbp-404 { text-align: center; padding: 70px 20px; }
.wbp-404__code { font-family: var(--font-head); font-size: 92px; color: var(--wbp-red); line-height: 1; }

/* ---------- Footer ---------- */
.wbp-footer { background: var(--wbp-navy); color: #b9c0d6; margin-top: 30px; }
.wbp-footer__top { display: grid; grid-template-columns: 1.1fr 2fr; gap: 44px; padding: 46px 24px; }
.wbp-footer__name { font-family: var(--font-head); font-size: 26px; color: #fff; font-weight: 700; }
.wbp-footer__logo { max-height: 70px; width: auto; margin-bottom: 14px; background: #fff; padding: 8px 12px; border-radius: 6px; }
.wbp-footer__about { margin: 14px 0; font-size: 15px; line-height: 1.8; }
.wbp-footer__contact { font-size: 14.5px; color: #9aa2bd; }
.wbp-footer__social { display: flex; gap: 8px; margin-top: 14px; }
.wbp-footer__social a { width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.09); color: #fff; display: inline-flex; align-items: center; justify-content: center; }
.wbp-footer__social a:hover { background: var(--wbp-red); }
.wbp-footer__cols { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.wbp-footer__col .widget__title, .wbp-footer__col h3 { color: #fff; border-right-color: var(--wbp-red); font-size: 16px; }
.wbp-footer__col ul { list-style: none; margin: 0; padding: 0; }
.wbp-footer__col li { padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
.wbp-footer__col a { color: #b9c0d6; font-size: 14.5px; }
.wbp-footer__col a:hover { color: #fff; padding-right: 4px; }
.wbp-footer__bar { background: var(--wbp-navy-dark); }
.wbp-footer__bar-inner { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; gap: 16px; flex-wrap: wrap; font-size: 13.5px; }
.wbp-footer__bar p { margin: 0; }
.wbp-footer__menu { display: flex; gap: 18px; list-style: none; margin: 0; padding: 0; }
.wbp-footer__menu a { color: #b9c0d6; }
.wbp-totop { position: fixed; right: 22px; bottom: 22px; width: 46px; height: 46px; border-radius: 50%; border: 0; background: var(--wbp-red); color: #fff; font-size: 20px; cursor: pointer; box-shadow: var(--wbp-shadow); opacity: 0; visibility: hidden; transform: translateY(10px); transition: .2s; z-index: 300; }
.wbp-totop.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }

/* ---------- Advertisements ---------- */
.wbp-ad { margin: 22px 0; text-align: center; }
.wbp-ad__label { display: block; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--wbp-muted); margin-bottom: 6px; }
.wbp-ad__inner { display: inline-block; max-width: 100%; }
.wbp-ad__inner img { display: block; margin: 0 auto; max-width: 100%; height: auto; }
.wbp-ad--header { margin: 0; text-align: right; }
.wbp-ad--header .wbp-ad__label { display: none; }
.wbp-ad--after_hero, .wbp-ad--between_sections, .wbp-ad--footer { background: var(--wbp-band); padding: 16px; border-radius: var(--wbp-radius); }
.wbp-ad--sidebar { margin-top: 0; }
.masthead .wbp-ad { margin: 0; }

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
	.wbp-hero2__grid { grid-template-columns: 1fr 1.4fr; }
	.wbp-hero2__side--cards { display: none; }
	.wbp-spot { grid-template-columns: 1.4fr 1fr; }
	.wbp-spot__list { display: none; }
	.wbp-mosaic { grid-template-columns: repeat(3, 1fr); }
	.wbp-mosaic .wbp-card:nth-child(n+7) { display: none; }
	.wbp-mag__cards { grid-template-columns: repeat(2, 1fr); }
	.wbp-layout { grid-template-columns: 1fr; }
	.wbp-sidebar { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
}
@media (max-width: 820px) {
	.wbp-masthead__inner { flex-direction: column; text-align: center; }
	.wbp-masthead__ad { margin: 0; }
	.wbp-nav__toggle { display: inline-flex; }
	.wbp-menu { display: none; flex-direction: column; width: 100%; order: 3; }
	.wbp-menu.is-open { display: flex; }
	.wbp-menu > li > a { padding: 12px 6px; border-bottom: 1px solid rgba(255,255,255,.12); }
	.wbp-menu ul.sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: rgba(255,255,255,.08); border: 0; }
	.wbp-menu ul.sub-menu a { color: #fff; }
	.wbp-nav__inner { flex-wrap: wrap; }
	.wbp-nav__search { display: none; }
	.wbp-hero2__grid { grid-template-columns: 1fr; }
	.wbp-hero2__side { display: none; }
	/* Stack all distinct layouts into a single column on mobile */
	.wbp-spot, .wbp-mag { grid-template-columns: 1fr; }
	.wbp-trip { grid-template-columns: 1fr; }
	.wbp-trip__col + .wbp-trip__col { padding-left: 0; border-left: 0; padding-top: 16px; border-top: 1px solid var(--wbp-line); }
	.wbp-spot__mid, .wbp-spot__list { padding-left: 0; border-left: 0; }
	.wbp-mag__aside { padding-left: 0; border-left: 0; }
	.wbp-mosaic { grid-template-columns: repeat(2, 1fr); }
	.wbp-mosaic .wbp-card:nth-child(n+7) { display: block; }
	.wbp-mag__cards { grid-template-columns: repeat(3, 1fr); }
	.wbp-grid--3, .wbp-grid--4 { grid-template-columns: repeat(2,1fr); }
	.wbp-footer__top { grid-template-columns: 1fr; gap: 28px; }
	.wbp-single__title { font-size: 28px; }
	.comment-form { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
	.wbp-section__title, .wbp-block__title { font-size: 20px; }
	.wbp-grid--2, .wbp-grid--3, .wbp-grid--4 { grid-template-columns: 1fr; }
	.wbp-sidebar { grid-template-columns: 1fr; }
	.wbp-single__title { font-size: 24px; }
	.wbp-article { font-size: 16.5px; }
}
