/* =============================================================
   Verzorgingsgids — verzorgingsgids.nl
   Production stylesheet (classic PHP WordPress theme)
   -------------------------------------------------------------
   Brand: practical, approachable, warm personal-care magazine.
   Tagline: "Slimme verzorging, elke dag."
   This single stylesheet powers both the live theme and the
   design-reference HTML mocks. Edit here; both stay in sync.
   ============================================================= */

/* -------------------------------------------------------------
   1. Tokens
   ------------------------------------------------------------- */
:root{
  --primary:#CD7C5F;   /* terracotta — links, accents, "gids", druppel */
  --zalm:#E2A98F;      /* salmon — accent on dark, hovers */
  --pale:#F4DDD0;      /* pale tint — wordmark on dark, soft fills */
  --ink:#5C4E46;       /* warm brown — body text + "Verzorgings" */
  --head:#463A33;      /* darker warm brown — headings */
  --panel:#FCF6F1;     /* warm cream — cards / sections */
  --bg:#FFFDFB;        /* cream-white — page */
  --hair:#EFE4DC;      /* hairline borders / dividers */
  --dark-panel:#3A2C27;/* dark mission / CTA block */
  --footer:#28201C;    /* deep espresso — footer */
  --muted:#A99C92;     /* brown-grey — tagline, meta, captions */

  /* category accents */
  --cat-huidverzorging:#CD7C5F;
  --cat-haarverzorging:#B5734E;
  --cat-lichaam:#7E9B7A;
  --cat-make-up:#C9758C;
  --cat-gezondheid:#5E8C8A;
  --cat-producten:#9A7BB0;

  --maxw:1200px;
  --gutter:40px;
  --radius:16px;
  --radius-sm:12px;
  --radius-chip:999px;

  --wordmark:'Fraunces',Georgia,'Times New Roman',serif;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;   /* koppen / display / wordmark */
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif; /* body / nav / meta / tagline */
}

/* -------------------------------------------------------------
   2. Reset & base
   ------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;}
a{color:var(--primary);text-decoration:none;transition:color .18s ease;}
a:hover{color:#b5664c;}
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:400;
  color:var(--head);
  letter-spacing:-.01em;
  line-height:1.12;
  margin:0;
  text-wrap:balance;
}
p{margin:0 0 1.1em;}
p:last-child{margin-bottom:0;}
ul,ol{margin:0 0 1.1em;padding-left:1.3em;}
hr{border:0;border-top:1px solid var(--hair);margin:0;}
::selection{background:var(--pale);color:var(--head);}

.vg-wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);}

/* eyebrow / kicker / labels */
.vg-eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
}

