/*
Theme Name: Vonk
Theme URI: https://example.com
Author: Vonk
Author URI: https://example.com
Description: Vonk — a glossy Dutch magazine theme. Front page driven by your posts, with a feature grid, recommended mini-cards and a magazine-style reading view.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vonk
*/

:root{
  --ink:#1a1014;
  --paper:#fff8f6;
  --magenta:#ff1f7a;
  --coral:#ff5a6e;
  --gold:#f5b53d;
  --plum:#8e2d8c;
  --hot-orange:#ff7a3d;
  --bubble:#ffd6e6;
  --rule:rgba(26,16,20,.12);
  --muted:#8e2d8c;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Jost',sans-serif;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* ---------- top bar ---------- */
.bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 5vw;position:sticky;top:0;z-index:100;
  background:rgba(255,248,246,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--rule);
}
.logo{
  font-family:'Unbounded',sans-serif;font-weight:800;font-size:32px;text-transform:lowercase;
  letter-spacing:-1.5px;text-decoration:none;
  background:linear-gradient(100deg,var(--magenta),var(--hot-orange) 55%,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.nav{display:flex;gap:30px;font-weight:500;font-size:13px;text-transform:uppercase;letter-spacing:2px;list-style:none}
.nav a{color:var(--ink);text-decoration:none;position:relative;transition:.2s}
.nav a:hover{color:var(--magenta)}
.add{
  background:var(--magenta);color:#fff;border:none;padding:11px 22px;border-radius:40px;
  font-family:'Jost';font-weight:600;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:.2s;
  box-shadow:0 6px 18px rgba(255,31,122,.35);text-decoration:none;display:inline-block;
}
.add:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,31,122,.45)}
@media(max-width:760px){.nav{display:none}}

/* ---------- ticker ---------- */
.ticker{
  background:linear-gradient(90deg,var(--magenta),var(--plum));color:#fff;overflow:hidden;white-space:nowrap;padding:11px 0;
}
.ticker span{
  display:inline-block;font-family:'Jost';font-size:13px;letter-spacing:2px;text-transform:uppercase;font-weight:500;
  padding-right:50px;animation:scroll 24s linear infinite;
}
.ticker b{color:var(--gold);font-weight:700}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- thumbnails ---------- */
.thumb{background-size:cover;background-position:center}

/* ---------- suggested mini-cards ---------- */
.suggested{padding:48px 5vw 14px}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:8px}
.sec-head h3{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(26px,4vw,40px);font-style:italic}
.sec-head h3 em{color:var(--magenta)}
.sec-head .more{
  font-family:'Jost';font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:600;
  text-decoration:none;color:var(--magenta);
}
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.mini{
  border-radius:16px;overflow:hidden;cursor:pointer;transition:.25s;background:#fff;
  box-shadow:0 8px 22px rgba(142,45,140,.10);text-decoration:none;color:inherit;display:block;
}
.mini:hover{transform:translateY(-6px);box-shadow:0 16px 34px rgba(255,31,122,.22)}
.mini .thumb{height:120px;position:relative}
.mini .thumb span{
  position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);color:var(--magenta);
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:20px;
}
.mini .body{padding:14px 16px 18px}
.mini h4{font-family:'Playfair Display',serif;font-weight:700;font-size:16px;line-height:1.15}
.mini .meta{font-family:'Jost';font-size:11px;letter-spacing:.5px;color:var(--plum);margin-top:8px;font-weight:500}
@media(max-width:900px){.mini-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.mini-grid{grid-template-columns:1fr}}

