/* ============================================================
   Droam Wire theme — CNN-inspired redesign
   Brand gradient retained; all other tokens reset.
   ============================================================ */

:root {
  --brand-grad: linear-gradient(135deg, rgb(41, 66, 86) 2%, rgb(9, 113, 161) 49%, rgb(99, 108, 81) 100%);
  --brand: #0971a1;
  --brand-dark: #294256;
  --brand-warm: #636c51;
  --cnn-blue: #005095;

  --text: #0c0c0c;
  --text-soft: #2a2a2a;
  --muted: #5c5c5c;
  --muted-foreground: #5c5c5c;
  --muted-soft: #707070;
  --line: #d9d9d9;
  --soft-line: #ececec;
  --page: #ffffff;
  --footer: #0f0f0f;

  --max: 1280px;
  --radius-sm: 2px;

  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  --font-serif: "Source Serif 4", Georgia, "Times New Roman", serif;
}

/* Strip dark-mode behavior — pure light design */
html.dark { color-scheme: light; }

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--page);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; transition: color 0.15s ease; }
a:hover { color: var(--brand); }

img, svg { display: block; max-width: 100%; }

button { font: inherit; cursor: pointer; }

h1, h2, h3, h4, h5, h6 { margin: 0; font-weight: 800; letter-spacing: -0.01em; line-height: 1.15; }

.dw-sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

.dw-wrap { min-height: 100vh; display: flex; flex-direction: column; }
.dw-main { flex: 1; }

/* ─── Helpers ───────────────────────────────────────────────── */
.dw-muted { color: var(--muted); }
.dw-headline-serif { font-family: var(--font-serif); font-weight: 700; }
.dw-kicker {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  border: 1px solid var(--text);
  background: var(--text);
  color: #fff;
  font-weight: 700;
  font-size: 14px;
}
.dw-btn:hover { background: var(--brand); border-color: var(--brand); color: #fff; }

/* ─── Header ────────────────────────────────────────────────── */
.dw-site-header { position: relative; z-index: 60; }
.dw-sticky-header {
  position: sticky; top: 0; z-index: 60;
  background: #fff;
  box-shadow: 0 1px 0 var(--soft-line);
}
@keyframes dwPulse { 0% { transform: scale(1); opacity: 0.55; } 70% { transform: scale(2.6); opacity: 0; } 100% { transform: scale(2.6); opacity: 0; } }

/* Utility strip */
.dw-util {
  background: #0c0c0c;
  color: rgba(255,255,255,0.85);
}
.dw-util-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 24px;
  height: 34px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px;
  font-size: 12px;
}
.dw-util-left,
.dw-util-right {
  display: flex; align-items: center; gap: 18px;
}
.dw-util-left a {
  color: rgba(255,255,255,0.72);
  font-weight: 600;
  letter-spacing: 0.04em;
  transition: color 0.15s ease;
}
.dw-util-left a:hover { color: #fff; }
.dw-util-live {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #fff;
}
.dw-util-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #e74c3c;
  position: relative;
}
.dw-util-live-dot::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: #e74c3c;
  animation: dwPulse 1.6s ease-out infinite;
  will-change: transform, opacity;
  pointer-events: none;
}
.dw-util-date {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13px;
  color: rgba(255,255,255,0.78);
}
.dw-util-btn {
  border: 0;
  background: transparent;
  padding: 0;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #fff;
  cursor: pointer;
  position: relative;
}
.dw-util-btn::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 2px;
  background: var(--brand-grad);
  transform: scaleX(0.6);
  transition: transform 0.2s ease;
}
.dw-util-btn:hover::after { transform: scaleX(1); }

/* Masthead (full-bleed gradient, centered logo) */
.dw-masthead { background: var(--brand-grad); }
.dw-masthead-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 22px 24px 18px;
  display: flex; align-items: center; justify-content: center;
}
.dw-brand { display: inline-flex; align-items: center; }
.dw-brand-logo { height: 52px; width: auto; display: block; }

/* Gradient accent stripe between masthead and nav */
.dw-accent-stripe {
  height: 3px;
  background: var(--brand-grad);
}

/* Legacy subscribe-btn (still emitted by some surfaces) → util-btn style */
.dw-subscribe-btn {
  border: 1px solid var(--text);
  background: var(--text);
  color: #fff;
  padding: 8px 14px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.dw-subscribe-btn:hover { background: var(--brand); border-color: var(--brand); }

/* Subscribe dropdown */
.dw-subscribe-form {
  background: #f6f7f8;
  border-bottom: 1px solid var(--line);
}
.dw-subscribe-form[hidden] { display: none; }
.dw-subscribe-form-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 16px 24px;
}
.dw-subscribe-form-label {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--text-soft);
}
.dw-subscribe-row { display: flex; gap: 8px; max-width: 480px; }
.dw-subscribe-input {
  flex: 1;
  padding: 10px 12px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 14px;
}
.dw-subscribe-input:focus { outline: 2px solid var(--brand); outline-offset: -2px; border-color: var(--brand); }
.dw-subscribe-submit {
  padding: 10px 18px;
  border: 0;
  background: var(--brand-grad);
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 13px;
}
.dw-subscribe-msg { margin: 8px 0 0; font-size: 13px; color: var(--brand-dark); }

/* Subscribe block — placed on homepage above footer and at the end of single posts/events */
.dw-subscribe-block {
  max-width: 760px;
  margin: 24px auto;
  padding: 14px 16px 16px;
  background: linear-gradient(180deg, rgba(9,113,161,0.06), #fff);
  border: 1px solid var(--line);
  border-top: 3px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
}
.dw-subscribe-block--wide {
  max-width: var(--max);
  margin: 22px auto 58px;
  padding: 22px 24px 24px;
}
.dw-events-split > .dw-events-split-right { display: flex; flex-direction: column; gap: 20px; min-width: 0; align-self: start; }
.dw-events-split-right > .dw-subscribe-block { margin: 0; max-width: none; }
.dw-events-split-right > .dw-droam-promo { margin: 0; }
.dw-subscribe-block--inline { max-width: 720px; margin: 20px auto; padding: 12px 14px 14px; }

.dw-subscribe-block-text { margin: 0 0 10px; }
.dw-subscribe-block-text h3 {
  margin: 0 0 6px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-dark);
  font-family: inherit;
}
.dw-subscribe-block-text p {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
}

.dw-subscribe-block-form { display: grid; gap: 10px; }
.dw-subscribe-block .dw-subscribe-input-wrap { display: block; }
.dw-subscribe-block .dw-subscribe-input {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line);
  background: #fff;
  color: #111;
  font-size: 15px;
  border-radius: 0;
}
.dw-subscribe-block .dw-subscribe-input:focus {
  outline: 0;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(9,113,161,0.18);
}
.dw-subscribe-block .dw-subscribe-submit {
  padding: 12px 18px;
  background: var(--brand-grad);
  border: 0;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 0;
}
.dw-subscribe-block .dw-subscribe-submit:hover { filter: brightness(1.08); }
.dw-subscribe-block .dw-subscribe-msg {
  margin: 0;
  font-size: 13px;
  color: var(--brand-dark);
}
.dw-subscribe-block .dw-subscribe-msg:empty { display: none; }

/* Primary nav */
.dw-site-nav {
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.dw-site-nav-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 24px;
  display: flex; align-items: center; justify-content: center;
  gap: 28px;
  overflow-x: auto;
  white-space: nowrap;
  height: 48px;
  scrollbar-width: none;
}
.dw-site-nav-inner::-webkit-scrollbar { display: none; }
.dw-site-nav-link {
  position: relative;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-soft);
  padding: 14px 0;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color 0.15s ease;
}
.dw-site-nav-link:hover { color: var(--brand); }
.dw-site-nav-link.is-active {
  color: var(--brand);
  font-weight: 800;
}
.dw-site-nav-link.is-active::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 3px;
  background: var(--brand-grad);
}
.dw-site-nav-link--contact { margin-left: 0; }

/* Ticker — clean white strip with brand-gradient badge */
.dw-ticker {
  display: flex; align-items: stretch;
  background: #fafbfc;
  color: var(--text);
  border-bottom: 1px solid var(--soft-line);
  overflow: hidden;
}
.dw-ticker-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 18px;
  background: var(--brand-grad);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.dw-ticker-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #fff;
  position: relative;
}
.dw-ticker-dot::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: #fff;
  animation: dwPulse 1.6s ease-out infinite;
  will-change: transform, opacity;
  pointer-events: none;
}
.dw-ticker-live { color: #fff; }
.dw-ticker-text {
  flex: 1;
  display: flex; align-items: center;
  padding: 8px 0;
  overflow: hidden;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-soft);
  white-space: nowrap;
  mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}
.dw-ticker-text > span {
  display: inline-block;
  padding-left: 100%;
  animation: dwTicker 150s linear infinite;
}
.dw-ticker-text a { color: var(--brand-dark); font-weight: 600; }
.dw-ticker-text a:hover { color: var(--brand); }
@keyframes dwTicker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ─── Page container ───────────────────────────────────────── */
.dw-home-layout {
  max-width: var(--max);
  margin: 0 auto;
  padding: 22px 24px 58px;
  display: flex;
  flex-direction: column;
}
.dw-home-layout > .dw-feed { order: 1; }
.dw-home-layout > .dw-home-sidebar { order: 2; }
.dw-home-layout > section { order: 3; }
.dw-feed { width: 100%; }

/* ─── Front shell head ──────────────────────────────────────── */
.dw-front-shell { padding-top: 4px; }
.dw-front-shell-head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 24px;
  padding: 6px 0 22px;
  border-bottom: 2px solid var(--text);
  margin-bottom: 26px;
}
.dw-front-shell-title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(22px, 2.3vw, 30px);
  font-weight: 700;
  line-height: 1.18;
  max-width: 60ch;
  letter-spacing: -0.01em;
}
.dw-front-shell-meta {
  margin: 0;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  white-space: nowrap;
}

/* ─── Zone A: CNN top grid ─────────────────────────────────── */
.dw-cnn-top-grid {
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) minmax(380px, 1.42fr) minmax(240px, 0.8fr);
  gap: 26px;
  align-items: start;
}

/* Left column — 3 mini cards stacked */
.dw-cnn-left { display: grid; gap: 0; align-content: start; }
.dw-cnn-mini {
  display: grid; gap: 10px;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--line);
}
.dw-cnn-mini:last-child { border-bottom: 0; margin-bottom: 0; }
.dw-cnn-mini-img {
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--soft-line);
}
.dw-cnn-mini-img--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-cnn-mini-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.dw-cnn-mini:hover .dw-cnn-mini-img img { transform: scale(1.04); }
.dw-cnn-mini-title {
  font-size: 18px;
  line-height: 1.18;
  font-weight: 800;
  color: var(--text);
}
.dw-cnn-mini:hover .dw-cnn-mini-title { color: var(--brand); }