/* skip link for a11y */
.vg-skip{position:absolute;left:-999px;top:0;background:var(--primary);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200;}
.vg-skip:focus{left:0;color:#fff;}

/* -------------------------------------------------------------
   3. Brand lockup (header / footer)
   ------------------------------------------------------------- */
.vg-brand{display:inline-flex;align-items:center;gap:20px;text-decoration:none;}
.vg-brand .drop{height:54px;width:auto;color:var(--primary);flex:none;}
.vg-brand .drop path{vector-effect:non-scaling-stroke;}
.vg-brand .wm{
  font-family:var(--wordmark);
  font-weight:400;
  letter-spacing:-.012em;
  line-height:1;
  font-size:31px;
  color:var(--ink);
  white-space:nowrap;
}
.vg-brand .wm .acc{color:var(--primary);}
/* on dark */
.vg-brand.is-dark .drop{color:var(--zalm);}
.vg-brand.is-dark .wm{color:var(--pale);}
.vg-brand.is-dark .wm .acc{color:var(--zalm);}

/* primary stacked lockup with justified tagline (hero / footer) */
.vg-lockup{display:inline-flex;align-items:center;gap:24px;}
.vg-lockup .drop{height:84px;width:auto;color:var(--primary);flex:none;}
.vg-lockup .brand-col{display:inline-flex;flex-direction:column;width:fit-content;}
.vg-lockup .wm{font-family:var(--wordmark);font-weight:400;letter-spacing:-.012em;line-height:1;font-size:42px;color:var(--ink);white-space:nowrap;}
.vg-lockup .wm .acc{color:var(--primary);}
.vg-lockup .tag{width:100%;display:flex;justify-content:space-between;font-family:var(--sans);font-weight:400;text-transform:uppercase;color:var(--muted);font-size:10.5px;letter-spacing:.18em;margin-top:.78em;}
.vg-lockup.is-dark .drop{color:var(--zalm);}
.vg-lockup.is-dark .wm{color:var(--pale);}
.vg-lockup.is-dark .wm .acc{color:var(--zalm);}
.vg-lockup.is-dark .tag{color:rgba(244,221,208,.6);}
/* header-maat lockup: druppel + wordmark + 4-woorden tagline eronder */
.vg-lockup.is-header{gap:16px;}
.vg-lockup.is-header .drop{height:50px;}
.vg-lockup.is-header .wm{font-size:27px;}
.vg-lockup.is-header .tag{font-size:8.5px;letter-spacing:.16em;margin-top:.6em;}

/* -------------------------------------------------------------
   4. Header / navigation
   ------------------------------------------------------------- */
.vg-topbar{
  background:var(--panel);
  border-bottom:1px solid var(--hair);
  font-size:11.5px;
  color:var(--muted);
}
.vg-topbar .vg-wrap{display:flex;justify-content:space-between;align-items:center;height:38px;}
.vg-topbar .tagline{font-style:italic;font-family:var(--serif);font-size:13px;color:var(--ink);white-space:nowrap;}
.vg-topbar .links{white-space:nowrap;}
.vg-topbar .links{display:flex;gap:22px;align-items:center;}
.vg-topbar a{color:var(--muted);letter-spacing:.02em;}
.vg-topbar a:hover{color:var(--primary);}

.vg-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,253,251,.92);
  backdrop-filter:saturate(1.1) blur(8px);
  border-bottom:1px solid var(--hair);
}
.vg-header .vg-wrap{display:flex;align-items:center;justify-content:space-between;gap:32px;height:88px;}
.vg-nav{display:flex;align-items:center;gap:30px;}
.vg-nav a{
  font-family:var(--sans);
  font-weight:500;
  font-size:14.5px;
  color:var(--ink);
  letter-spacing:.01em;
  position:relative;
  padding:6px 0;
  white-space:nowrap;
}
.vg-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:var(--cat,var(--primary));transition:right .22s ease;border-radius:2px;
}
.vg-nav a:hover{color:var(--head);}
.vg-nav a:hover::after,.vg-nav a.is-active::after{right:0;}
.vg-nav a.is-active{color:var(--head);}
.vg-search-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:var(--radius-chip);
  border:1px solid var(--hair);background:#fff;color:var(--ink);cursor:pointer;flex:none;
  transition:border-color .18s ease,color .18s ease;
}
.vg-search-btn:hover{border-color:var(--primary);color:var(--primary);}
.vg-search-btn svg{width:18px;height:18px;}
.vg-burger{display:none;}

/* -------------------------------------------------------------
   5. Category chips & accent dots
   ------------------------------------------------------------- */
.vg-chip{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--cat,var(--primary));
  padding:5px 13px;border-radius:var(--radius-chip);
  background:color-mix(in srgb,var(--cat,var(--primary)) 12%,transparent);
  line-height:1;
}
.vg-chip.is-plain{background:none;padding-left:0;}

a.vg-chip:hover{color:var(--cat,var(--primary));filter:brightness(.92);}

/* meta line */
.vg-meta{font-family:var(--sans);font-size:13px;color:var(--muted);display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.vg-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.6;}

/* -------------------------------------------------------------
   6. Image frames / placeholders
   ------------------------------------------------------------- */