/* ---------- feature grid ---------- */
.feed{padding:54px 5vw;display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.card{
  border-radius:20px;overflow:hidden;cursor:pointer;transition:.25s;background:#fff;
  box-shadow:0 10px 30px rgba(142,45,140,.12);display:flex;flex-direction:column;text-decoration:none;color:inherit;
}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(255,31,122,.22)}
.card .thumb{position:relative;width:100%}
.card .tag{
  position:absolute;top:14px;left:14px;background:#fff;color:var(--magenta);
  font-family:'Jost';font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:5px 13px;border-radius:24px;
}
.card .body{padding:22px 24px 26px}
.card h2{font-family:'Playfair Display',serif;font-weight:800;line-height:1.08}
.card .src{font-family:'Jost';font-size:12px;letter-spacing:.5px;margin-top:12px;color:var(--plum);font-weight:500}

.lead{grid-column:span 7}
.lead .thumb{height:340px}
.lead h2{font-size:clamp(30px,3.8vw,46px)}

.side{grid-column:span 5}
.side .thumb{height:200px}
.side h2{font-size:26px}

.c3,.c4,.c5{grid-column:span 4}
.c3 .thumb,.c4 .thumb,.c5 .thumb{height:170px}
.c3 h2,.c4 h2,.c5 h2{font-size:22px}

.wide{grid-column:span 8;flex-direction:row}
.wide .thumb{width:45%;min-height:240px;flex-shrink:0}
.wide .body{display:flex;flex-direction:column;justify-content:center}
.wide h2{font-size:clamp(24px,2.6vw,34px)}

