/* ============================================================
   OMMETOER — BLOGMODULE STYLING
   Brand tokens eerst; nergens losse kleuren hardcoden.
   ============================================================ */
:root {
  --ot-bg:        #260F0D;
  --ot-text:      #FDF3C3;
  --ot-text-dim:  rgba(253, 243, 195, 0.62);
  --ot-line:      rgba(253, 243, 195, 0.16);
  --ot-fill:      rgba(253, 243, 195, 0.08);
  --ot-radius:    14px;
  --ot-maxw:      1200px;
}

/* PP Mori Semibold — TODO Laura: plaats de fontbestanden in /fonts en check de paden. */
@font-face {
  font-family: "PP Mori";
  src: url("../fonts/PPMori-SemiBold.woff2") format("woff2"),
       url("../fonts/PPMori-SemiBold.woff")  format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

.ot-blog, .ot-blog * { box-sizing: border-box; }
.ot-blog {
  font-family: "PP Mori", "Helvetica Neue", Arial, sans-serif;
  font-weight: 600; color: var(--ot-text);
  -webkit-font-smoothing: antialiased; letter-spacing: 0.01em;
}
.ot-page { background: var(--ot-bg); color: var(--ot-text); min-height: 100vh; margin: 0; }
.ot-wrap { max-width: var(--ot-maxw); margin: 0 auto; padding: 0 24px; }

.ot-btn {
  display: inline-block; font: inherit; text-decoration: none; color: var(--ot-text);
  border: 1px solid var(--ot-line); border-radius: 999px; padding: 10px 22px;
  font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase;
  transition: background .25s ease, border-color .25s ease; white-space: nowrap;
}
.ot-btn:hover { background: var(--ot-fill); border-color: var(--ot-text-dim); }
.ot-link { color: var(--ot-text-dim); text-decoration: none; transition: color .2s ease; }
.ot-link:hover { color: var(--ot-text); }

.ot-home { background: var(--ot-bg); color: var(--ot-text); padding: clamp(48px, 8vw, 110px) 24px; }
.ot-home__inner { max-width: var(--ot-maxw); margin: 0 auto; }
.ot-home__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: clamp(28px, 4vw, 52px); }
.ot-home__title, .ot-hero__title { margin: 0; font-weight: 600; line-height: 1.02; letter-spacing: 0.005em; font-size: clamp(30px, 5.2vw, 62px); }

.ot-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.6vw, 40px); }
@media (max-width: 900px) { .ot-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ot-grid { grid-template-columns: 1fr; } }

.ot-card { display: block; text-decoration: none; color: inherit; }
.ot-card__media {
  position: relative; width: 100%; aspect-ratio: 3 / 4; border-radius: var(--ot-radius);
  overflow: hidden; background: var(--ot-fill); border: 1px solid var(--ot-line);
}
.ot-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.ot-card__ph {
  position: absolute; inset: 0; display: grid; place-items: center;
  color: var(--ot-text-dim); font-size: 12px; letter-spacing: 0.22em;
  background: radial-gradient(120% 120% at 30% 20%, rgba(253,243,195,0.10), transparent 60%), var(--ot-fill);
}
.ot-card:hover .ot-card__media img { transform: scale(1.04); }
.ot-card:hover .ot-card__ph { color: var(--ot-text); }
.ot-card__meta { margin-top: 16px; }
.ot-card__kw { display: block; font-size: 11.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ot-text-dim); margin-bottom: 8px; }
.ot-card__title { margin: 0; font-size: clamp(17px, 1.5vw, 21px); font-weight: 600; line-height: 1.18; }
.ot-card:focus-visible .ot-card__media, .ot-btn:focus-visible, .ot-link:focus-visible { outline: 2px solid var(--ot-text); outline-offset: 3px; border-radius: var(--ot-radius); }

.ot-overview-hero { padding: clamp(60px, 9vw, 130px) 0 clamp(32px, 5vw, 60px); }
.ot-overview-hero p { max-width: 560px; color: var(--ot-text-dim); font-size: clamp(15px, 1.4vw, 18px); line-height: 1.5; margin: 18px 0 0; }

.ot-topbar { display: flex; align-items: center; justify-content: space-between; padding: 22px 0; border-bottom: 1px solid var(--ot-line); }
.ot-topbar__brand { font-size: 15px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ot-text); text-decoration: none; }

.ot-article { padding: clamp(28px, 5vw, 64px) 0 0; }
.ot-article__head { max-width: 820px; margin: 0 auto clamp(24px, 4vw, 40px); text-align: center; }
.ot-article__kw { font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ot-text-dim); }
.ot-article__title { margin: 14px 0 0; font-size: clamp(28px, 4.4vw, 52px); line-height: 1.06; font-weight: 600; }
.ot-article__date { margin-top: 14px; color: var(--ot-text-dim); font-size: 13px; letter-spacing: 0.08em; }

.ot-hero-img { width: 100%; aspect-ratio: 16 / 9; border-radius: var(--ot-radius); overflow: hidden; background: var(--ot-fill); border: 1px solid var(--ot-line); margin: 0 0 clamp(32px, 5vw, 56px); position: relative; }
.ot-hero-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ot-hero-img .ot-card__ph { font-size: 13px; }

.ot-body { max-width: 720px; margin: 0 auto; padding-bottom: clamp(48px, 7vw, 96px); }
.ot-body p { font-size: clamp(16px, 1.5vw, 19px); line-height: 1.7; margin: 0 0 1.3em; color: var(--ot-text); }
.ot-body h2 { font-size: clamp(20px, 2.4vw, 28px); line-height: 1.2; margin: 1.8em 0 .6em; }
.ot-body blockquote { margin: 1.8em 0; padding: 6px 0 6px 26px; border-left: 2px solid var(--ot-text-dim); font-size: clamp(19px, 2.2vw, 25px); line-height: 1.35; }
.ot-body figure { margin: 2em 0; }
.ot-body figure .ot-imgwrap { width: 100%; aspect-ratio: 16 / 10; border-radius: var(--ot-radius); overflow: hidden; background: var(--ot-fill); border: 1px solid var(--ot-line); position: relative; display:block; }
.ot-body figure img { width: 100%; height: 100%; object-fit: cover; display: block; }

.ot-other { border-top: 1px solid var(--ot-line); padding: clamp(44px, 6vw, 84px) 0 clamp(60px, 8vw, 110px); }
.ot-other__head { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: clamp(24px, 3.5vw, 44px); }
.ot-other__title { margin: 0; font-size: clamp(13px, 1.4vw, 15px); letter-spacing: 0.22em; text-transform: uppercase; color: var(--ot-text-dim); }

.ot-foot { border-top: 1px solid var(--ot-line); padding: 28px 0; display: flex; justify-content: space-between; gap: 16px; color: var(--ot-text-dim); font-size: 13px; letter-spacing: 0.06em; }
.ot-empty { text-align: center; padding: clamp(80px, 14vw, 200px) 0; }
.ot-empty h1 { font-size: clamp(24px, 4vw, 40px); margin: 0 0 18px; }