.vg-figure{
  position:relative;overflow:hidden;border-radius:var(--radius);
  background:
    radial-gradient(120% 120% at 18% 12%, color-mix(in srgb,var(--cat,var(--primary)) 26%,var(--panel)) 0%, color-mix(in srgb,var(--cat,var(--primary)) 9%,var(--panel)) 55%, var(--panel) 100%);
}
.vg-figure img{width:100%;height:100%;object-fit:cover;}
.vg-figure::after{ /* subtle droplet watermark for placeholder state */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:no-repeat center/auto 46% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='10 6 80 98'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.5' stroke-width='3' stroke-linejoin='round' stroke-linecap='round'%3E%3Cpath d='M50 14 C66 38 78 54 78 68 a28 28 0 0 1 -56 0 C22 54 34 38 50 14 Z'/%3E%3Cpath d='M40 64 a10 10 0 0 0 8 12' opacity='0.5'/%3E%3C/g%3E%3C/svg%3E");
}
.vg-figure.has-img::after{display:none;}
.vg-figure .vg-figcap{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;font-size:11px;letter-spacing:.04em;color:#fff;background:linear-gradient(to top,rgba(40,32,28,.55),transparent);}
.aspect-16-9{aspect-ratio:16/9;}
.aspect-4-3{aspect-ratio:4/3;}
.aspect-3-2{aspect-ratio:3/2;}
.aspect-1-1{aspect-ratio:1/1;}

/* -------------------------------------------------------------
   7. Article cards
   ------------------------------------------------------------- */
.vg-card{display:flex;flex-direction:column;gap:14px;}
.vg-card .vg-figure{margin-bottom:2px;}
.vg-card h3{font-size:21px;line-height:1.18;}
.vg-card h3 a{color:var(--head);}
.vg-card h3 a:hover{color:var(--primary);}
.vg-card p{font-size:14.5px;color:var(--ink);line-height:1.6;margin:0;}
.vg-card .vg-meta{margin-top:2px;}

/* horizontal list item (no image / small thumb) */
.vg-listitem{display:grid;grid-template-columns:1fr;gap:8px;padding:22px 0;border-top:1px solid var(--hair);}
.vg-listitem:first-child{border-top:0;padding-top:0;}
.vg-listitem h3{font-size:19px;line-height:1.2;}
.vg-listitem h3 a{color:var(--head);}
.vg-listitem h3 a:hover{color:var(--primary);}
.vg-listitem.with-thumb{grid-template-columns:1fr 104px;align-items:start;gap:18px;}
.vg-listitem.with-thumb .vg-figure{width:104px;height:104px;border-radius:var(--radius-sm);}
.vg-listitem .num{font-family:var(--serif);font-size:15px;color:var(--primary);}

/* -------------------------------------------------------------
   8. Homepage hero (asymmetric)
   ------------------------------------------------------------- */
.vg-hero{padding:54px 0 64px;border-bottom:1px solid var(--hair);}
.vg-hero-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:56px;align-items:start;}
.vg-hero-feature .vg-figure{margin-bottom:26px;}
.vg-hero-feature h1{font-size:clamp(34px,4.4vw,56px);line-height:1.04;margin:18px 0 0;}
.vg-hero-feature h1 a{color:var(--head);}
.vg-hero-feature h1 a:hover{color:var(--primary);}
.vg-hero-feature .dek{font-size:19px;line-height:1.55;color:var(--ink);margin:18px 0 22px;max-width:38ch;}
.vg-hero-aside{display:flex;flex-direction:column;}
.vg-hero-aside .aside-head{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding-bottom:16px;border-bottom:2px solid var(--head);margin-bottom:4px;}

/* byline w/ avatar */
.vg-byline{display:flex;align-items:center;gap:12px;}
.vg-avatar{
  width:38px;height:38px;border-radius:50%;flex:none;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:14px;color:#fff;
  background:var(--primary);letter-spacing:.01em;
}
.vg-byline .by-name{font-family:var(--sans);font-weight:600;font-size:13.5px;color:var(--head);line-height:1.2;}
.vg-byline .by-meta{font-size:12.5px;color:var(--muted);line-height:1.2;margin-top:2px;}

/* -------------------------------------------------------------
   9. Section headings
   ------------------------------------------------------------- */