/* Center column — lead */
.dw-cnn-center { display: grid; gap: 0; }
.dw-cnn-center-main { margin-bottom: 18px; }
.dw-cnn-center-title {
  font-family: var(--font-serif);
  font-size: clamp(34px, 4.3vw, 62px);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
  color: var(--text);
}
.dw-cnn-center-link:hover .dw-cnn-center-title { color: var(--brand); }
.dw-cnn-center-img {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--soft-line);
}
.dw-cnn-center-img img { width: 100%; height: 100%; object-fit: cover; }
.dw-cnn-center-sub {
  display: block;
  padding: 12px 0;
  border-top: 1px solid var(--line);
  position: relative;
}
.dw-cnn-center-sub:last-child { border-bottom: 1px solid var(--line); }
.dw-cnn-center-sub::before {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand);
  margin-right: 10px;
  vertical-align: 3px;
}
.dw-cnn-center-sub-title {
  display: inline;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
}
.dw-cnn-center-sub:hover .dw-cnn-center-sub-title { color: var(--brand); }

/* Right column — featured overlay */
.dw-cnn-right { display: flex; flex-direction: column; gap: 16px; height: 100%; }
.dw-cnn-right-feat { position: relative; overflow: hidden; flex: 1 1 0; min-height: 0; }
.dw-cnn-right-link { display: block; height: 100%; }
.dw-cnn-right-img { position: absolute; inset: 0; }
.dw-cnn-right-img img { width: 100%; height: 100%; object-fit: cover; }
.dw-cnn-right-img--empty { background: var(--brand-grad); }
.dw-cnn-right-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,0.85) 100%);
}
.dw-cnn-right-text {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 18px;
  color: #fff;
}
.dw-cnn-right-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.18;
  color: #fff;
  margin-top: 8px;
}

/* ─── Zone B: Ribbon ──────────────────────────────────────── */
.dw-front-ribbon-shell {
  margin-top: 36px;
  padding-top: 22px;
  border-top: 2px solid var(--text);
}
.dw-front-ribbon-shell::before {
  content: "More top stories";
  display: block;
  margin-bottom: 16px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.dw-ribbon {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 22px;
}
.dw-ribbon-card {}
.dw-ribbon-link { display: grid; gap: 10px; padding-bottom: 14px; border-bottom: 1px solid var(--line); height: 100%; }
.dw-ribbon-img { aspect-ratio: 16/10; overflow: hidden; background: var(--soft-line); }
.dw-ribbon-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.dw-ribbon-link:hover .dw-ribbon-img img { transform: scale(1.04); }
.dw-ribbon-img--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-ribbon-body { display: grid; gap: 6px; }
.dw-ribbon-title { font-size: 16px; font-weight: 800; line-height: 1.2; color: var(--text); }
.dw-ribbon-link:hover .dw-ribbon-title { color: var(--brand); }

/* ─── Zone C: Pulse / overlay pair ─────────────────────────── */
.dw-front-pulse-grid {
  margin-top: 36px;
  padding-top: 22px;
  border-top: 2px solid var(--text);
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px;
}
.dw-front-pulse-grid::before {
  grid-column: 1 / -1;
  content: "Featured";
  margin-bottom: 4px;
  font-size: 22px; font-weight: 800; letter-spacing: -0.01em;
}

/* Overlay card (shared, used in pulse + triple + double) */
.dw-cat-row-overlay-card { position: relative; overflow: hidden; aspect-ratio: 16/10; }
.dw-cat-row-overlay-link { display: block; height: 100%; }
.dw-cat-row-overlay-img { position: absolute; inset: 0; }
.dw-cat-row-overlay-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.dw-cat-row-overlay-card:hover .dw-cat-row-overlay-img img { transform: scale(1.04); }
.dw-cat-row-overlay-img--empty { background: var(--brand-grad); }
.dw-cat-row-overlay-grad {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.78) 100%);
}
.dw-cat-row-overlay-text {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 18px;
  color: #fff;
}
.dw-cat-row-overlay-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.2;
  color: #fff;
}

/* ─── Category rows ───────────────────────────────────────── */
.dw-cat-row {
  margin-top: 40px;
  padding-top: 22px;
  border-top: 2px solid var(--text);
}
.dw-cat-row-header {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 16px;
  margin-bottom: 18px;
}
.dw-cat-row-kicker {
  margin: 0 0 4px;
  font-size: 11px; font-weight: 800; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-cat-row-title {
  margin: 0;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.dw-cat-row-more {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--brand);
}
.dw-cat-row-more:hover { color: var(--brand-dark); }

.dw-cat-row-body {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 22px;
}
.dw-cat-row-body--triple { grid-template-columns: repeat(3, 1fr); }
.dw-cat-row-body--river  { grid-template-columns: repeat(4, 1fr); }
.dw-cat-row-body--double { grid-template-columns: 1fr 1fr; }
.dw-cat-row-body--feature { grid-template-columns: 2fr 3fr; }
.dw-cat-row-body--inverted { grid-template-columns: 2fr 3fr; }

/* Lead card (cnn / feature / inverted bands) */
.dw-cat-row-lead { position: relative; overflow: hidden; aspect-ratio: 16/10; }
.dw-cat-row-lead-link { display: block; height: 100%; }
.dw-cat-row-lead-img { position: absolute; inset: 0; }
.dw-cat-row-lead-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.dw-cat-row-lead:hover .dw-cat-row-lead-img img { transform: scale(1.04); }
.dw-cat-row-lead-img--empty { background: var(--brand-grad); }
.dw-cat-row-lead-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.82) 100%);
}
.dw-cat-row-lead-text {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 20px;
  color: #fff;
}
.dw-cat-row-lead-title {
  font-family: var(--font-serif);
  font-size: 26px;
  line-height: 1.15;
  font-weight: 700;
  color: #fff;
}

/* Stack column (image card + text items) */
.dw-cat-row-stack { display: grid; gap: 0; align-content: start; }
.dw-cat-row-card { padding-bottom: 14px; margin-bottom: 14px; border-bottom: 1px solid var(--line); }
.dw-cat-row-card-img { aspect-ratio: 16/10; overflow: hidden; background: var(--soft-line); margin-bottom: 10px; }
.dw-cat-row-card-img img { width: 100%; height: 100%; object-fit: cover; }
.dw-cat-row-card-img--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-cat-row-card-title { font-size: 18px; font-weight: 800; line-height: 1.18; }
.dw-cat-row-card-link:hover .dw-cat-row-card-title { color: var(--brand); }

.dw-cat-row-text-item {
  display: block;
  padding: 11px 0;
  border-top: 1px solid var(--line);
  position: relative;
}
.dw-cat-row-text-item:last-child { border-bottom: 1px solid var(--line); }
.dw-cat-row-text-item::before {
  content: "";
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--brand);
  margin-right: 10px;
  vertical-align: 3px;
}
.dw-cat-row-text-title {
  display: inline;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.22;
}
.dw-cat-row-text-item:hover .dw-cat-row-text-title { color: var(--brand); }

.dw-cat-row-feature-list { display: grid; align-content: start; }

/* River band — 4 compact horizontal */
.dw-cat-row-river-card { }
.dw-cat-row-river-link { display: grid; gap: 10px; padding-bottom: 14px; border-bottom: 1px solid var(--line); height: 100%; }
.dw-cat-row-river-thumb { aspect-ratio: 16/10; overflow: hidden; background: var(--soft-line); }
.dw-cat-row-river-thumb img { width: 100%; height: 100%; object-fit: cover; }
.dw-cat-row-river-thumb--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-cat-row-river-title { font-size: 16px; font-weight: 800; line-height: 1.2; }
.dw-cat-row-river-link:hover .dw-cat-row-river-title { color: var(--brand); }

/* ─── Category / kicker chips ─────────────────────────────── */
.dw-cat {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 6px;
}
.dw-cat-sm { font-size: 10px; }
.dw-cat-telecom { color: var(--brand); }
.dw-cat-esim    { color: #294256; }
.dw-cat-roaming { color: #636c51; }
.dw-cat-prepaid { color: #0971a1; }
.dw-cat-providers { color: #294256; }
.dw-cat-postpaid  { color: #636c51; }

.dw-meta-date {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 6px;
}
.dw-meta-date--light { color: rgba(255,255,255,0.85); }

.dw-featured-label {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 8px;
}
.dw-featured-label-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--brand);
  position: relative;
}
.dw-featured-label-dot::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--brand);
  animation: dwPulse 1.6s ease-out infinite;
  will-change: transform, opacity;
  pointer-events: none;
}

/* ─── Topic-archive / fallback render section ─────────────── */
.dw-topic-section { margin-top: 26px; }
.dw-topic-section {
  content-visibility: auto;
  contain-intrinsic-size: auto 800px;
}
.dw-cat-row {
  content-visibility: auto;
  contain-intrinsic-size: auto 600px;
}
.dw-section-rule {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--text);
  margin-bottom: 22px;
}
.dw-section-title { font-size: 26px; font-weight: 800; letter-spacing: -0.01em; }
.dw-section-count { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }

.dw-cluster {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 26px;
  margin-bottom: 28px;
}
.dw-cluster-lead {}
.dw-cluster-lead-link { display: block; }
.dw-cluster-lead-img { aspect-ratio: 16/9; overflow: hidden; background: var(--soft-line); margin-bottom: 14px; }
.dw-cluster-lead-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.dw-cluster-lead:hover .dw-cluster-lead-img img { transform: scale(1.03); }
.dw-cluster-lead-img--empty { background: var(--brand-grad); }
.dw-cluster-lead-body {}
.dw-cluster-lead-title {
  font-family: var(--font-serif);
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.015em;
}
.dw-cluster-lead-link:hover .dw-cluster-lead-title { color: var(--brand); }