.quote{grid-column:span 4;background:linear-gradient(150deg,var(--magenta),var(--plum));color:#fff;justify-content:center;padding:34px}
.quote h2{font-family:'Playfair Display',serif;font-style:italic;font-size:25px;line-height:1.25}
.quote .src{color:rgba(255,255,255,.85)}

@media(max-width:900px){
  .lead,.side,.wide{grid-column:span 12}
  .wide{flex-direction:column}.wide .thumb{width:100%}
  .c3,.c4,.c5,.quote{grid-column:span 6}
}
@media(max-width:560px){.c3,.c4,.c5,.quote{grid-column:span 12}}

/* ---------- add-source strip ---------- */
.strip{
  margin:0 5vw 70px;border-radius:24px;padding:54px 40px;text-align:center;
  background:linear-gradient(135deg,var(--bubble),#fff 60%,var(--gold));
  box-shadow:0 14px 36px rgba(245,181,61,.25);
}
.strip h3{font-family:'Playfair Display',serif;font-weight:900;font-size:34px;font-style:italic;margin-bottom:10px}
.strip h3 em{color:var(--magenta);font-style:italic}
.strip p{max-width:42ch;margin:0 auto 24px;color:var(--plum);font-weight:500}
.strip .fake-input{
  display:inline-flex;align-items:center;gap:10px;background:#fff;border-radius:40px;
  padding:6px 6px 6px 24px;font-family:'Jost';font-size:14px;box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.strip .fake-input em{color:#bbb;font-style:normal}
.strip .fake-input button{
  background:var(--magenta);color:#fff;border:none;border-radius:30px;padding:12px 24px;
  font-weight:600;cursor:pointer;font-family:'Jost';letter-spacing:1px;text-transform:uppercase;font-size:12px;
}

footer.site{
  background:var(--ink);color:var(--paper);padding:44px 5vw;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-family:'Jost';font-size:13px;letter-spacing:1px;
}
footer.site b{color:var(--gold);font-style:italic;font-family:'Bodoni Moda',serif}
footer.site a{color:var(--paper);text-decoration:none}
footer.site a:hover{color:var(--gold)}

/* =========================================================
   SINGLE ARTICLE — magazine reading view (Vonk styling)
   ========================================================= */
.article-hero{
  width:100%;aspect-ratio:16/9;max-height:460px;
  background-size:cover;background-position:center;
  display:flex;align-items:flex-end;
}
.article-container{
  max-width:1060px;margin:0 auto;padding:48px 5vw 100px;
  display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:56px;align-items:start;
}
.article-container > article{min-width:0;max-width:700px}

.post .kicker{
  display:inline-block;font-family:'Jost';font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  color:#fff;background:linear-gradient(120deg,var(--magenta),var(--plum));
  padding:6px 14px;border-radius:24px;margin-bottom:18px;text-decoration:none;
}
.post h1{
  font-family:'Playfair Display',serif;font-weight:900;font-style:italic;
  font-size:clamp(30px,4.4vw,50px);line-height:1.08;letter-spacing:-.5px;margin-bottom:16px;
}
.post .byline{
  font-family:'Jost';font-size:14px;font-weight:600;color:var(--plum);
  margin-bottom:28px;padding-bottom:20px;border-bottom:2px solid var(--magenta);
}
.post .standfirst{font-size:21px;line-height:1.6;color:#5a4650;margin-bottom:28px;font-weight:500}
.post p{font-size:17px;line-height:1.85;margin-bottom:22px}
.post .standfirst + p::first-letter{
  font-family:'Playfair Display',serif;font-size:64px;line-height:.8;float:left;margin:6px 12px 0 0;color:var(--magenta);font-weight:900;
}
.post h2{font-family:'Playfair Display',serif;font-weight:800;font-size:26px;margin:42px 0 16px;color:var(--plum)}
.post a{color:var(--magenta);text-decoration:underline;font-weight:600}
.post a:hover{text-decoration:none}
.post blockquote{
  margin:32px 0;padding:22px 26px;border-radius:14px;border-left:4px solid var(--magenta);
  background:linear-gradient(135deg,var(--bubble),#fff);
  font-family:'Playfair Display',serif;font-style:italic;font-size:20px;line-height:1.3;
}
.post ul{margin:0 0 24px 22px}
.post ul li{font-size:17px;line-height:1.8;margin-bottom:10px}
.post ul li strong{color:var(--magenta)}
.endmark{text-align:center;margin:48px 0 0;color:var(--magenta);font-size:30px}

.data-table{width:100%;border-collapse:collapse;margin:28px 0;font-size:15px;border-radius:12px;overflow:hidden;box-shadow:0 8px 22px rgba(142,45,140,.12)}
.data-table thead{background:linear-gradient(120deg,var(--magenta),var(--plum));color:#fff}
.data-table th{padding:14px 16px;text-align:left;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.data-table td{padding:14px 16px;border-bottom:1px solid var(--rule)}
.data-table tbody tr:hover{background:var(--bubble)}
.data-table tbody tr:last-child td{border-bottom:none}

.cta-box{margin:36px 0;padding:22px 26px;border-radius:14px;background:linear-gradient(120deg,var(--magenta),var(--plum))}
.cta-box .cta-label{display:block;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:6px}
.cta-box a{color:#fff;font-size:18px;font-weight:700;text-decoration:none}
.cta-box a:hover{opacity:.88}

/* related sidebar */
.related{position:sticky;top:90px}
.related-title{font-family:'Jost';font-size:13px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--magenta);padding-bottom:12px;margin-bottom:16px;border-bottom:3px solid var(--magenta)}
.related-list{display:flex;flex-direction:column}
.related-card{display:block;padding:14px 0;text-decoration:none;border-bottom:1px solid var(--rule);transition:padding-left .15s}
.related-card:last-child{border-bottom:none}
.related-card:hover{padding-left:6px}
.related-kicker{display:block;font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--plum);margin-bottom:5px}
.related-headline{display:block;font-family:'Playfair Display',serif;font-size:16px;font-weight:700;line-height:1.3;color:var(--ink)}
.related-card:hover .related-headline{color:var(--magenta)}

@media(max-width:900px){
  .article-container{grid-template-columns:1fr;gap:40px;max-width:700px}
  .article-container > article{max-width:none}
  .related{position:static;border-top:1px solid var(--rule);padding-top:28px}
}
@media(max-width:600px){
  .article-container{padding:32px 6vw 80px}
}

/* simple archive/listing reuse */
.page-head{padding:48px 5vw 0}
.page-head h1{font-family:'Playfair Display',serif;font-style:italic;font-weight:900;font-size:clamp(28px,4vw,44px)}
.page-head h1 em{color:var(--magenta)}
