/* ============================================================
   Cadeaukompas — premium Dutch gift-guide design system
   Palette: warm cream + deep berry + amber gold. Editorial, trustworthy.
   ============================================================ */
:root{
  --cream:#fbf7f2; --cream-2:#f4ece1; --ink:#211b24; --ink-soft:#5b5560;
  --berry:#7c2d54; --berry-dk:#5e2040; --berry-tint:#f3e4ec;
  --gold:#c8893b; --gold-dk:#a96e26; --gold-tint:#f8edda;
  --line:#e8ded2; --white:#ffffff; --green:#2f7d5d;
  --shadow-sm:0 1px 2px rgba(33,27,36,.06),0 2px 8px rgba(33,27,36,.05);
  --shadow:0 6px 22px rgba(33,27,36,.10);
  --shadow-lg:0 18px 50px rgba(94,32,64,.16);
  --r:14px; --r-lg:22px; --maxw:1180px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);
  line-height:1.65;-webkit-font-smoothing:antialiased;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--berry);text-decoration:none}
a:hover{color:var(--berry-dk)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,5vw,3.7rem);font-weight:600}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
h3{font-size:1.3rem}
p{color:var(--ink-soft)}
.lead{font-size:1.2rem;color:var(--ink-soft);max-width:60ch}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold-dk)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:600;
  font-size:1rem;padding:.85em 1.5em;border-radius:999px;border:0;cursor:pointer;transition:.18s;
  text-decoration:none}
.btn-primary{background:var(--berry);color:#fff;box-shadow:0 6px 16px rgba(124,45,84,.28)}
.btn-primary:hover{background:var(--berry-dk);color:#fff;transform:translateY(-1px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-dk));color:#fff}
.btn-gold:hover{filter:brightness(1.05);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:var(--white);color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--berry);color:var(--berry)}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,242,.82);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-weight:600;
  font-size:1.35rem;color:var(--ink)}