.vg-section{padding:60px 0;}
.vg-section.tight{padding:44px 0;}
.vg-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:32px;}
.vg-section-head h2{font-size:27px;}
.vg-section-head .more{font-family:var(--sans);font-weight:500;font-size:13.5px;color:var(--primary);display:inline-flex;align-items:center;gap:6px;}
.vg-section-head .more svg{width:14px;height:14px;}
.vg-rule-head{display:flex;align-items:center;gap:18px;margin-bottom:30px;}
.vg-rule-head h2{font-size:27px;flex:none;}
.vg-rule-head .rule{flex:1;height:1px;background:var(--hair);}

/* -------------------------------------------------------------
   10. Grids
   ------------------------------------------------------------- */
.vg-grid{display:grid;gap:38px 40px;}
.cols-2{grid-template-columns:repeat(2,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-4{grid-template-columns:repeat(4,1fr);}
/* asymmetric "latest" grid: 1 lead + list */
.vg-split{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:start;}

/* -------------------------------------------------------------
   11. Category explore strip
   ------------------------------------------------------------- */
.vg-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.vg-cat-tile{
  display:flex;align-items:center;gap:14px;
  padding:20px 22px;border:1px solid var(--hair);border-radius:var(--radius);
  background:#fff;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;
}
.vg-cat-tile:hover{border-color:color-mix(in srgb,var(--cat) 45%,var(--hair));transform:translateY(-2px);box-shadow:0 10px 26px rgba(92,78,70,.07);}
.vg-cat-tile .swatch{width:40px;height:40px;border-radius:12px;flex:none;background:var(--cat);display:flex;align-items:center;justify-content:center;}
.vg-cat-tile .swatch svg{width:22px;height:22px;color:#fff;}
.vg-cat-tile .label{font-family:var(--serif);font-size:18px;color:var(--head);line-height:1.15;}
.vg-cat-tile .count{display:block;font-family:var(--sans);font-size:12px;color:var(--muted);margin-top:3px;letter-spacing:.02em;}

/* -------------------------------------------------------------
   12. Mission / stats (dark panel)
   ------------------------------------------------------------- */
.vg-mission{background:var(--dark-panel);color:var(--pale);border-radius:calc(var(--radius) + 8px);overflow:hidden;}
.vg-mission-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:0;}
.vg-mission .copy{padding:56px 52px;}
.vg-mission .eyebrow{color:var(--zalm);margin-bottom:18px;}
.vg-mission h2{color:#fff;font-size:30px;line-height:1.18;margin-bottom:18px;}
.vg-mission p{color:rgba(244,221,208,.82);font-size:16px;line-height:1.7;max-width:42ch;}
.vg-stats{display:grid;grid-template-columns:1fr 1fr;border-left:1px solid rgba(244,221,208,.12);}
.vg-stat{padding:34px 36px;border-bottom:1px solid rgba(244,221,208,.12);border-right:1px solid rgba(244,221,208,.12);}
.vg-stat:nth-child(2n){border-right:0;}
.vg-stat:nth-child(n+3){border-bottom:0;}
.vg-stat .num{font-family:var(--serif);font-size:42px;line-height:1;color:#fff;}
.vg-stat .lab{font-family:var(--sans);font-size:13px;color:var(--zalm);margin-top:10px;letter-spacing:.02em;line-height:1.4;}

/* -------------------------------------------------------------
   13. Newsletter / CTA band
   ------------------------------------------------------------- */
.vg-news{background:var(--panel);border:1px solid var(--hair);border-radius:var(--radius);padding:46px 48px;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;}
.vg-news h2{font-size:27px;margin-bottom:12px;}
.vg-news p{color:var(--ink);font-size:15px;max-width:40ch;}
.vg-form{display:flex;gap:10px;}
.vg-input{flex:1;border:1px solid var(--hair);background:#fff;border-radius:var(--radius-chip);padding:14px 20px;font-family:var(--sans);font-size:15px;color:var(--ink);}
.vg-input::placeholder{color:var(--muted);}
.vg-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 18%,transparent);}
.vg-btn{
  border:0;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:14.5px;
  padding:14px 26px;border-radius:var(--radius-chip);background:var(--primary);color:#fff;
  white-space:nowrap;transition:background .18s ease,transform .12s ease;
}
.vg-btn:hover{background:#bd6e52;}
.vg-btn:active{transform:translateY(1px);}
.vg-btn.is-ghost{background:#fff;color:var(--head);border:1px solid var(--hair);}
.vg-btn.is-ghost:hover{border-color:var(--primary);color:var(--primary);}
.vg-form .note{font-size:11.5px;color:var(--muted);margin-top:10px;}

/* -------------------------------------------------------------
   14. Footer
   ------------------------------------------------------------- */
.vg-footer{background:var(--footer);color:rgba(244,221,208,.7);margin-top:0;}
.vg-footer .vg-wrap{padding-top:64px;padding-bottom:40px;}
.vg-footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(244,221,208,.12);}
.vg-footer .about p{color:rgba(244,221,208,.62);font-size:14px;line-height:1.7;margin:22px 0 0;max-width:34ch;}
.vg-footer h4{color:var(--pale);font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;}
.vg-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.vg-footer ul a{color:rgba(244,221,208,.72);font-size:14px;}
.vg-footer ul a:hover{color:var(--zalm);}
.vg-footer .accent-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:9px;vertical-align:middle;}
.vg-footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:26px;font-size:12.5px;color:rgba(244,221,208,.5);flex-wrap:wrap;}
.vg-footer-bottom a{color:rgba(244,221,208,.6);}
.vg-footer-bottom a:hover{color:var(--zalm);}
.vg-footer-bottom .legal{display:flex;gap:22px;}

/* -------------------------------------------------------------
   15. Breadcrumbs
   ------------------------------------------------------------- */
.vg-breadcrumbs{font-family:var(--sans);font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:9px;flex-wrap:wrap;padding:22px 0;}
.vg-breadcrumbs a{color:var(--muted);}
.vg-breadcrumbs a:hover{color:var(--primary);}
.vg-breadcrumbs .sep{opacity:.5;}
.vg-breadcrumbs .current{color:var(--ink);}

/* -------------------------------------------------------------
   16. Single article
   ------------------------------------------------------------- */
.vg-article{padding:4px 0 0;}
/* compacte, redactionele opener: titelblok links, beeld rechts ernaast */
.vg-article-head{display:grid;grid-template-columns:1.02fr .98fr;gap:52px;align-items:center;padding:10px 0 30px;border-bottom:1px solid var(--hair);}
.vg-article-head .head-text .vg-chip{margin-bottom:16px;}
.vg-article-head h1{font-size:clamp(30px,3.3vw,44px);line-height:1.08;}
.vg-article-head .dek{font-family:var(--serif);font-weight:300;font-size:19px;line-height:1.5;color:var(--ink);margin:16px 0 0;max-width:46ch;}
.vg-article-head .vg-byline{margin-top:22px;}
.vg-article-head .head-figure{margin:0;}
.vg-article-head .head-figure .vg-figure{border-radius:var(--radius);}
.vg-article-head .head-cap{font-size:12px;color:var(--muted);margin-top:10px;}
@media (max-width:860px){
  .vg-article-head{grid-template-columns:1fr;gap:24px;padding-top:6px;}
}

.vg-prose{max-width:calc(var(--maxw) - 2*var(--gutter));margin:0 auto;padding:38px 0 8px;font-size:18px;line-height:1.75;color:var(--ink);}
.vg-prose > p:first-of-type::first-letter{
  font-family:var(--serif);font-weight:400;float:left;font-size:64px;line-height:.78;
  padding:6px 12px 0 0;color:var(--primary);
}
.vg-prose h2{font-size:28px;margin:46px 0 16px;}
.vg-prose h3{font-size:21px;margin:34px 0 12px;color:var(--head);}
.vg-prose a{text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--primary) 45%,transparent);}
.vg-prose ul,.vg-prose ol{margin:0 0 1.4em;padding-left:1.4em;}
.vg-prose li{margin-bottom:.5em;}
.vg-prose li::marker{color:var(--primary);}
.vg-prose figure{margin:38px 0;}
.vg-prose figure .vg-figure{border-radius:var(--radius);}
.vg-prose figcaption{font-size:12.5px;color:var(--muted);margin-top:10px;text-align:center;}