.dw-cluster-secondary { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-content: start; }
.dw-news-card {}
.dw-news-card-link { display: block; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.dw-news-card-img { aspect-ratio: 16/10; overflow: hidden; background: var(--soft-line); margin-bottom: 10px; }
.dw-news-card-img img { width: 100%; height: 100%; object-fit: cover; }
.dw-news-card-img--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-news-card-title { font-size: 16px; font-weight: 800; line-height: 1.2; }
.dw-news-card-link:hover .dw-news-card-title { color: var(--brand); }

.dw-article-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.dw-list-card-link { display: grid; gap: 10px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.dw-list-card-img { aspect-ratio: 16/10; object-fit: cover; }
.dw-list-card-img--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-list-card-title { font-size: 15px; font-weight: 800; line-height: 1.2; }
.dw-list-card-link:hover .dw-list-card-title { color: var(--brand); }

/* ─── Flat feed (filtered views) ──────────────────────────── */
.dw-flat-feed {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.dw-flat-card { padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.dw-flat-card-link { display: grid; gap: 10px; }
.dw-flat-card-img { aspect-ratio: 16/10; overflow: hidden; background: var(--soft-line); }
.dw-flat-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.dw-flat-card:hover .dw-flat-card-img img { transform: scale(1.03); }
.dw-flat-card-img--empty { background: linear-gradient(135deg, #f0f3f6, #e6ebf0); }
.dw-flat-card-title { font-size: 18px; font-weight: 800; line-height: 1.2; }
.dw-flat-card:hover .dw-flat-card-title { color: var(--brand); }

.dw-flat-card--lead { grid-column: 1 / -1; padding-bottom: 24px; }
.dw-flat-card--lead .dw-flat-card-link { grid-template-columns: 1.4fr 1fr; gap: 24px; }
.dw-flat-card--lead .dw-flat-card-img { aspect-ratio: 16/9; }
.dw-flat-card--lead .dw-flat-card-title {
  font-family: var(--font-serif);
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.015em;
}

/* ─── Homepage calendar sidebar (in-flow, below feed) ────── */
.dw-home-sidebar {
  margin: 48px auto 0;
  max-width: 480px;
  width: 100%;
}
.dw-home-sidebar[hidden] { display: block !important; }
.dw-home-sidebar-inner { width: 100%; }

/* Homepage Upcoming Events section (same look as contact page strip) */
.dw-home-events-section {
  margin: 56px 0 8px;
  width: 100%;
}
.dw-home-layout > .dw-home-events-section { order: 2; }

/* "What is DROAM News?" brand panel */
.dw-brand-panel {
  margin: 56px 0 8px;
  border-top: 2px solid var(--text);
  padding-top: 32px;
}
.dw-brand-panel-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(260px, 0.7fr);
  gap: 48px;
  align-items: start;
}
.dw-brand-panel-main { min-width: 0; }
.dw-brand-panel-eyebrow {
  margin: 0 0 14px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dw-brand-panel-title {
  margin: 0 0 18px;
  font-family: var(--font-serif);
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.02em;
  color: var(--text);
  max-width: 20ch;
}
.dw-brand-panel-text {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.65;
  color: var(--text-soft);
  max-width: 64ch;
}
.dw-brand-panel-actions {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 22px;
}
.dw-brand-panel-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 22px;
  background: var(--brand-grad);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: filter 0.2s ease, transform 0.2s ease;
}
.dw-brand-panel-cta svg { width: 14px; height: 14px; }
.dw-brand-panel-cta:hover {
  color: #fff;
  filter: brightness(1.08);
  transform: translateY(-1px);
}
.dw-brand-panel-link {
  position: relative;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
  padding: 8px 0;
}
.dw-brand-panel-link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 4px;
  height: 2px;
  background: var(--brand-grad);
  transform: scaleX(0.4);
  transform-origin: left;
  transition: transform 0.2s ease;
}
.dw-brand-panel-link:hover { color: var(--brand); }
.dw-brand-panel-link:hover::after { transform: scaleX(1); }

.dw-brand-panel-side {
  padding: 24px 26px;
  background: linear-gradient(180deg, rgba(9,113,161,0.06), #fff);
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
}
.dw-brand-panel-stats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
}
.dw-brand-panel-stats li {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
}
.dw-brand-panel-stats li:first-child { border-top: 0; padding-top: 0; }
.dw-brand-panel-stats li:last-child { padding-bottom: 0; }
.dw-brand-panel-stat-num {
  font-family: var(--font-serif);
  font-size: 30px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1;
}
.dw-brand-panel-stat-lbl {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: right;
}

@media (max-width: 820px) {
  .dw-brand-panel { margin-top: 40px; padding-top: 24px; }
  .dw-brand-panel-inner { grid-template-columns: 1fr; gap: 28px; }
  .dw-brand-panel-actions { gap: 10px 16px; }
}

.dw-home-cal {
  background: #fff;
  border: 1px solid var(--line);
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  box-shadow: 0 12px 40px rgba(15, 30, 55, 0.12);
}
.dw-home-cal--full { box-shadow: none; max-width: 720px; margin: 0 auto; }
.dw-home-cal--archive { box-shadow: none; }
.dw-home-cal--archive .dw-home-cal-cell { aspect-ratio: 1.05 / 1; font-size: 14px; }
.dw-home-cal--archive .dw-home-cal-grid--head { padding: 10px 8px 6px; }
.dw-home-cal--archive .dw-home-cal-weekday { font-size: 11px; padding: 6px 0; }

/* Calendar head with prev/next nav */
.dw-home-cal-head--nav {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 18px 18px 14px;
}
.dw-home-cal-head-center { text-align: center; flex: 1; min-width: 0; }
.dw-home-cal-nav {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.dw-home-cal-nav svg { width: 16px; height: 16px; }
.dw-home-cal-nav:hover {
  background: var(--brand-grad);
  color: #fff;
  border-color: transparent;
}

/* Contact page calendar section */
.dw-contact-cal-hero {
  background: linear-gradient(135deg, #0f1e37 0%, #0971a1 100%);
  color: #fff;
  padding: 48px 24px 44px;
  text-align: center;
}
.dw-contact-cal-hero .dw-contact-title { font-size: clamp(28px, 3.6vw, 44px); }
.dw-contact-cal-body {
  max-width: 1180px;
  margin: 0 auto;
  padding: 48px 24px 64px;
}
.dw-home-cal-head {
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--line);
  text-align: center;
}
.dw-home-cal-eyebrow {
  margin: 0 0 4px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dw-home-cal-title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text);
}

.dw-home-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.dw-home-cal-grid--head {
  padding: 8px 6px 4px;
  border-bottom: 1px solid var(--soft-line);
}
.dw-home-cal-weekday {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
  padding: 4px 0;
}

.dw-home-cal-cell {
  position: relative;
  aspect-ratio: 1 / 1;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  border-right: 1px solid var(--soft-line);
  border-bottom: 1px solid var(--soft-line);
  text-decoration: none;
}
.dw-home-cal-cell:nth-child(7n) { border-right: 0; }
.dw-home-cal-cell.is-muted { color: #c4c4c4; }
.dw-home-cal-cell.is-today .dw-home-cal-num {
  background: var(--brand-grad);
  color: #fff;
  width: 24px; height: 24px;
  display: grid; place-items: center;
  border-radius: 50%;
  font-weight: 800;
}
.dw-home-cal-cell.has-events {
  font-weight: 800;
  color: var(--brand-dark);
  background: rgba(9,113,161,0.04);
  cursor: pointer;
}
.dw-home-cal-cell.has-events:hover {
  background: rgba(9,113,161,0.12);
  color: var(--brand);
}
button.dw-home-cal-cell {
  font: inherit;
  border: 0;
  border-right: 1px solid var(--soft-line);
  border-bottom: 1px solid var(--soft-line);
  padding: 0;
}
button.dw-home-cal-cell:nth-child(7n) { border-right: 0; }
.dw-home-cal-cell.is-active {
  background: var(--brand-grad) !important;
  color: #fff !important;
}
.dw-home-cal-cell.is-active .dw-home-cal-dot { background: #fff; }
.dw-home-cal-cell.is-active.is-today .dw-home-cal-num {
  background: rgba(255,255,255,0.25);
  color: #fff;
}
.dw-home-cal-num { display: inline-block; line-height: 1; }
.dw-home-cal-dot {
  position: absolute;
  bottom: 5px;
  left: 50%;
  transform: translateX(-50%);
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--brand-grad);
}

/* Selected-day pane */
.dw-home-cal-selected {
  padding: 14px 18px 16px;
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(9,113,161,0.05), #fff);
}
.dw-home-cal-selected[hidden] { display: none; }
.dw-home-cal-selected-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}
.dw-home-cal-selected-title {
  margin: 0;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-dark);
}
.dw-home-cal-selected-close {
  width: 24px; height: 24px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 11px;
  line-height: 1;
  color: var(--muted);
  cursor: pointer;
}
.dw-home-cal-selected-close:hover { background: var(--brand); color: #fff; border-color: var(--brand); }

/* Upcoming events list */
.dw-home-cal-upcoming {
  padding: 16px 18px 18px;
  border-top: 1px solid var(--line);
}
.dw-home-cal-upcoming-title {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
}
.dw-home-cal-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
}
.dw-home-cal-list li {
  border-top: 1px solid var(--line);
}
.dw-home-cal-list li:first-child { border-top: 0; }
.dw-home-cal-list-link {
  display: grid;
  gap: 3px;
  padding: 10px 0;
  color: var(--text);
}
.dw-home-cal-list-link:hover .dw-home-cal-list-title { color: var(--brand); }
.dw-home-cal-list-date {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-home-cal-list-title {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--text);
}
.dw-home-cal-list-loc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.3;
}
.dw-home-cal-empty {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
}
.dw-home-cal-all {
  display: inline-block;
  margin-top: 14px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-home-cal-all:hover { color: var(--brand-dark); }

/* ─── Article page (single post) ──────────────────────────── */
.dw-article-page {
  max-width: var(--max);
  margin: 0 auto;
  padding: 32px 24px 64px;
}
.dw-article-layout {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) minmax(260px, 340px);
  gap: 32px;
  align-items: start;
}

/* Share rail */
.dw-share-rail {
  position: sticky; top: 96px;
  display: grid; gap: 12px;
  padding-top: 170px;
}
.dw-share-btn {
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: #fff;
  color: var(--text);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.dw-share-btn:hover { background: var(--brand-grad); color: #fff; border-color: transparent; }
.dw-share-btn svg { width: 18px; height: 18px; }
.dw-share-btn.is-copied { background: var(--brand-grad); color: #fff; border-color: transparent; }

/* Article main */
.dw-article-main {}
.dw-article-breadcrumb {
  font-size: 14px;
  color: var(--muted);
  margin-bottom: 18px;
}
.dw-article-breadcrumb a { font-weight: 700; color: var(--text-soft); }
.dw-article-breadcrumb a:hover { color: var(--brand); }
.dw-article-breadcrumb span { padding: 0 4px; }

.dw-article-label {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  display: inline-block;
}

.dw-article-title {
  font-family: var(--font-serif);
  max-width: 760px;
  font-size: clamp(38px, 5.2vw, 64px);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.025em;
  color: var(--text);
  margin: 0;
}

.dw-article-dek {
  max-width: 720px;
  margin: 18px 0 18px;
  color: #4a4a4a;
  font-size: 20px;
  line-height: 1.4;
}

.dw-article-byline {
  padding: 14px 0 18px;
  border-top: 1px solid var(--line);
  color: #333;
  font-size: 14px;
}
.dw-article-byline p { margin: 5px 0; }
.dw-article-byline p:first-child { font-weight: 700; }

.dw-article-lead-media { margin: 0 0 28px; }
.dw-article-lead-media img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.dw-article-lead-media figcaption {
  margin-top: 8px;
  color: var(--muted-soft);
  font-size: 12px;
  line-height: 1.4;
}

.dw-article-body { max-width: 680px; }
.dw-article-body p,
.dw-article-body li {
  font-family: var(--font-serif);
  font-size: 20px;
  line-height: 1.6;
  font-weight: 400;
  color: #1a1a1a;
}
.dw-article-body p strong,
.dw-article-body p b,
.dw-article-body li strong,
.dw-article-body li b { font-weight: inherit; }
.dw-article-body p { margin: 0 0 22px; }
.dw-article-body h2,
.dw-article-body h3 {
  font-family: var(--font-sans);
  margin: 32px 0 14px;
  letter-spacing: -0.01em;
}
.dw-article-body h2 { font-size: 26px; }
.dw-article-body h3 { font-size: 21px; }
.dw-article-body a { color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }
.dw-article-body a:hover { color: var(--brand-dark); }
.dw-article-body blockquote {
  margin: 28px 0;
  padding: 6px 0 6px 22px;
  border-left: 4px solid var(--brand);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.45;
  color: var(--text);
}
.dw-article-body img { margin: 24px auto; width: 100%; height: auto; }
.dw-article-body ul,
.dw-article-body ol { padding-left: 24px; margin: 0 0 22px; }
.dw-article-body code {
  background: #f4f5f7;
  padding: 2px 6px;
  font-size: 0.92em;
  font-family: ui-monospace, "SFMono-Regular", Menlo, monospace;
}

/* Inline-related block (heavy black top + hairline bottom) */
.dw-article-body .inline-related,
.dw-inline-related {
  margin: 28px 0;
  padding: 16px 0;
  border-top: 1px solid var(--text);
  border-bottom: 1px solid var(--line);
}
.dw-inline-related h2 { margin: 0 0 10px; font-size: 16px; font-family: var(--font-sans); }
.dw-inline-related a { font-size: 17px; font-weight: 700; line-height: 1.25; color: var(--text); text-decoration: none; }
.dw-inline-related a:hover { color: var(--brand); }

.dw-article-pages {
  margin-top: 26px; padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 14px;
}
.dw-article-pages span { font-weight: 700; margin-right: 8px; }

/* Article sidebar */
.dw-article-sidebar {
  position: sticky; top: 96px;
  display: grid; gap: 22px;
  min-width: 0;
}
.dw-ad-box {
  display: grid; place-items: center;
  min-height: 250px;
  border: 1px solid var(--soft-line);
  background: #f7f7f7;
  color: #8a8a8a;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* Droam promo card (replaces generic ad-box on article page) */
.dw-droam-promo {
  display: block;
  position: relative;
  padding: 22px 22px 24px;
  background: var(--brand-grad);
  color: #fff;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.dw-droam-promo::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(255,255,255,0.16), transparent 65%);
  pointer-events: none;
}
.dw-droam-promo:hover {
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(9, 113, 161, 0.28);
}
.dw-droam-promo-eyebrow {
  margin: 0 0 10px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.78);
}
.dw-droam-promo-title {
  margin: 0 0 10px;
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.01em;
  color: #fff;
}
.dw-droam-promo-text {
  margin: 0 0 14px;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,0.88);
}
.dw-droam-promo-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  position: relative;
}
.dw-droam-promo-cta::after {
  content: "";
  position: absolute;
  left: 0; right: 24px; bottom: -4px;
  height: 1px;
  background: rgba(255,255,255,0.6);
  transition: right 0.2s ease;
}
.dw-droam-promo:hover .dw-droam-promo-cta::after { right: 0; }
.dw-droam-promo-cta svg { width: 14px; height: 14px; }
.dw-sidebar-card {
  border-top: 1px solid var(--text);
  padding-top: 14px;
}
.dw-sidebar-card h2 {
  margin: 0 0 14px;
  font-size: 20px;
  font-weight: 800;
}
.dw-sidebar-card article {
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.dw-sidebar-card article:last-child { border-bottom: 0; margin-bottom: 0; }
.dw-sidebar-card-img { display: block; margin-bottom: 10px; }
.dw-sidebar-card-img img { aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.dw-sidebar-card h3 { margin: 0; font-size: 17px; line-height: 1.2; font-weight: 800; }
.dw-sidebar-card h3 a:hover { color: var(--brand); }

/* ─── Category page ───────────────────────────────────────── */
.dw-category-page {
  max-width: var(--max);
  margin: 0 auto;
  padding: 26px 24px 58px;
}
.dw-category-header {
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.dw-category-header h1 {
  margin: 0 0 18px;
  font-family: var(--font-serif);
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.025em;
}
.dw-category-tabs {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scrollbar-width: none;
  color: #333;
  font-size: 14px;
  font-weight: 700;
  white-space: nowrap;
}
.dw-category-tabs::-webkit-scrollbar { display: none; }
.dw-category-tabs a { color: #333; padding: 2px 0; }
.dw-category-tabs a:hover { color: var(--brand); }
.dw-category-tabs a[aria-current="page"] {
  color: var(--brand);
  position: relative;
}
.dw-category-tabs a[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 3px;
  background: var(--brand-grad);
}

.dw-category-hero {
  display: grid;
  grid-template-columns: minmax(380px, 1.32fr) minmax(230px, 0.75fr) minmax(260px, 0.86fr);
  gap: 24px;
  padding-top: 24px;
}

.dw-category-lead img {
  aspect-ratio: 16/9;
  object-fit: cover;
  width: 100%;
  margin-bottom: 12px;
}
.dw-category-lead h2 {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(32px, 4.1vw, 54px);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.02em;
}
.dw-category-lead h2 a:hover { color: var(--brand); }
.dw-category-lead p {
  margin: 12px 0 14px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.4;
}
.dw-category-lead ul {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--line);
}
.dw-category-lead li {
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.25;
}
.dw-category-lead li::before {
  content: "";
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--brand);
  margin-right: 10px;
  vertical-align: 3px;
}
.dw-category-lead li a:hover { color: var(--brand); }

.dw-category-side article {
  padding-bottom: 15px;
  margin-bottom: 15px;
  border-bottom: 1px solid var(--line);
}
.dw-category-side article:last-child { border-bottom: 0; margin-bottom: 0; }
.dw-category-side img {
  aspect-ratio: 16/10;
  object-fit: cover;
  width: 100%;
  margin-bottom: 10px;
}
.dw-category-side h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.18;
  font-weight: 800;
}
.dw-category-side h3 a:hover { color: var(--brand); }

.dw-latest-panel {
  border-top: 2px solid var(--text);
  padding-top: 12px;
}
.dw-latest-panel h2 {
  margin: 0 0 14px;
  font-size: 22px;
  font-weight: 800;
}
.dw-latest-panel ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
.dw-latest-panel li {
  display: grid;
  gap: 6px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line);
}
.dw-latest-panel li:last-child { border-bottom: 0; }
.dw-latest-panel time {
  color: var(--brand);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
}
.dw-latest-panel a {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.22;
  color: var(--text);
}
.dw-latest-panel a:hover { color: var(--brand); }

.dw-category-section,
.dw-region-layout,
.dw-photo-section {
  margin-top: 40px;
  padding-top: 22px;
  border-top: 2px solid var(--text);
}
.dw-category-section > h2,
.dw-photo-section > h2 {
  margin: 0 0 18px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.dw-world-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.dw-world-card-grid img {
  aspect-ratio: 16/10;
  object-fit: cover;
  width: 100%;
  margin-bottom: 10px;
}
.dw-world-card-grid span {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dw-world-card-grid h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.16;
  font-weight: 800;
}
.dw-world-card-grid h3 a:hover { color: var(--brand); }

.dw-region-layout {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.dw-region-column h2 {
  margin: 0 0 14px;
  font-size: 22px;
  font-weight: 800;
}
.dw-region-column article {
  padding: 14px 0;
  border-top: 1px solid var(--line);
}
.dw-region-column article:first-of-type { border-top-color: var(--text); }
.dw-region-column h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  line-height: 1.18;
}
.dw-region-column h3 a:hover { color: var(--brand); }
.dw-region-column p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.4;
}

.dw-photo-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 22px;
  align-items: start;
}
.dw-photo-grid img {
  aspect-ratio: 16/10;
  object-fit: cover;
  width: 100%;
  margin-bottom: 10px;
}
.dw-photo-large img { aspect-ratio: 16 / 8.5; }
.dw-photo-grid h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.18;
  font-weight: 800;
}
.dw-photo-large h3 { font-size: 24px; }
.dw-photo-grid h3 a:hover { color: var(--brand); }

.dw-blog-pagination {
  margin-top: 40px;
  display: flex; justify-content: center; gap: 8px;
}
.dw-blog-pagination .page-numbers {
  padding: 8px 12px;
  border: 1px solid var(--line);
  font-size: 14px;
  font-weight: 700;
}
.dw-blog-pagination .page-numbers.current {
  background: var(--brand-grad);
  color: #fff;
  border-color: transparent;
}
.dw-blog-pagination .page-numbers:hover:not(.current) { background: #f4f5f7; }

/* ─── Events page (archive-dw_event.php) ──────────────────── */
.dw-events-page {
  max-width: var(--max);
  margin: 0 auto;
  padding: 32px 24px 64px;
}

.dw-events-masthead {
  text-align: center;
  max-width: 820px;
  margin: 0 auto 36px;
  padding-bottom: 28px;
  border-bottom: 2px solid var(--text);
}
.dw-events-kicker {
  margin: 0 0 12px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dw-events-title {
  margin: 0 0 14px;
  font-family: var(--font-serif);
  font-size: clamp(38px, 5.5vw, 64px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.025em;
}
.dw-events-dek {
  margin: 0 auto;
  max-width: 640px;
  font-size: 18px;
  line-height: 1.5;
  color: var(--muted);
}

/* Events page: 2-col split — calendar | upcoming events */
.dw-events-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
  margin-bottom: 56px;
}
.dw-events-split > .dw-calendar-panel,
.dw-events-split > .dw-home-cal {
  margin-bottom: 0;
  align-self: start;
}
.dw-events-split > .dw-events-upcoming { margin-top: 0; }
.dw-events-split .dw-events-grid { grid-template-columns: 1fr; gap: 18px; }
.dw-events-split .dw-event-card { display: grid; grid-template-columns: 140px 1fr; }
.dw-events-split .dw-event-card-img { aspect-ratio: auto; height: 100%; }
.dw-events-split .dw-event-card-img img { height: 100%; min-height: 140px; }
.dw-events-split .dw-event-card-body { padding: 16px 18px; }
.dw-events-split .dw-event-card-title { font-size: 18px; }
.dw-events-split .dw-event-card-excerpt { display: none; }

/* Calendar panel */
.dw-calendar-panel {
  background: #fff;
  border: 1px solid var(--line);
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  padding: 24px;
  margin-bottom: 56px;
}
.dw-calendar-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 18px;
}
.dw-calendar-toolbar-center { text-align: center; }
.dw-calendar-eyebrow {
  margin: 0 0 4px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-calendar-title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 700;
  letter-spacing: -0.02em;
}
.dw-calendar-nav {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
  padding: 8px 14px;
  border: 1px solid var(--line);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.dw-calendar-nav:hover {
  background: var(--brand-grad);
  color: #fff;
  border-color: transparent;
}

.dw-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.dw-calendar-grid-head {
  border-bottom: 2px solid var(--text);
  margin-bottom: 0;
}
.dw-calendar-weekday {
  padding: 10px 8px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
}

.dw-calendar-cell {
  position: relative;
  min-height: 96px;
  padding: 8px 10px;
  border-right: 1px solid var(--soft-line);
  border-bottom: 1px solid var(--soft-line);
  background: #fff;
  display: flex; flex-direction: column;
  gap: 6px;
}
.dw-calendar-cell:nth-child(7n) { border-right: 0; }
.dw-calendar-cell.is-muted { background: #fafbfc; color: #bcbcbc; }
.dw-calendar-cell.is-today { background: linear-gradient(180deg, rgba(9,113,161,0.06), #fff); }
.dw-calendar-cell.is-today .dw-calendar-date {
  background: var(--brand-grad);
  color: #fff;
  border-color: transparent;
}
.dw-calendar-day-head { display: flex; align-items: center; justify-content: space-between; }
.dw-calendar-date {
  width: 30px; height: 30px;
  display: inline-grid; place-items: center;
  border: 1px solid transparent;
  background: transparent;
  font-size: 14px;
  font-weight: 700;
  color: inherit;
  cursor: default;
  border-radius: 0;
}
.dw-calendar-date-btn { cursor: pointer; }
.dw-calendar-date-btn:hover {
  background: var(--brand);
  color: #fff;
}
.dw-calendar-count {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: var(--brand);
  padding: 2px 6px;
  border: 1px solid var(--brand);
}
.dw-calendar-dots { display: flex; gap: 4px; }
.dw-calendar-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand-grad);
}

/* Hover-list popover anchored to cell */
.dw-calendar-cell.is-open { z-index: 30; }
.dw-calendar-cell.is-open::before {
  content: "";
  position: absolute; inset: -1px;
  border: 1px solid var(--text);
  pointer-events: none;
}
.dw-calendar-hover-list {
  position: absolute;
  top: calc(100% + 6px);
  left: -1px;
  width: 320px;
  max-width: 90vw;
  z-index: 40;
  background: #fff;
  border: 1px solid var(--text);
  box-shadow: 0 16px 48px rgba(0,0,0,0.16);
  padding: 14px;
  display: grid; gap: 10px;
}
.dw-calendar-hover-list[hidden] { display: none; }
.dw-calendar-cell.open-right .dw-calendar-hover-list { left: -1px; right: auto; }
.dw-calendar-cell.open-left .dw-calendar-hover-list { left: auto; right: -1px; }
.dw-calendar-cell.open-above .dw-calendar-hover-list { top: auto; bottom: calc(100% + 6px); }
.dw-calendar-hover-item {
  display: grid; gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  background: #fff;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.dw-calendar-hover-item:hover {
  border-color: var(--brand);
  background: #f4f9fc;
}
.dw-calendar-hover-title {
  font-size: 15px;
  font-weight: 800;
  line-height: 1.2;
  color: var(--text);
}
.dw-calendar-hover-meta {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-calendar-hover-excerpt {
  font-size: 13px;
  line-height: 1.4;
  color: var(--muted);
}

/* Mobile sheet */
.dw-calendar-mobile-panel {
  position: fixed; inset: auto 0 0 0;
  z-index: 60;
  background: #fff;
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  box-shadow: 0 -16px 48px rgba(0,0,0,0.18);
  padding: 18px 18px 24px;
  max-height: 70vh;
  overflow-y: auto;
}
.dw-calendar-mobile-panel[hidden] { display: none; }
.dw-calendar-mobile-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.dw-calendar-mobile-panel-label {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 700;
}
.dw-calendar-mobile-panel-close {
  width: 34px; height: 34px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 16px;
}
.dw-calendar-mobile-panel-content {
  display: grid; gap: 10px;
}

/* Upcoming events grid */
.dw-events-upcoming { margin-top: 8px; }
.dw-events-upcoming-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--text);
  margin-bottom: 24px;
}
.dw-events-upcoming-head h2 {
  margin: 0;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.dw-events-upcoming-meta {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.dw-events-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 1fr;
  gap: 28px 24px;
}
.dw-event-card {
  display: grid;
  grid-template-rows: auto 1fr;
  background: #fff;
  border: 1px solid var(--line);
  transition: border-color 0.2s ease, transform 0.3s ease, box-shadow 0.3s ease;
}
.dw-event-card:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(9, 113, 161, 0.10);
}
.dw-event-card-img {
  display: block;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--soft-line);
  position: relative;
}
.dw-event-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.dw-event-card:hover .dw-event-card-img img { transform: scale(1.04); }
.dw-event-card-img--empty {
  background: var(--brand-grad);
  display: grid; place-items: center;
}
.dw-event-card-datebox {
  text-align: center;
  color: #fff;
  font-family: var(--font-serif);
  line-height: 1;
}
.dw-event-card-month {
  display: block;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.dw-event-card-day {
  display: block;
  font-size: 56px;
  font-weight: 700;
  margin-top: 6px;
}
.dw-event-card-body {
  padding: 18px 18px 20px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 0;
}
.dw-event-card-cat {
  margin: 0;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dw-event-card-title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(22px * 1.18 * 2);
}
.dw-event-card-title a:hover { color: var(--brand); }
.dw-event-card-when,
.dw-event-card-where {
  margin: 0;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-soft);
}
.dw-event-card-when svg,
.dw-event-card-where svg {
  width: 14px; height: 14px;
  color: var(--brand);
  flex: 0 0 auto;
}
.dw-event-card-excerpt {
  margin: 4px 0 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.dw-event-card-cta {
  margin-top: auto;
  padding-top: 6px;
  align-self: start;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-event-card-cta:hover { color: var(--brand-dark); }

.dw-events-empty {
  text-align: center;
  padding: 48px 16px;
  max-width: 36rem;
  margin: 0 auto;
}

/* Single event page extras (chiprow + details sidebar) */
.dw-event-chiprow {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin: 18px 0 22px;
}
.dw-event-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 12px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-soft);
}
.dw-event-chip svg {
  width: 15px; height: 15px;
  color: var(--brand);
  flex: 0 0 auto;
}

.dw-event-cta-row { margin: 28px 0 0; }
.dw-event-cta-btn {
  background: var(--brand-grad);
  border-color: transparent;
  color: #fff;
  padding: 12px 22px;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.dw-event-cta-btn:hover { filter: brightness(1.05); background: var(--brand-grad); color: #fff; }

.dw-event-detail-card {
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  background: #f7f9fb;
  padding: 20px 22px 22px;
}
.dw-event-detail-card h2 {
  margin: 0 0 14px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-event-detail-card dl { margin: 0; }
.dw-event-detail-card dl > div {
  padding: 10px 0;
  border-top: 1px solid var(--line);
}
.dw-event-detail-card dl > div:first-child { border-top: 0; padding-top: 0; }
.dw-event-detail-card dt {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}
.dw-event-detail-card dd {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--text);
}
.dw-event-detail-cta {
  display: inline-block;
  margin-top: 14px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-event-detail-cta:hover { color: var(--brand-dark); }

.dw-sidebar-card-meta {
  margin: 4px 0 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand);
}

/* ─── Event single (compat for single-dw_event.php) ───────── */
.dw-single {
  max-width: 800px;
  margin: 0 auto;
  padding: 36px 24px 64px;
}
.dw-single-header { margin-bottom: 26px; }
.dw-single-headline { max-width: 760px; }
.dw-single-topic {
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 12px;
}
.dw-single .dw-kicker { color: var(--muted); }
.dw-single-title {
  font-family: var(--font-serif);
  font-size: clamp(34px, 5vw, 58px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 6px 0 14px;
}
.dw-single-meta {
  font-size: 14px;
  color: var(--muted);
  margin: 4px 0;
}
.dw-single-hero { margin: 24px 0; }
.dw-single-hero img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.dw-single-content { max-width: 680px; margin: 0 auto; }
.dw-single-content p {
  font-family: var(--font-serif);
  font-size: 20px;
  line-height: 1.65;
  color: #1a1a1a;
  margin: 0 0 22px;
}
.dw-single-content a { color: var(--brand); text-decoration: underline; }

/* prose modal body */
.dw-prose p { font-family: var(--font-serif); font-size: 18px; line-height: 1.65; margin: 0 0 18px; }

/* ─── Static pages (default page.php) ────────────────────── */
.dw-page, .dw-static-page {
  max-width: 800px;
  margin: 0 auto;
  padding: 40px 24px 64px;
}
.dw-page h1, .dw-static-page h1 {
  font-family: var(--font-serif);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 18px;
}
.dw-page p, .dw-static-page p { font-family: var(--font-serif); font-size: 18px; line-height: 1.65; margin: 0 0 18px; color: #1a1a1a; }

/* Default page.php inline article */
.page article > h1.dw-headline-serif,
.entry-content {
  font-family: var(--font-serif);
}
.entry-content p,
.entry-content li {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.65;
  color: #1a1a1a;
}
.entry-content p { margin: 0 0 18px; }
.entry-content h2 { font-family: var(--font-sans); font-size: 26px; font-weight: 800; letter-spacing: -0.01em; margin: 32px 0 14px; }
.entry-content h3 { font-family: var(--font-sans); font-size: 21px; font-weight: 800; margin: 26px 0 12px; }
.entry-content a { color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }
.entry-content a:hover { color: var(--brand-dark); }
.entry-content blockquote {
  margin: 26px 0;
  padding: 6px 0 6px 22px;
  border-left: 4px solid var(--brand);
  font-style: italic;
  font-size: 20px;
  line-height: 1.5;
}
.entry-content ul, .entry-content ol { padding-left: 24px; margin: 0 0 20px; }

/* ─── Policy / About / Editorial / Privacy / SEO guide ───── */
.dw-policy-page {
  max-width: var(--max);
  margin: 0 auto;
}

.dw-policy-hero {
  background: var(--brand-grad);
  color: #fff;
  padding: 64px 24px 56px;
  text-align: center;
}
.dw-policy-hero-inner {
  max-width: 820px;
  margin: 0 auto;
}
.dw-policy-hero .dw-contact-title {
  margin: 0 0 12px;
  font-family: var(--font-serif);
  font-size: clamp(38px, 5.5vw, 64px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: #fff;
}
.dw-policy-hero .dw-contact-subtitle {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
}

.dw-policy-body {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 56px;
  padding: 56px 24px 72px;
  max-width: 1180px;
  margin: 0 auto;
}
.dw-policy-body--single {
  grid-template-columns: minmax(0, 760px);
  justify-content: center;
}

.dw-policy-toc-col { align-self: start; }
.dw-policy-toc {
  position: sticky;
  top: 180px;
  padding: 18px 18px 20px;
  background: #f7f9fb;
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
}
.dw-policy-toc-label {
  margin: 0 0 12px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-policy-toc-list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: dw-toc;
}
.dw-policy-toc-list li {
  counter-increment: dw-toc;
  padding: 8px 0;
  border-top: 1px solid var(--line);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
}
.dw-policy-toc-list li:first-child { border-top: 0; padding-top: 0; }
.dw-policy-toc-list li::before {
  content: counter(dw-toc, decimal-leading-zero);
  display: inline-block;
  margin-right: 8px;
  font-size: 11px;
  font-weight: 800;
  color: var(--brand);
}
.dw-policy-toc-list li.dw-toc-sub {
  padding-left: 18px;
  font-size: 13px;
  font-weight: 500;
}
.dw-policy-toc-list a { color: var(--text); }
.dw-policy-toc-list a:hover { color: var(--brand); }

.dw-policy-content-col { min-width: 0; }
.dw-policy-content {
  max-width: 720px;
}
.dw-policy-content h2,
.dw-policy-content h3 {
  scroll-margin-top: 180px;
}
.dw-policy-content h2 {
  font-family: var(--font-sans);
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 36px 0 14px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.dw-policy-content h2:first-child { padding-top: 0; border-top: 0; margin-top: 0; }
.dw-policy-content h3 {
  font-family: var(--font-sans);
  font-size: 19px;
  font-weight: 800;
  margin: 26px 0 10px;
}
.dw-policy-content p,
.dw-policy-content li {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.65;
  color: #1a1a1a;
}
.dw-policy-content p { margin: 0 0 18px; }
.dw-policy-content ul, .dw-policy-content ol { padding-left: 24px; margin: 0 0 20px; }
.dw-policy-content a { color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }
.dw-policy-content a:hover { color: var(--brand-dark); }
.dw-policy-content blockquote {
  margin: 26px 0;
  padding: 6px 0 6px 22px;
  border-left: 4px solid var(--brand);
  font-style: italic;
}

.dw-policy-contact-cta {
  margin-top: 48px;
  padding: 28px 28px;
  background: linear-gradient(180deg, rgba(9,113,161,0.06), #fff);
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  text-align: center;
}
.dw-policy-cta-label {
  margin: 0 0 12px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.dw-policy-cta-link {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  background: var(--brand-grad);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.dw-policy-cta-link:hover { filter: brightness(1.08); color: #fff; }
.dw-policy-cta-link svg { width: 16px; height: 16px; }

/* ─── Contact Us v2 (redesigned) ──────────────────────────── */
.dw-contact-v2 {
  --rail-w: 320px;
}

.dw-contact-v2-hero {
  background: var(--brand-grad);
  color: #fff;
  padding: 72px 24px 64px;
  position: relative;
  overflow: hidden;
}
.dw-contact-v2-hero::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(255,255,255,0.12), transparent 60%);
  pointer-events: none;
}
.dw-contact-v2-hero-inner {
  max-width: 880px;
  margin: 0 auto;
  position: relative;
  text-align: left;
}
.dw-contact-v2-eyebrow {
  margin: 0 0 14px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
}
.dw-contact-v2-title {
  margin: 0 0 18px;
  font-family: var(--font-serif);
  font-size: clamp(40px, 5.8vw, 68px);
  font-weight: 700;
  line-height: 1.0;
  letter-spacing: -0.025em;
  color: #fff;
  max-width: 16ch;
}
.dw-contact-v2-dek {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.55;
  color: rgba(255,255,255,0.88);
  max-width: 60ch;
}

.dw-contact-v2-body {
  max-width: 1180px;
  margin: 0 auto;
  padding: 64px 24px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--rail-w);
  gap: 56px;
  align-items: start;
}

.dw-contact-v2-h2 {
  margin: 0 0 12px;
  font-family: var(--font-serif);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--text);
}
.dw-contact-v2-lead {
  margin: 0 0 28px;
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.55;
  color: var(--muted);
  max-width: 56ch;
}

/* Contact paths definition list */
.dw-contact-v2-paths {
  margin: 0 0 36px;
  padding: 22px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.dw-contact-v2-paths dl {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 28px;
}
.dw-contact-v2-paths > dl > div { padding: 4px 0; }
.dw-contact-v2-paths dt {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 4px;
}
.dw-contact-v2-paths dd {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  color: var(--text-soft);
}

/* CF7 form — editorial card design */
.dw-contact-v2-form-wrap {
  background: #fff;
  border: 1px solid var(--line);
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  padding: 36px 44px 40px;
  box-shadow: 0 8px 28px rgba(15, 30, 55, 0.05);
}
@media (max-width: 640px) {
  .dw-contact-v2-form-wrap { padding: 28px 22px 32px; }
}
.dw-contact-v2-form-wrap .wpcf7-form { display: block; margin: 0; }
.dw-contact-v2-form-wrap .wpcf7-form > p {
  margin: 0 0 28px;
  padding: 4px 0;
  font-size: 14px;
  display: block;
}
.dw-contact-v2-form-wrap .wpcf7-form > p + p { margin-top: 6px; }
.dw-contact-v2-form-wrap .wpcf7-form > p:last-of-type { margin-bottom: 0; }

/* Labels */
.dw-contact-v2-form-wrap label {
  display: block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text);
  padding-top: 10px;
  margin-bottom: 12px;
  position: relative;
}
.dw-contact-v2-form-wrap label > br { display: none; }
.dw-contact-v2-form-wrap label .wpcf7-required,
.dw-contact-v2-form-wrap label .required {
  color: var(--brand);
  margin-left: 4px;
  font-weight: 900;
}

/* Inputs — outlined card with smooth focus */
.dw-contact-v2-form-wrap input[type="text"],
.dw-contact-v2-form-wrap input[type="email"],
.dw-contact-v2-form-wrap input[type="tel"],
.dw-contact-v2-form-wrap input[type="url"],
.dw-contact-v2-form-wrap input[type="number"],
.dw-contact-v2-form-wrap textarea,
.dw-contact-v2-form-wrap select {
  width: 100%;
  padding: 14px 18px;
  border: 1.5px solid var(--line);
  background: #fafbfc;
  font: inherit;
  font-size: 15px;
  color: var(--text);
  margin-top: 0;
  border-radius: 0;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}
.dw-contact-v2-form-wrap input::placeholder,
.dw-contact-v2-form-wrap textarea::placeholder {
  color: #aab0b7;
  font-weight: 400;
}
.dw-contact-v2-form-wrap input:hover,
.dw-contact-v2-form-wrap textarea:hover,
.dw-contact-v2-form-wrap select:hover {
  border-color: #c5cdd5;
  background: #fff;
}
.dw-contact-v2-form-wrap input:focus,
.dw-contact-v2-form-wrap textarea:focus,
.dw-contact-v2-form-wrap select:focus {
  outline: 0;
  background: #fff;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(9,113,161,0.14);
}
.dw-contact-v2-form-wrap input.wpcf7-not-valid,
.dw-contact-v2-form-wrap textarea.wpcf7-not-valid {
  border-color: #c0303f;
  background: #fef5f6;
  animation: dwFieldShake 0.4s ease;
}
@keyframes dwFieldShake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-4px); }
  40%, 80% { transform: translateX(4px); }
}
.dw-contact-v2-form-wrap textarea {
  min-height: 140px;
  max-height: 240px;
  resize: vertical;
  line-height: 1.5;
}

/* Submit button */
.dw-contact-v2-form-wrap .wpcf7-submit,
.dw-contact-v2-form-wrap input[type="submit"] {
  margin-top: 8px;
  padding: 16px 36px;
  background: var(--brand-grad);
  background-size: 180% 180%;
  background-position: 0% 50%;
  border: 0;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 0;
  position: relative;
  transition: background-position 0.4s ease, transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 8px 22px rgba(9, 113, 161, 0.26);
}
.dw-contact-v2-form-wrap .wpcf7-submit:hover {
  background-position: 100% 50%;
  transform: translateY(-2px);
  box-shadow: 0 14px 36px rgba(9, 113, 161, 0.36);
}
.dw-contact-v2-form-wrap .wpcf7-submit:active {
  transform: translateY(0);
  box-shadow: 0 4px 12px rgba(9, 113, 161, 0.22);
}
.dw-contact-v2-form-wrap .wpcf7-submit[disabled],
.dw-contact-v2-form-wrap .wpcf7-submit.disabled {
  opacity: 0.6;
  cursor: wait;
  transform: none;
}

/* Spinner */
.dw-contact-v2-form-wrap .wpcf7-spinner {
  margin: 0 0 0 16px;
  vertical-align: middle;
  background: none;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(9,113,161,0.18);
  border-top-color: var(--brand);
  border-radius: 50%;
  animation: dwSpin 0.7s linear infinite;
}
.dw-contact-v2-form-wrap .wpcf7-spinner::before { display: none; }
@keyframes dwSpin { to { transform: rotate(360deg); } }

/* Response messages — full-bleed banners with icon + slide-in */
.dw-contact-v2-form-wrap .wpcf7-response-output,
.dw-contact-v2-form-wrap form .wpcf7-response-output {
  margin: 26px 0 0 !important;
  padding: 18px 22px 18px 64px !important;
  border: 0 !important;
  border-left: 4px solid var(--brand) !important;
  outline: 0 !important;
  border-radius: 0 !important;
  position: relative;
  font-size: 14px;
  line-height: 1.5;
  font-weight: 600;
  color: var(--text);
  background: #f3f6f9;
  animation: dwResponseIn 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  list-style: none;
}
.dw-contact-v2-form-wrap .wpcf7-response-output::before {
  content: "";
  position: absolute;
  left: 22px; top: 50%;
  transform: translateY(-50%);
  width: 26px; height: 26px;
  border-radius: 50%;
  background-color: var(--brand);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 13l4 4 10-10'/%3E%3C/svg%3E");
  background-size: 16px 16px;
  background-repeat: no-repeat;
  background-position: center;
  box-shadow: 0 4px 10px rgba(0,0,0,0.12);
}
@keyframes dwResponseIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Success state */
.dw-contact-v2-form-wrap form.sent .wpcf7-response-output,
.dw-contact-v2-form-wrap .wpcf7 form.sent .wpcf7-response-output {
  border-left-color: #1e8a4b !important;
  background: linear-gradient(180deg, #effaf2, #f6fbf7) !important;
  color: #144d2a !important;
}
.dw-contact-v2-form-wrap form.sent .wpcf7-response-output::before { background-color: #1e8a4b; }

/* Error / invalid state */
.dw-contact-v2-form-wrap form.invalid .wpcf7-response-output,
.dw-contact-v2-form-wrap form.unaccepted .wpcf7-response-output,
.dw-contact-v2-form-wrap form.payment-required .wpcf7-response-output,
.dw-contact-v2-form-wrap form.failed .wpcf7-response-output,
.dw-contact-v2-form-wrap form.aborted .wpcf7-response-output,
.dw-contact-v2-form-wrap form.spam .wpcf7-response-output {
  border-left-color: #c0303f !important;
  background: linear-gradient(180deg, #fef0f1, #fff5f6) !important;
  color: #6b1d27 !important;
}
.dw-contact-v2-form-wrap form.invalid .wpcf7-response-output::before,
.dw-contact-v2-form-wrap form.unaccepted .wpcf7-response-output::before,
.dw-contact-v2-form-wrap form.failed .wpcf7-response-output::before,
.dw-contact-v2-form-wrap form.aborted .wpcf7-response-output::before,
.dw-contact-v2-form-wrap form.spam .wpcf7-response-output::before {
  background-color: #c0303f;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3C/svg%3E");
}

/* Inline field error tips */
.dw-contact-v2-form-wrap .wpcf7-not-valid-tip {
  color: #c0303f;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-top: 8px;
  padding-left: 18px;
  position: relative;
  display: block;
  animation: dwResponseIn 0.3s ease;
}
.dw-contact-v2-form-wrap .wpcf7-not-valid-tip::before {
  content: "!";
  position: absolute;
  left: 0; top: 0;
  width: 14px; height: 14px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: #c0303f;
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
}

/* Checkbox + radio (wpcf7 list items) */
.dw-contact-v2-form-wrap .wpcf7-list-item {
  display: inline-block;
  margin: 0 14px 8px 0;
  font-size: 14px;
}
.dw-contact-v2-form-wrap .wpcf7-list-item input[type="checkbox"],
.dw-contact-v2-form-wrap .wpcf7-list-item input[type="radio"] {
  width: auto;
  margin-right: 6px;
  accent-color: var(--brand);
}

/* Notice (form-not-found etc.) */
.dw-contact-v2-notice {
  padding: 16px 18px;
  border-left: 4px solid var(--brand);
  background: #f7f9fb;
  font-size: 14px;
  color: var(--text-soft);
  line-height: 1.5;
}

/* Right rail */
.dw-contact-v2-rail {
  position: sticky;
  top: 180px;
  display: grid;
  gap: 18px;
  align-self: start;
}
.dw-contact-v2-card {
  background: #fff;
  border: 1px solid var(--line);
  padding: 22px 22px 24px;
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
}
.dw-contact-v2-card--sub {
  background: linear-gradient(180deg, rgba(9,113,161,0.06), #fff);
}
.dw-contact-v2-card-title {
  margin: 0 0 16px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-contact-v2-card-text {
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
}

/* Offices list */
.dw-contact-v2-offices {
  list-style: none;
  margin: 0;
  padding: 0;
}
.dw-contact-v2-offices li {
  padding: 16px 0;
  border-top: 1px solid var(--line);
}
.dw-contact-v2-offices li:first-child { border-top: 0; padding-top: 0; }
.dw-contact-v2-offices li:last-child { padding-bottom: 0; }
.dw-contact-v2-office-region {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
}
.dw-contact-v2-office-addr {
  font-family: var(--font-serif);
  font-style: normal;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-soft);
  margin: 0 0 10px;
}
.dw-contact-v2-office-links { display: grid; gap: 6px; }
.dw-contact-v2-office-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.dw-contact-v2-office-link svg { width: 13px; height: 13px; color: var(--brand); flex: 0 0 auto; }
.dw-contact-v2-office-link:hover { color: var(--brand); }

/* Subscribe card */
.dw-contact-v2-sub-form { display: grid; gap: 10px; }
.dw-contact-v2-sub-input {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 15px;
}
.dw-contact-v2-sub-input:focus {
  outline: 0;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(9,113,161,0.18);
}
.dw-contact-v2-sub-btn {
  padding: 12px 18px;
  background: var(--brand-grad);
  border: 0;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}
.dw-contact-v2-sub-btn:hover { filter: brightness(1.08); }
.dw-contact-v2-sub-msg { margin: 0; font-size: 13px; color: var(--brand-dark); }

/* Social card */
.dw-contact-v2-social { display: grid; gap: 8px; }
.dw-contact-v2-social-link {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.dw-contact-v2-social-link svg { width: 16px; height: 16px; color: var(--brand); }
.dw-contact-v2-social-link:hover {
  background: var(--brand-grad);
  color: #fff;
  border-color: transparent;
}
.dw-contact-v2-social-link:hover svg { color: #fff; }

/* Events strip */
.dw-contact-v2-events {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px 80px;
}
.dw-contact-v2-events-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--text);
  margin-bottom: 24px;
}
.dw-contact-v2-events-all {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand);
}
.dw-contact-v2-events-all:hover { color: var(--brand-dark); }
.dw-contact-v2-events-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.dw-contact-v2-event {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 14px;
  align-items: start;
  padding: 16px;
  border: 1px solid var(--line);
  background: #fff;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  height: 100%;
}
.dw-contact-v2-event:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(9,113,161,0.10);
}
.dw-contact-v2-event-date {
  display: grid; place-items: center;
  padding: 8px 0;
  background: var(--brand-grad);
  color: #fff;
  text-align: center;
  font-family: var(--font-serif);
  line-height: 1;
}
.dw-contact-v2-event-month {
  display: block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.dw-contact-v2-event-day {
  display: block;
  font-size: 28px;
  font-weight: 700;
  margin-top: 4px;
}
.dw-contact-v2-event-body { min-width: 0; }
.dw-contact-v2-event-title {
  margin: 0 0 6px;
  font-family: var(--font-serif);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--text);
}
.dw-contact-v2-event:hover .dw-contact-v2-event-title { color: var(--brand); }
.dw-contact-v2-event-meta {
  margin: 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  display: flex; flex-wrap: wrap; gap: 4px 10px;
}
.dw-contact-v2-event-meta span:not(:last-child)::after {
  content: "·";
  margin-left: 10px;
  color: var(--line);
}

/* Responsive */
@media (max-width: 1100px) {
  .dw-contact-v2-body {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .dw-contact-v2-rail { position: static; }
  .dw-contact-v2-events-list { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px) {
  .dw-contact-v2-hero { padding: 52px 16px 44px; }
  .dw-contact-v2-body { padding: 44px 16px; gap: 32px; }
  .dw-contact-v2-paths dl { grid-template-columns: 1fr; gap: 14px; }
  .dw-contact-v2-events { padding: 0 16px 56px; }
  .dw-contact-v2-events-list { grid-template-columns: 1fr; }
}

/* ─── Contact Us (legacy v1 classes — kept for fallback) ──── */
.dw-contact-page {}

.dw-contact-hero,
.dw-sub-hero {
  background: var(--brand-grad);
  color: #fff;
  padding: 64px 24px 56px;
  text-align: center;
}
.dw-sub-hero {
  background: linear-gradient(135deg, #0f1e37 0%, #0971a1 100%);
  padding: 48px 24px 44px;
  margin-top: 0;
}
.dw-contact-hero-inner {
  max-width: 820px;
  margin: 0 auto;
}
.dw-contact-title {
  margin: 0 0 12px;
  font-family: var(--font-serif);
  font-size: clamp(38px, 5.5vw, 64px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: #fff;
}
.dw-sub-hero .dw-contact-title { font-size: clamp(28px, 3.6vw, 44px); }
.dw-contact-subtitle {
  margin: 0;
  font-size: 16px;
  color: rgba(255,255,255,0.88);
  line-height: 1.5;
}

.dw-contact-body,
.dw-sub-body {
  max-width: 1180px;
  margin: 0 auto;
  padding: 56px 24px;
}
.dw-sub-body { padding-top: 44px; padding-bottom: 64px; }

.dw-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.9fr);
  gap: 48px;
  align-items: start;
}

.dw-contact-section-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--text);
}
.dw-contact-notice {
  margin: 0 0 22px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--muted);
}
.dw-contact-form-col {}
.dw-contact-info-col { display: grid; gap: 22px; }

/* Office cards */
.dw-office-card {
  background: #fff;
  border: 1px solid var(--line);
  border-top: 4px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  padding: 22px 22px 20px;
}
.dw-office-card-header {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.dw-office-card-icon {
  width: 18px; height: 18px;
  color: var(--brand);
  flex: 0 0 auto;
}
.dw-office-card-region {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text);
}
.dw-office-address {
  font-style: normal;
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.5;
  color: var(--text);
  margin-bottom: 12px;
}
.dw-office-contacts { display: grid; gap: 8px; }
.dw-office-contact-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-soft);
}
.dw-office-contact-link svg { width: 14px; height: 14px; color: var(--brand); flex: 0 0 auto; }
.dw-office-contact-link:hover { color: var(--brand); }

/* Contact social cluster */
.dw-contact-social { display: grid; gap: 8px; }
.dw-contact-social-link {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border: 1px solid var(--line);
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.dw-contact-social-link svg { width: 16px; height: 16px; color: var(--brand); }
.dw-contact-social-link:hover { background: var(--brand-grad); color: #fff; border-color: transparent; }
.dw-contact-social-link:hover svg { color: #fff; }

/* CF7 wrap */
.dw-contact-cf7-wrap input[type="text"],
.dw-contact-cf7-wrap input[type="email"],
.dw-contact-cf7-wrap input[type="tel"],
.dw-contact-cf7-wrap input[type="url"],
.dw-contact-cf7-wrap textarea,
.dw-contact-cf7-wrap select {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line);
  background: #fff;
  font: inherit;
  font-size: 15px;
  margin-top: 4px;
}
.dw-contact-cf7-wrap input:focus,
.dw-contact-cf7-wrap textarea:focus,
.dw-contact-cf7-wrap select:focus {
  outline: 2px solid var(--brand);
  outline-offset: -2px;
  border-color: var(--brand);
}
.dw-contact-cf7-wrap textarea { min-height: 140px; resize: vertical; }
.dw-contact-cf7-wrap p { margin: 0 0 14px; font-size: 14px; }
.dw-contact-cf7-wrap label { display: block; font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.dw-contact-cf7-wrap .wpcf7-submit,
.dw-contact-cf7-wrap input[type="submit"] {
  padding: 12px 24px;
  background: var(--brand-grad);
  border: 0;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
}
.dw-contact-cf7-wrap .wpcf7-submit:hover { filter: brightness(1.05); }
.dw-contact-cf7-wrap .wpcf7-response-output {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  font-size: 14px;
}
.dw-contact-cf7-wrap .wpcf7-not-valid-tip { color: #b00020; font-size: 13px; }

/* Subscribe section */
.dw-sub-form {
  display: grid;
  gap: 12px;
  max-width: 480px;
}
.dw-sub-field { display: grid; gap: 6px; }
.dw-sub-field label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--text);
}
.dw-sub-input {
  padding: 12px 14px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 15px;
}
.dw-sub-input:focus { outline: 2px solid var(--brand); outline-offset: -2px; border-color: var(--brand); }
.dw-sub-submit {
  padding: 12px 24px;
  background: var(--brand-grad);
  border: 0;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  justify-self: start;
}
.dw-sub-submit:hover { filter: brightness(1.05); }
.dw-sub-msg { margin: 0; font-size: 14px; color: var(--brand-dark); }
.dw-sub-benefits {
  list-style: none;
  margin: 0;
  padding: 0;
}
.dw-sub-benefits li {
  position: relative;
  padding: 10px 0 10px 22px;
  border-bottom: 1px solid var(--line);
  font-size: 14px;
  line-height: 1.45;
  color: var(--text);
}
.dw-sub-benefits li:last-child { border-bottom: 0; }
.dw-sub-benefits li::before {
  content: "";
  position: absolute;
  left: 0; top: 18px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand-grad);
}

/* ─── Footer ──────────────────────────────────────────────── */
.dw-footer {
  background: var(--brand-grad);
  color: #fff;
  margin-top: 60px;
  content-visibility: auto;
  contain-intrinsic-size: auto 600px;
}
.dw-footer-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 44px 24px 36px;
}
.dw-footer-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.dw-footer-brand-logo {
  height: 40px;
}
.dw-footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 38px;
  padding-bottom: 30px;
  border-bottom: 1px solid rgba(255,255,255,0.2);
}
.dw-footer-grid h4 {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 14px;
  color: #fff;
}
.dw-footer-stack { display: grid; gap: 10px; }
.dw-footer-stack a { color: rgba(255,255,255,0.7); font-size: 14px; }
.dw-footer-stack a:hover { color: #9bd9f5; }

.dw-footer-social { display: flex; gap: 10px; }
.dw-footer-social-link {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  border-radius: 50%;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.dw-footer-social-link svg { width: 16px; height: 16px; }
.dw-footer-social-link:hover { background: var(--brand-grad); border-color: transparent; color: #fff; }

.dw-footer-bottom {
  display: flex; flex-wrap: wrap; align-items: center; gap: 16px;
  padding-top: 22px;
  font-size: 12px;
  color: rgba(255,255,255,0.55);
}
.dw-footer-copy { color: rgba(255,255,255,0.55); }
.dw-footer-legal-link { color: rgba(255,255,255,0.75); font-size: 12px; }
.dw-footer-legal-link:hover { color: #9bd9f5; }

/* ─── Modal ───────────────────────────────────────────────── */
.dw-modal {
  position: fixed; inset: 0;
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 280ms ease-out, visibility 280ms;
}
.dw-modal.is-open { opacity: 1; visibility: visible; }
.dw-modal[hidden] { display: none; }
.dw-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(8, 12, 18, 0.78);
  backdrop-filter: blur(2px);
}
.dw-modal-panel {
  position: relative;
  background: #fff;
  width: min(880px, 94vw);
  max-height: 92vh;
  display: flex; flex-direction: column;
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
  opacity: 0;
  transform: translateY(48px);
  transition: transform 420ms cubic-bezier(.16,1,.3,1), opacity 280ms ease-out;
}
.dw-modal.is-open .dw-modal-panel {
  opacity: 1;
  transform: translateY(0);
}
.dw-modal-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--line);
  background: #fff;
}
.dw-modal-open-tab {
  font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--brand);
}
.dw-modal-close {
  width: 34px; height: 34px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 18px; font-weight: 700;
  line-height: 1;
}
.dw-modal-close:hover { background: var(--text); color: #fff; border-color: var(--text); }
.dw-modal-scroll { overflow-y: auto; padding: 28px 32px 36px; }
.dw-modal-hero img { aspect-ratio: 16/9; object-fit: cover; width: 100%; margin-bottom: 18px; }
.dw-modal-title {
  font-family: var(--font-serif);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}
.dw-modal-meta { font-size: 13px; color: var(--muted); margin-bottom: 22px; }
.dw-modal-body p { font-family: var(--font-serif); font-size: 18px; line-height: 1.65; margin: 0 0 18px; }
html.dw-modal-open { overflow: hidden; }

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width: 1100px) {
  .dw-cnn-top-grid { grid-template-columns: 1fr 1.4fr; }
  .dw-cnn-right { grid-column: 1 / -1; }
  .dw-cnn-right-feat { aspect-ratio: 16/8; }
  .dw-ribbon { grid-template-columns: repeat(3, 1fr); }
  .dw-front-pulse-grid { grid-template-columns: 1fr; }
  .dw-cat-row-body { grid-template-columns: 1fr !important; }
  .dw-cat-row-body--triple { grid-template-columns: repeat(2, 1fr) !important; }
  .dw-cat-row-body--river { grid-template-columns: repeat(2, 1fr) !important; }
  .dw-cluster { grid-template-columns: 1fr; }
  .dw-article-list { grid-template-columns: repeat(2, 1fr); }
  .dw-flat-feed { grid-template-columns: repeat(2, 1fr); }
  .dw-footer-grid { grid-template-columns: 1fr 1fr; }

  /* Article page: share rail thinner, sidebar narrower but still on the right */
  .dw-article-layout {
    grid-template-columns: 44px minmax(0, 1fr) minmax(220px, 280px);
    gap: 24px;
  }

  /* Category hero: 2 cols + latest panel full-width */
  .dw-category-hero {
    grid-template-columns: minmax(0, 1.25fr) minmax(250px, 0.9fr);
  }
  .dw-latest-panel { grid-column: 1 / -1; }
  .dw-latest-panel ol {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
  }
  .dw-region-layout { grid-template-columns: 1fr 1fr; }
  .dw-photo-grid { grid-template-columns: 1fr 1fr; }

  /* Events */
  .dw-events-grid { grid-template-columns: 1fr 1fr; }
  .dw-calendar-cell { min-height: 80px; }
  .dw-events-split { grid-template-columns: 1fr; gap: 40px; }
  .dw-events-split .dw-events-grid { grid-template-columns: 1fr 1fr; }
  .dw-events-split .dw-event-card { grid-template-columns: 1fr; }
  .dw-events-split .dw-event-card-img { aspect-ratio: 16/10; height: auto; }
  .dw-events-split .dw-event-card-img img { min-height: 0; }

  /* Policy/Contact mid breakpoint */
  .dw-policy-body { grid-template-columns: 1fr; gap: 32px; }
  .dw-policy-toc { position: static; }
  .dw-contact-layout { grid-template-columns: 1fr; gap: 32px; }
}

@media (max-width: 820px) {
  .dw-util-inner { padding: 0 16px; height: auto; min-height: 34px; flex-wrap: wrap; gap: 8px 14px; }
  .dw-util-left { gap: 12px; font-size: 11px; }
  .dw-util-right { gap: 12px; }
  .dw-util-date { display: none; }
  .dw-masthead-inner { padding: 16px 16px 12px; }
  .dw-brand-logo { height: 40px; }
  .dw-site-nav-inner { padding: 0 16px; gap: 18px; justify-content: flex-start; }
  .dw-site-nav-link { font-size: 12px; letter-spacing: 0.04em; }

  /* Homepage mobile: tighter padding, calendar already in flow */
  .dw-home-layout { padding: 18px 16px 48px; }
  .dw-home-sidebar { margin-top: 32px; }

  .dw-cnn-top-grid { grid-template-columns: 1fr; gap: 22px; }
  .dw-cnn-center { order: -1; }
  .dw-cnn-center-title { font-size: 34px; letter-spacing: -0.01em; }
  .dw-cnn-right-feat { aspect-ratio: 16/10; }
  .dw-ribbon { grid-template-columns: 1fr 1fr; }
  .dw-flat-feed { grid-template-columns: 1fr; }
  .dw-flat-card--lead .dw-flat-card-link { grid-template-columns: 1fr; }
  .dw-article-list { grid-template-columns: 1fr; }

  .dw-cat-row-body--triple,
  .dw-cat-row-body--river,
  .dw-cat-row-body--double,
  .dw-cat-row-body--feature,
  .dw-cat-row-body--inverted { grid-template-columns: 1fr !important; }

  .dw-front-shell-head { flex-direction: column; align-items: flex-start; gap: 8px; }

  /* Article page: single column, share rail horizontal under headline */
  .dw-article-page { padding: 24px 16px 48px; }
  .dw-article-layout { grid-template-columns: 1fr; }
  .dw-share-rail {
    position: static;
    display: flex;
    order: 2;
    padding-top: 0;
    flex-wrap: wrap;
  }
  .dw-article-main { order: 1; }
  .dw-article-sidebar {
    position: static;
    width: auto;
    order: 3;
    grid-template-columns: 1fr;
    grid-column: auto;
  }
  .dw-article-title { font-size: 38px; letter-spacing: -0.01em; }
  .dw-article-dek { font-size: 18px; }
  .dw-article-body p, .dw-article-body li { font-size: 18px; }

  /* Category page: collapse */
  .dw-category-page { padding: 22px 16px 48px; }
  .dw-category-hero,
  .dw-world-card-grid,
  .dw-region-layout,
  .dw-photo-grid { grid-template-columns: 1fr; }
  .dw-category-lead h2 { font-size: 32px; letter-spacing: 0; }
  .dw-latest-panel ol { display: block; }

  /* Static pages mobile */
  .dw-policy-hero, .dw-contact-hero, .dw-sub-hero { padding: 44px 16px 36px; }
  .dw-policy-body, .dw-contact-body, .dw-sub-body { padding: 36px 16px; gap: 28px; }
  .dw-policy-contact-cta { padding: 22px 18px; }

  /* Events on mobile */
  .dw-events-page { padding: 22px 16px 48px; }
  .dw-events-title { font-size: 36px; }
  .dw-calendar-panel { padding: 14px; }
  .dw-calendar-toolbar { flex-wrap: wrap; gap: 10px; }
  .dw-calendar-toolbar-center { order: -1; flex: 1 1 100%; }
  .dw-calendar-weekday { font-size: 10px; padding: 8px 2px; }
  .dw-calendar-cell { min-height: 56px; padding: 4px 4px; }
  .dw-calendar-date { width: 24px; height: 24px; font-size: 12px; }
  .dw-calendar-count { display: none; }
  .dw-calendar-hover-list { display: none !important; }
  .dw-events-grid { grid-template-columns: 1fr; }
  .dw-events-upcoming-head { flex-direction: column; align-items: flex-start; gap: 6px; }

  .dw-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .dw-footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px; }
  .dw-modal-panel { width: 96vw; max-height: 96vh; }
  .dw-modal-scroll { padding: 20px 18px 28px; }
}

@media (max-width: 520px) {
  .dw-front-shell-title { font-size: 20px; }
  .dw-cnn-center-title { font-size: 30px; }
  .dw-cnn-mini-img { aspect-ratio: 16/9; }
  .dw-ribbon { grid-template-columns: 1fr; }
  .dw-ticker-text { font-size: 12px; }
  .dw-category-header h1 { font-size: 36px; }
  .dw-article-title { font-size: 32px; }
}

/* Featured guides panel (homepage) */
.dw-guides-panel {
  margin: 56px 0 8px;
  border-top: 2px solid var(--text);
  padding-top: 32px;
}
.dw-guides-panel-inner { min-width: 0; }
.dw-guides-panel-head { margin-bottom: 24px; }
.dw-guides-panel-eyebrow {
  margin: 0 0 14px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dw-guides-panel-title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(24px, 2.6vw, 36px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text);
  max-width: 28ch;
}
.dw-guides-panel-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.dw-guides-panel-item { display: block; }
.dw-guides-panel-link {
  display: block;
  padding: 18px 20px;
  background: var(--page);
  border: 1px solid var(--line);
  border-top: 3px solid transparent;
  border-image: var(--brand-grad);
  border-image-slice: 1;
  color: var(--text);
  height: 100%;
}
@media (prefers-reduced-motion: no-preference) {
  .dw-guides-panel-link {
    transition: transform 0.18s ease, box-shadow 0.18s ease;
  }
  .dw-guides-panel-link:hover {
    transform: translateY(-2px);
  }
}
.dw-guides-panel-link:hover {
  box-shadow: 0 12px 28px rgba(15, 30, 55, 0.10);
  color: var(--text);
}
.dw-guides-panel-link:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 3px;
}
.dw-guides-panel-item-title {
  display: block;
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.22;
  letter-spacing: -0.005em;
  color: var(--text);
  margin-bottom: 8px;
}
.dw-guides-panel-item-blurb {
  display: block;
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
}
@media (max-width: 960px) {
  .dw-guides-panel-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 820px) {
  .dw-guides-panel { margin-top: 40px; padding-top: 24px; }
}
@media (max-width: 600px) {
  .dw-guides-panel-grid { grid-template-columns: 1fr; }
}

/* Footer featured-guides column — inherits .dw-footer-stack styling */
.dw-footer-resources { display: block; }

/* ─── Calendar sidebar / popup transitions ───────────────── */
.dw-home-sidebar {
  transform: translateX(110%);
  opacity: 0;
  visibility: hidden;
  transition: transform 480ms cubic-bezier(.22,1,.36,1), opacity 380ms ease-out, visibility 480ms;
  will-change: transform, opacity;
}
.dw-home-sidebar.is-open {
  transform: translateX(0);
  opacity: 1;
  visibility: visible;
}

#dw-cal-popup {
  position: fixed; inset: 0;
  z-index: 220;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 250ms ease-out, visibility 250ms;
}
#dw-cal-popup.is-open { opacity: 1; visibility: visible; }
#dw-cal-popup[hidden] { display: none; }
.dw-cal-popup-panel {
  opacity: 0;
  transform: scale(.88) translateY(24px);
  transition: transform 320ms cubic-bezier(.34,1.56,.64,1), opacity 250ms ease-out;
}
#dw-cal-popup.is-open .dw-cal-popup-panel {
  opacity: 1;
  transform: scale(1) translateY(0);
}

.dw-cal-events {
  animation: dw-cal-events-in 220ms ease-out both;
}
@keyframes dw-cal-events-in {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Print ───────────────────────────────────────────────── */
@media print {
  .dw-site-header, .dw-footer, .dw-modal { display: none !important; }
  body { color: #000; background: #fff; }
}

@media (prefers-reduced-motion: reduce) {
  .dw-ticker-text > span,
  .dw-util-live-dot::after,
  .dw-ticker-dot::after,
  .dw-featured-label-dot::after { animation: none !important; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