.brand .mark{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;
  background:linear-gradient(140deg,var(--berry),var(--gold));color:#fff;font-size:1.1rem}
.nav-links{display:flex;gap:1.6rem;align-items:center;list-style:none}
.nav-links a{color:var(--ink);font-weight:500;font-size:.97rem}
.nav-links a:hover{color:var(--berry)}
.nav-cta{display:flex;gap:.6rem;align-items:center}
.burger{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:84px 0 72px;
  background:radial-gradient(1200px 500px at 80% -10%,var(--gold-tint),transparent 60%),
             radial-gradient(900px 460px at 5% 110%,var(--berry-tint),transparent 55%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin:.5rem 0 1rem}
.hero h1 .hl{color:var(--berry);font-style:italic}
.hero .lead{margin-bottom:1.7rem}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.6rem}
.chips{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{background:var(--white);border:1px solid var(--line);border-radius:999px;
  padding:.4em .95em;font-size:.88rem;font-weight:500;color:var(--ink);box-shadow:var(--shadow-sm)}
.chip:hover{border-color:var(--berry);color:var(--berry)}
/* hero visual collage */
.hero-art{position:relative;height:420px}
.gift-card{position:absolute;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  background:var(--white);overflow:hidden;border:1px solid var(--line)}
.gift-card .top{height:64%;display:grid;place-items:center;font-size:3rem}
.gift-card .bot{padding:.7rem .9rem}
.gift-card .bot small{color:var(--gold-dk);font-weight:700;font-size:.72rem;letter-spacing:.06em}
.gift-card .bot b{display:block;font-family:var(--serif);font-size:1.05rem;color:var(--ink)}
.gc1{width:200px;height:240px;left:0;top:20px;transform:rotate(-5deg)}
.gc1 .top{background:linear-gradient(140deg,#f3e4ec,#e7c6d8)}
.gc2{width:210px;height:252px;right:8px;top:0;transform:rotate(4deg);z-index:2}
.gc2 .top{background:linear-gradient(140deg,#f8edda,#eccf9a)}
.gc3{width:196px;height:226px;left:60px;bottom:0;transform:rotate(3deg)}
.gc3 .top{background:linear-gradient(140deg,#e4eee9,#bfe0cf)}

/* ---------- trust band ---------- */
.trust{background:var(--ink);color:#e9e2ec}
.trust .wrap{display:flex;gap:2.4rem;flex-wrap:wrap;justify-content:center;
  padding:18px 24px;font-size:.92rem}
.trust b{color:#fff}
.trust span{display:inline-flex;align-items:center;gap:.5rem}

/* ---------- sections ---------- */
section{padding:72px 0}
.sec-head{max-width:62ch;margin-bottom:38px}
.sec-head.center{margin:0 auto 40px;text-align:center}
.sec-head p{margin-top:.6rem}

/* category grid */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat{display:block;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px 22px;box-shadow:var(--shadow-sm);transition:.2s}
.cat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.cat .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.6rem;
  margin-bottom:14px;background:var(--berry-tint)}
.cat h3{margin-bottom:.3rem}
.cat p{font-size:.93rem}
.cat .more{display:inline-block;margin-top:10px;color:var(--berry);font-weight:600;font-size:.9rem}

/* guide cards */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.guide{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.2s;display:flex;flex-direction:column}
.guide:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.guide .cover{height:172px;display:grid;place-items:center;font-size:2.6rem;position:relative}
.guide .cover .tag{position:absolute;left:14px;top:14px;background:rgba(255,255,255,.9);
  color:var(--berry-dk);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.3em .7em;border-radius:999px}
.guide .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.guide .body h3{font-size:1.18rem;line-height:1.2}
.guide .body p{font-size:.94rem;flex:1}
.guide .meta{display:flex;align-items:center;gap:.5rem;color:var(--ink-soft);font-size:.83rem;margin-top:.4rem}
.cv-a{background:linear-gradient(140deg,#f3e4ec,#e7c6d8)}
.cv-b{background:linear-gradient(140deg,#f8edda,#eccf9a)}
.cv-c{background:linear-gradient(140deg,#e4eee9,#bfe0cf)}
.cv-d{background:linear-gradient(140deg,#e7e4f3,#c9c2e6)}
.cv-e{background:linear-gradient(140deg,#fbe7e0,#f3c3b0)}
.cv-f{background:linear-gradient(140deg,#e3eef3,#b8d6e6)}

/* product card (used on guide pages) */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prod{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.2s;display:flex;flex-direction:column}
.prod:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.prod .ph{height:170px;background:var(--cream-2);display:grid;place-items:center;font-size:2.4rem}
.prod .pb{padding:16px 18px 18px;display:flex;flex-direction:column;gap:.45rem;flex:1}
.prod .pb h4{font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1.3}
.prod .price{font-family:var(--serif);font-size:1.25rem;color:var(--berry);font-weight:600}
.prod .price small{color:var(--ink-soft);font-family:var(--sans);font-weight:500;font-size:.8rem}
.prod .btn{margin-top:auto;justify-content:center}
.rating{color:var(--gold-dk);font-size:.85rem;font-weight:600}

/* clean product media (consistent white frame for all product photos) */
.media{background:#fff;border-bottom:1px solid var(--line);height:210px;display:grid;place-items:center;
  padding:20px;overflow:hidden}
.media img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;mix-blend-mode:multiply}
.media.ph-empty{background:linear-gradient(140deg,var(--cream),var(--cream-2));border-bottom:1px solid var(--line)}
.media.ph-empty .mono{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;
  font-family:var(--serif);font-size:1.7rem;color:#fff;background:linear-gradient(140deg,var(--berry),var(--gold))}
.guide .media{height:200px}
.score-badge{position:absolute;left:12px;top:12px;background:#fff;color:var(--ink);font-weight:700;
  font-size:.82rem;padding:.32em .7em;border-radius:999px;box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:.25rem}
.score-badge .st{color:var(--gold-dk)}
.guide{position:relative}

/* review hero (page header, real-review layout) */
.rev-hero{display:grid;grid-template-columns:minmax(0,420px) 1fr;gap:36px;align-items:center;
  background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;
  box-shadow:var(--shadow-sm);margin:8px 0 30px}
.rev-hero .media{height:300px;border:0;border-radius:14px;background:#fff}
.rev-hero .vlabel{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.13em;
  text-transform:uppercase;color:var(--gold-dk);margin:.1rem 0 .6rem}
.rev-hero .ravg{display:flex;align-items:baseline;gap:.5rem;margin:.3rem 0 .7rem}
.rev-hero .ravg .num{font-family:var(--serif);font-size:2.6rem;color:var(--berry);line-height:1}
.rev-hero .ravg .max{color:var(--ink-soft)}
.rev-hero .ravg .stars{color:var(--gold-dk);font-size:1.05rem;letter-spacing:1px}
.rev-hero h1{font-size:clamp(1.7rem,3.2vw,2.3rem);margin:.1rem 0}
.rev-hero .vsum{color:#3a343f;margin:.5rem 0 1rem}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:8px 0 6px}
.pc{border-radius:14px;padding:18px 20px}
.pc.pos{background:#eef7f1;border:1px solid #cfe7da}
.pc.neg{background:#fbeeec;border:1px solid #f0d3cc}
.pc h4{font-family:var(--sans);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.5rem}
.pc.pos h4{color:var(--green)} .pc.neg h4{color:#b0492f}
.pc ul{list-style:none;margin:0;display:grid;gap:.5rem}
.pc li{padding-left:1.4rem;position:relative;color:#3a343f;font-size:.96rem}
.pc.pos li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}
.pc.neg li::before{content:"–";position:absolute;left:0;color:#b0492f;font-weight:700}
@media(max-width:760px){.rev-hero{grid-template-columns:1fr}.rev-hero .media{height:240px}.proscons{grid-template-columns:1fr}}

/* ===== Tom's-Guide-style review chrome ===== */
.rev-meta{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;font-size:.9rem;color:var(--ink-soft);
  padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:6px 0 18px}
.pill{display:inline-block;background:var(--berry);color:#fff;font-weight:700;font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;padding:.3em .7em;border-radius:6px}
.rev-meta .author{color:var(--ink);font-weight:600}
.share{display:flex;gap:.45rem;margin-left:auto}
.share a{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--cream-2);
  color:var(--ink-soft);font-size:.85rem;font-weight:700;text-decoration:none}
.share a:hover{background:var(--berry);color:#fff}
.tg-disc{font-size:.85rem;color:var(--ink-soft);background:var(--cream-2);border-radius:8px;padding:10px 14px;margin:0 0 22px}
.reasons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:6px 0 8px}
.reasons .col{border-radius:14px;padding:18px 20px}
.reasons .buy{background:#eef7f1;border:1px solid #cfe7da}
.reasons .avoid{background:#fbeeec;border:1px solid #f0d3cc}
.reasons h4{font-family:var(--sans);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.6rem}
.reasons .buy h4{color:var(--green)} .reasons .avoid h4{color:#b0492f}
.reasons ul{list-style:none;margin:0;display:grid;gap:.5rem}
.reasons li{padding-left:1.5rem;position:relative;color:#3a343f;font-size:.96rem}
.reasons .buy li::before{content:"✚";position:absolute;left:0;color:var(--green);font-weight:700}
.reasons .avoid li::before{content:"✕";position:absolute;left:0;color:#b0492f;font-weight:700}
/* labelled ad slot (real-site convention) */
.adslot{border:1px dashed var(--line);border-radius:10px;min-height:90px;display:grid;place-items:center;
  margin:26px 0;background:repeating-linear-gradient(45deg,#fbf7f2,#fbf7f2 10px,#f7f1e8 10px,#f7f1e8 20px)}
.adslot .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#b3a999}
/* where-to-buy / offers slot (for future affiliate links/ads) */
.buybox{border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;margin:30px 0;background:var(--white);box-shadow:var(--shadow-sm)}
.buybox h3{font-family:var(--serif);font-size:1.3rem;margin-bottom:4px}
.buybox .sub{color:var(--ink-soft);font-size:.92rem;margin-bottom:14px}
.buybox .offers{display:grid;gap:10px}
.buybox .offer{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);
  border-radius:10px;padding:12px 16px}
.buybox .offer .shop{font-weight:600;color:var(--ink)}
.buybox .empty{color:var(--ink-soft);font-size:.92rem;text-align:center;padding:8px 0}
.related-wrap{border-top:1px solid var(--line);margin-top:40px;padding-top:28px}
.related-wrap h2{margin-bottom:18px}

/* editorial / article */
.article{max-width:760px;margin:0 auto;padding:56px 24px}
.article .kicker{color:var(--gold-dk);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.8rem}
.article h1{margin:.5rem 0 .7rem}
.article .dek{font-size:1.22rem;color:var(--ink-soft);margin-bottom:1.4rem}
.article .byline{display:flex;align-items:center;gap:.7rem;color:var(--ink-soft);font-size:.9rem;
  padding-bottom:24px;border-bottom:1px solid var(--line);margin-bottom:32px}
.article h2{margin:42px 0 14px}
.article h3{margin:28px 0 8px;font-family:var(--sans);font-weight:700;font-size:1.18rem}
.article p{margin-bottom:1.1rem;color:#3a343f}
.article ul,.article ol{margin:0 0 1.2rem 1.3rem;color:#3a343f}
.article li{margin-bottom:.5rem}
.callout{background:var(--gold-tint);border-left:4px solid var(--gold);border-radius:10px;
  padding:18px 20px;margin:24px 0;font-size:.98rem}
.callout b{color:var(--gold-dk)}
.toc{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:20px 24px;margin:0 0 30px}
.toc b{font-family:var(--sans);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.toc ol{margin:.6rem 0 0 1.1rem}
.toc a{color:var(--ink)}
.disclosure{font-size:.85rem;color:var(--ink-soft);background:var(--cream-2);border-radius:10px;
  padding:12px 16px;margin:18px 0}

/* newsletter */
.news{background:linear-gradient(135deg,var(--berry),var(--berry-dk));color:#fff;border-radius:var(--r-lg);
  padding:48px;display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:center}
.news h2{color:#fff}
.news p{color:#f0dde7}
.news form{display:flex;gap:.6rem;flex-wrap:wrap}
.news input{flex:1;min-width:200px;border:0;border-radius:999px;padding:.9em 1.2em;font-size:1rem}

/* footer */
.foot{background:var(--ink);color:#cfc7d4;padding:56px 0 28px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.foot h4{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.foot a{color:#cfc7d4;display:block;padding:.25rem 0;font-size:.95rem}
.foot a:hover{color:#fff}
.foot .brand{color:#fff;margin-bottom:12px}
.foot-bottom{border-top:1px solid #3a3340;margin-top:36px;padding-top:20px;font-size:.85rem;
  color:#9a90a3;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* breadcrumb */
.crumb{font-size:.86rem;color:var(--ink-soft);padding:18px 0}
.crumb a{color:var(--ink-soft)}

/* responsive */
@media(max-width:980px){
  .hero-grid,.news{grid-template-columns:1fr}
  .hero-art{height:300px;order:-1}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .guide-grid,.prod-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-links{display:none}
  .burger{display:block}
  .cat-grid,.guide-grid,.prod-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  section{padding:52px 0}
  .news{padding:30px}
}