/* pull quote */
.vg-pullquote{margin:42px 0;padding:6px 0 6px 28px;border-left:3px solid var(--primary);}
.vg-pullquote p{font-family:var(--serif);font-weight:300;font-size:26px;line-height:1.35;color:var(--head);font-style:italic;margin:0;}
.vg-pullquote cite{display:block;font-family:var(--sans);font-style:normal;font-size:13px;color:var(--muted);margin-top:12px;letter-spacing:.02em;}

/* numbered step list (routines) */
.vg-steps{list-style:none;margin:34px 0;padding:0;counter-reset:step;}
.vg-steps li{position:relative;padding:0 0 26px 64px;counter-increment:step;}
.vg-steps li::before{
  content:counter(step);position:absolute;left:0;top:-2px;
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:19px;color:#fff;background:var(--primary);
}
.vg-steps li:not(:last-child)::after{content:"";position:absolute;left:21px;top:46px;bottom:6px;width:2px;background:var(--hair);}
.vg-steps li h3{margin:6px 0 6px;font-size:19px;}
.vg-steps li p{font-size:16px;margin:0;color:var(--ink);}

/* tip / info callout */
.vg-callout{background:var(--panel);border:1px solid var(--hair);border-radius:var(--radius);padding:24px 26px;margin:36px 0;display:flex;gap:18px;}
.vg-callout .ic{width:38px;height:38px;border-radius:10px;background:color-mix(in srgb,var(--primary) 14%,transparent);color:var(--primary);display:flex;align-items:center;justify-content:center;flex:none;}
.vg-callout .ic svg{width:20px;height:20px;}
.vg-callout h4{font-family:var(--serif);font-size:17px;color:var(--head);margin-bottom:6px;}
.vg-callout p{font-size:14.5px;margin:0;color:var(--ink);}

/* tags */
.vg-tags{max-width:calc(var(--maxw) - 2*var(--gutter));margin:34px auto 0;display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.vg-tag{font-size:13px;color:var(--ink);background:var(--panel);border:1px solid var(--hair);border-radius:var(--radius-chip);padding:6px 14px;}
.vg-tag:hover{border-color:var(--primary);color:var(--primary);}

/* author box */
.vg-authorbox{max-width:calc(var(--maxw) - 2*var(--gutter));margin:44px auto 0;padding:28px;background:var(--panel);border:1px solid var(--hair);border-radius:var(--radius);display:flex;gap:20px;align-items:flex-start;}
.vg-authorbox .vg-avatar{width:58px;height:58px;font-size:20px;}
.vg-authorbox .name{font-family:var(--serif);font-size:20px;color:var(--head);}
.vg-authorbox .role{font-size:12.5px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin:3px 0 10px;}
.vg-authorbox p{font-size:14.5px;color:var(--ink);margin:0;}

/* share rail */
.vg-share{max-width:calc(var(--maxw) - 2*var(--gutter));margin:30px auto 0;display:flex;align-items:center;gap:14px;padding-top:24px;border-top:1px solid var(--hair);}
.vg-share span{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.vg-share a{width:38px;height:38px;border-radius:50%;border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;color:var(--ink);}
.vg-share a:hover{border-color:var(--primary);color:var(--primary);}
.vg-share a svg{width:16px;height:16px;}

/* -------------------------------------------------------------
   17. Category & archive header
   ------------------------------------------------------------- */
.vg-archive-head{padding:52px 0 44px;border-bottom:1px solid var(--hair);position:relative;}
.vg-archive-head::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:var(--cat,var(--primary));}
.vg-archive-head .vg-eyebrow{color:var(--cat,var(--primary));margin-bottom:14px;}
.vg-archive-head h1{font-size:clamp(34px,5vw,56px);line-height:1.02;}
.vg-archive-head .desc{font-size:18px;color:var(--ink);max-width:56ch;margin-top:18px;line-height:1.6;}
.vg-archive-head .count{font-size:13px;color:var(--muted);margin-top:18px;letter-spacing:.02em;}

/* pagination */
.vg-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin:56px 0 0;}
.vg-pagination a,.vg-pagination span{min-width:42px;height:42px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--hair);border-radius:10px;font-size:14px;font-weight:500;color:var(--ink);background:#fff;}
.vg-pagination a:hover{border-color:var(--primary);color:var(--primary);}
.vg-pagination .is-current{background:var(--primary);border-color:var(--primary);color:#fff;}
.vg-pagination .dots{border:0;background:none;color:var(--muted);}

/* -------------------------------------------------------------
   18. Generic page (pagina)
   ------------------------------------------------------------- */
.vg-page-head{padding:48px 0 36px;text-align:center;}
.vg-page-head h1{font-size:clamp(32px,4.6vw,52px);}
.vg-page-head .lede{font-family:var(--serif);font-weight:300;font-size:20px;color:var(--ink);max-width:56ch;margin:18px auto 0;line-height:1.5;}

/* -------------------------------------------------------------
   19. Search
   ------------------------------------------------------------- */
.vg-searchbar{max-width:680px;margin:0 auto;display:flex;gap:10px;}
.vg-searchbar .vg-input{flex:1;}
.vg-result{display:grid;grid-template-columns:1fr;gap:8px;padding:26px 0;border-top:1px solid var(--hair);}
.vg-result:first-of-type{border-top:0;}
.vg-result .vg-chip{margin-bottom:4px;}
.vg-result h3{font-size:22px;}
.vg-result h3 a{color:var(--head);}
.vg-result h3 a:hover{color:var(--primary);}
.vg-result p{font-size:14.5px;color:var(--ink);margin:0;max-width:70ch;}
.vg-result mark{background:color-mix(in srgb,var(--primary) 22%,transparent);color:var(--head);padding:0 2px;border-radius:3px;}

/* -------------------------------------------------------------
   20. 404
   ------------------------------------------------------------- */
.vg-404{text-align:center;padding:80px 0;max-width:620px;margin:0 auto;}
.vg-404 .drop{height:84px;width:auto;color:var(--primary);margin:0 auto 26px;}
.vg-404 .code{font-family:var(--serif);font-size:84px;line-height:1;color:var(--head);}
.vg-404 h1{font-size:30px;margin:14px 0 14px;}
.vg-404 p{color:var(--ink);font-size:16px;margin:0 auto 30px;max-width:46ch;}
.vg-404 .quick{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:26px;}

/* -------------------------------------------------------------
   21. Utilities
   ------------------------------------------------------------- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.divider{height:1px;background:var(--hair);border:0;}
.vg-section + .vg-section{padding-top:0;}

/* -------------------------------------------------------------
   22. Responsive
   ------------------------------------------------------------- */
@media (max-width:1040px){
  :root{--gutter:32px;}
  .vg-hero-grid{grid-template-columns:1fr;gap:44px;}
  .vg-split{grid-template-columns:1fr;gap:40px;}
  .vg-mission-inner{grid-template-columns:1fr;}
  .vg-stats{border-left:0;border-top:1px solid rgba(244,221,208,.12);}
  .vg-footer-top{grid-template-columns:1fr 1fr;gap:36px;}
  .cols-4{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:760px){
  :root{--gutter:20px;}
  body{font-size:16px;}
  .vg-topbar{display:none;}
  .vg-header .vg-wrap{height:72px;}
  .vg-nav{display:none;}
  .vg-burger{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;border:1px solid var(--hair);background:#fff;color:var(--ink);cursor:pointer;}
  .vg-burger svg{width:20px;height:20px;}
  .vg-brand .drop{height:42px;}
  .vg-brand .wm{font-size:25px;}
  .vg-cats{grid-template-columns:1fr;}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr;}
  .vg-news{grid-template-columns:1fr;gap:24px;padding:32px 26px;}
  .vg-mission .copy{padding:38px 28px;}
  .vg-stat{padding:26px 24px;}
  .vg-footer-top{grid-template-columns:1fr 1fr;}
  .vg-form{flex-direction:column;}
  .vg-listitem.with-thumb{grid-template-columns:1fr 80px;}
  .vg-listitem.with-thumb .vg-figure{width:80px;height:80px;}
}
@media (max-width:460px){
  .vg-footer-top{grid-template-columns:1fr;}
}
