/* Component & layout CSS.
   Vereist: /styles/tokens.css (variabelen + reset).
   Edit hier → upload-css.mjs → live. */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}

/* HEADER */
.site-header{background:var(--neo-card);border-bottom:4px solid #000;position:sticky;top:0;z-index:50}
.site-header .wrap{display:flex;align-items:center;gap:16px;min-height:72px;padding-top:14px;padding-bottom:14px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0;font-weight:700;font-size:20px;font-family:"Space Grotesk",Inter,sans-serif;letter-spacing:-.02em}
.brand-icon{width:42px;height:42px;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);color:#000;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px}
.brand-name{display:flex;align-items:baseline;gap:0}
.brand-name b{color:#FF5E5B}
.search{flex:1;max-width:560px;margin:0 auto;position:relative}
.search input{width:100%;height:44px;padding:0 14px 0 42px;border-radius:0;border:3px solid #000;background:#fff;font-size:14px;color:#000;font-weight:600;box-shadow:var(--shadow-sm);transition:box-shadow .1s,transform .1s,background .1s;font-family:"Space Grotesk",Inter,sans-serif}
.search input::placeholder{color:#525252;font-weight:500;font-family:Inter,sans-serif}
.search input:hover{box-shadow:var(--shadow);transform:translate(-1px,-1px)}
.search input:focus{outline:0;background:#fff;box-shadow:var(--shadow);transform:translate(-1px,-1px)}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#000;width:20px;height:20px;pointer-events:none;z-index:2;stroke-width:2.5}

/* SEARCH DROPDOWN — neo-brutalist autocomplete-paneel */
.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:3px solid #000;border-radius:0;box-shadow:6px 6px 0 0 #000;max-height:480px;overflow-y:auto;z-index:100;font-size:14px}
.search-dropdown[hidden]{display:none}
.sd-section{padding:0;border-bottom:3px solid #000}
.sd-section:last-of-type{border-bottom:0}
.sd-label{display:block;font-size:11px;font-weight:800;color:#000;background:var(--neo-yellow);text-transform:uppercase;letter-spacing:.08em;padding:8px 16px;font-family:"Space Grotesk",Inter,sans-serif;border-bottom:3px solid #000}
.sd-item{display:flex;align-items:center;gap:12px;padding:11px 16px;color:#000;font-weight:600;text-decoration:none;cursor:pointer;border-bottom:2px solid #f3f4f6;transition:background .1s}
.sd-item:last-child{border-bottom:0}
.sd-item:hover,.sd-item.active{background:var(--neo-yellow);font-weight:700}
.sd-item b{font-weight:800;color:#000;background:var(--neo-yellow);padding:0 2px;border:1px solid #000}
.sd-item:hover b,.sd-item.active b{background:#fff}
.sd-icon{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:#000;color:#fff;font-family:"Space Grotesk",Inter,sans-serif;font-weight:800}
.sd-cat .sd-icon{background:var(--neo-pink);color:#000}
.sd-shop .sd-icon{background:#000;color:var(--neo-yellow)}
.sd-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sd-count{color:#525252;font-size:12px;font-weight:700;flex-shrink:0;margin-left:8px;font-family:"Space Grotesk",Inter,sans-serif}
.sd-item:hover .sd-count,.sd-item.active .sd-count{color:#000}
.sd-empty{padding:18px 16px;color:#525252;text-align:center;font-size:13px;font-weight:600}
.sd-all{display:flex;align-items:center;justify-content:center;padding:12px 16px;color:#000;font-weight:800;background:var(--neo-yellow);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-family:"Space Grotesk",Inter,sans-serif;text-decoration:none;border-top:3px solid #000}
.sd-all:hover{background:var(--neo-pink)}
.nav-actions{display:flex;align-items:center;gap:14px;flex-shrink:0}
.nav-popular{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:#000;text-transform:uppercase;letter-spacing:.04em}
.nav-popular .pulse{position:relative;display:inline-block;width:12px;height:12px}
.nav-popular .pulse::before{content:"";position:absolute;inset:0;background:var(--neo-green);border:2px solid #000;border-radius:50%}
.nav-popular .pulse::after{content:"";position:absolute;inset:-3px;background:var(--neo-green);border-radius:50%;opacity:.6;animation:neo-ping 2s cubic-bezier(0,0,0.2,1) infinite}
@keyframes neo-ping{75%,100%{transform:scale(2);opacity:0}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:44px;padding:0 18px;border:3px solid #000;font-weight:800;font-size:14px;transition:all .15s;line-height:1;text-transform:uppercase;letter-spacing:.04em;box-shadow:var(--shadow);font-family:"Space Grotesk",Inter,sans-serif;color:#000;background:var(--neo-yellow)}
.btn:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px)}
.btn:active{box-shadow:none;transform:translate(4px,4px)}
.btn-primary{background:var(--neo-yellow);color:#000}
.btn-dark{background:#000;color:#fff}
.btn-accent{background:var(--neo-pink);color:#000}
.btn-ghost{background:#fff;color:#000}
.btn-block{display:flex;width:100%}

/* HERO HOME */
.hero{background:transparent;padding:48px 0 16px;text-align:center;position:relative}
.hero-pill{display:inline-flex;align-items:center;gap:6px;background:var(--neo-green);border:3px solid #000;box-shadow:var(--shadow-sm);color:#000;padding:6px 14px;font-size:13px;font-weight:800;margin-bottom:18px;text-transform:uppercase;letter-spacing:.04em}
.hero h1{font-size:54px;line-height:1.05;letter-spacing:-.025em;font-weight:800;max-width:920px;margin:0 auto 18px;font-family:"Space Grotesk",Inter,sans-serif}
.hero h1 .hl{background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);padding:0 8px;display:inline-block;transform:skewY(-2deg)}
.hero h1 b{color:#000}
.hero .sub{font-size:19px;color:#1a1a1a;max-width:680px;margin:0 auto 28px;font-weight:500}
.brand-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.brand-pill{display:inline-flex;align-items:center;gap:10px;background:#fff;border:3px solid #000;padding:8px 14px;font-size:14px;font-weight:700;color:#000;box-shadow:var(--shadow-sm)}
.brand-pill .ava{width:28px;height:28px;background:#fff;border:2px solid #000;color:#000;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;overflow:hidden;padding:2px;position:relative}
.brand-pill .ava img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.brand-pill .ava-fallback{display:none;align-items:center;justify-content:center;width:100%;height:100%;background:var(--neo-yellow);font-weight:800}
.brand-pill:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px)}

/* LAYOUT — minmax(0,1fr) zodat content kan krimpen i.p.v. grid uit te duwen op mobile */
.layout{display:grid;grid-template-columns:240px minmax(0,1fr);gap:24px;padding:24px 0 64px;align-items:start}
.layout>*{min-width:0}
.sidebar{position:sticky;top:88px}
.side-block{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:18px;margin-bottom:18px}
.side-block.yellow{background:var(--neo-yellow)}
.side-block.pink{background:var(--neo-pink)}
.side-block.green{background:var(--neo-green)}
.side-block.blue{background:var(--neo-blue)}
.side-title{font-size:11px;font-weight:800;letter-spacing:.08em;color:#000;text-transform:uppercase;display:flex;align-items:center;gap:6px;margin-bottom:12px;font-family:"Space Grotesk",Inter,sans-serif}
.cat-list{display:flex;flex-direction:column;gap:6px}
.cat-list a{display:block;padding:10px 14px;border:3px solid #000;font-size:14px;font-weight:700;color:#000;background:#fff;text-transform:capitalize}
.cat-list a.active,.cat-list a[aria-current="page"]{background:var(--neo-blue);color:#000;box-shadow:var(--shadow-sm)}
.cat-list a:not(.active):hover{background:var(--neo-yellow)}
.newsletter{background:#000;color:#fff;padding:20px;border:3px solid #000;box-shadow:var(--shadow);border-top:6px solid var(--neo-yellow)}
.newsletter h3{color:var(--neo-yellow);font-size:18px;margin-bottom:6px;font-family:"Space Grotesk",Inter,sans-serif}
.newsletter p{color:#e5e5e5;font-size:13px;margin-bottom:14px;line-height:1.5}
.newsletter input{width:100%;height:40px;padding:0 12px;border:3px solid var(--neo-yellow);font-size:13px;margin-bottom:10px;color:#000;background:#fff;font-weight:500}
.newsletter .btn{width:100%;background:var(--neo-pink);color:#000;border-color:var(--neo-yellow)}

/* SECTION HEADERS */
.main h2.section-h{font-size:26px;font-weight:800;letter-spacing:-.02em;display:flex;align-items:baseline;gap:10px;margin:var(--s-5) 0 var(--s-4);padding-top:8px;font-family:"Space Grotesk",Inter,sans-serif}
.main h2.section-h:first-of-type{margin-top:var(--s-3)}
.main h2.section-h .count{color:#000;font-size:13px;font-weight:800;background:var(--neo-yellow);border:3px solid #000;padding:3px 8px;text-transform:uppercase;letter-spacing:.04em}

/* TABS */
.tabs{display:flex;gap:0;margin-bottom:18px;border-bottom:4px solid #000;padding-bottom:0;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tabs a{padding:10px 16px;font-size:14px;font-weight:800;color:#1a1a1a;border:3px solid transparent;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em;font-family:"Space Grotesk",Inter,sans-serif}
.tabs a.active,.tabs a[aria-current]{background:var(--neo-yellow);border:3px solid #000;border-bottom:0;color:#000;position:relative;top:4px;box-shadow:4px -2px 0 0 #000}
.tabs a .ct{color:#525252;font-weight:600;margin-left:4px;font-size:13px}
.tabs a.active .ct{color:#000}

/* LOGO (gebruikt in store-grid, related-grid, etc.) */
.logo{flex-shrink:0;width:56px;height:56px;border:3px solid #000;background:#fff;display:flex;align-items:center;justify-content:center;padding:4px;overflow:hidden;position:relative}
.logo img{max-width:100%;max-height:100%;object-fit:contain;display:block;width:auto;height:auto}
.logo-fallback{display:none;width:100%;height:100%;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#000;background:var(--neo-yellow);font-family:"Space Grotesk",Inter,sans-serif}
.logo.logo-sm .logo-fallback{font-size:14px}
.logo.logo-xs .logo-fallback{font-size:11px;padding:2px}

/* COUPON CARDS (Store.tsx style) */
.cards{display:flex;flex-direction:column;gap:18px}
.coupon{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:22px;position:relative;transition:all .15s;cursor:pointer;display:flex;flex-direction:column;gap:18px}
.coupon:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px)}
.coupon:focus-visible{outline:3px solid var(--neo-pink);outline-offset:4px}
.coupon.toppick{background:#fffbe6;border-color:#000}
.coupon.expired{opacity:.6;background:#f5f5f5;cursor:default}
.coupon.expired:hover{box-shadow:var(--shadow);transform:none}
.toppick-flag{position:absolute;top:-14px;right:18px;background:var(--neo-red);color:#000;border:3px solid #000;padding:4px 10px;font-size:11px;font-weight:800;box-shadow:var(--shadow-sm);letter-spacing:.06em;font-family:"Space Grotesk",Inter,sans-serif;animation:wobble 2.5s ease-in-out infinite}
@keyframes wobble{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
.coupon-top{display:flex;gap:18px;align-items:flex-start}
.coupon-logo{flex-shrink:0;width:80px;height:80px;display:flex;align-items:center;justify-content:center;border:3px solid #000;background:#fff;position:relative;overflow:hidden;padding:8px}
.coupon-logo-img{max-width:100%;max-height:100%;object-fit:contain;display:block;width:auto;height:auto}
.coupon-logo-img.failed{display:none}
.coupon-logo-img.failed + .coupon-logo-fallback{display:flex}
.coupon-logo-fallback{display:none;width:100%;height:100%;align-items:center;justify-content:center;font-weight:800;font-size:24px;color:#000;background:var(--neo-yellow);font-family:"Space Grotesk",Inter,sans-serif}
.coupon-content{flex:1;min-width:0}
.coupon-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;align-items:center}
.coupon-title{font-size:22px;font-weight:800;margin:0 0 10px;line-height:1.2;letter-spacing:-.01em;color:#000;font-family:"Space Grotesk",Inter,sans-serif}
.coupon-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:#525252;font-weight:500;align-items:center}
.coupon-meta b{color:#000;font-weight:700}
.coupon-meta .success-pill{color:#15803d;font-weight:700}
.coupon-meta .community-attr{color:#0e7490;font-weight:500}
.coupon-meta .verifications-link{color:#525252;text-decoration:underline;text-underline-offset:2px;font-size:12px;font-weight:600}
.coupon-meta .verifications-link:hover{color:#000}
.coupon-restrict{font-size:12px;color:#737373;font-style:italic;margin-top:8px;padding-left:10px;border-left:3px solid #d4d4d4}
.coupon-divider{border-top:3px dashed #d4d4d4;margin:0;height:0}
.coupon-bottom{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.coupon-bottom.expired-bottom{flex-direction:row;justify-content:flex-start;gap:12px;color:#525252}
.expired-code{font-family:ui-monospace,Menlo,monospace;font-weight:700;padding:6px 12px;background:#fff;border:2px solid #525252;color:#525252;text-transform:uppercase;letter-spacing:.08em}
.expired-label{font-size:13px;color:#525252;font-style:italic}

/* === Verify-systeem in neobrutalist stijl === */
.tk-bottom-left{display:flex;flex-wrap:wrap;align-items:center;gap:8px;flex:1;min-width:0}
.verify-pill{display:inline-flex;align-items:center;gap:6px;background:var(--neo-green);color:#000;border:2px solid #000;padding:0 10px;height:32px;box-sizing:border-box;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-display);white-space:nowrap}
.verify-pill b{font-weight:900;font-size:12px}
.verify-pill .verify-count{font-weight:700;color:#000;opacity:.75;margin-left:2px}
.verify-pill.new{background:#fff;color:#000;border:2px solid #000}
.verify-pill.mid{background:#fed7aa;color:#7c2d12}
.verify-pill.mid .verify-count{color:#7c2d12}
.verify-pill.low{background:#fecaca;color:#7f1d1d}
.verify-pill.low .verify-count{color:#7f1d1d}
.edit-check{display:inline-flex;align-items:center;gap:4px;background:#000;color:var(--neo-yellow);border:2px solid #000;padding:3px 8px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-display);white-space:nowrap}
.edit-check.broken{background:#000;color:var(--neo-red)}
.coupon-vote{display:inline-flex;gap:6px;align-items:center;margin-left:auto;flex-shrink:0}
.vote-btn{flex:0 0 32px;width:32px;height:32px;min-width:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:2px solid #000;background:#fff;color:#000;cursor:pointer;font-family:var(--f-display);font-weight:900;font-size:20px;line-height:1;transition:transform .1s,background .12s}
.vote-btn .vote-icon{display:block;line-height:1;transform:translateY(-1px)}
.vote-btn:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 0 #000}
.vote-btn:active{transform:translate(0,0);box-shadow:none}
.vote-btn.vote-up:hover{background:var(--neo-green)}
.vote-btn.vote-down:hover{background:var(--neo-red)}
.vote-btn.voted{transform:none;box-shadow:none}
.vote-btn.vote-up.voted{background:var(--neo-green);color:#000}
.vote-btn.vote-down.voted{background:var(--neo-red);color:#000}
.coupon-action{display:flex;align-items:center;gap:12px}

/* TOON CODE box met peel-effect (acties.nl style) */
.code-box{position:relative;display:inline-block;width:190px;height:46px;overflow:hidden;font-family:"Space Grotesk",Inter,sans-serif;cursor:pointer}
/* Achtergrond-laag: hele code, rechts uitgelijnd — wordt zichtbaar als button krimpt */
.code-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:flex-end;padding:0 14px 0 30px;background:#fff;border:3px dashed #000;font-family:ui-monospace,"SF Mono",Menlo,monospace;font-weight:800;font-size:17px;color:#000;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:clip}
.coupon.toppick .code-bg{background:#fffbe6}
/* Voorgrond-button: bedekt grotendeels code in rust, krimpt op hover */
.reveal-btn{position:absolute;top:0;left:0;bottom:0;width:166px;background:#000;color:var(--neo-yellow);border:3px solid #000;display:flex;align-items:center;justify-content:center;padding:0 14px;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;font-family:"Space Grotesk",Inter,sans-serif;cursor:pointer;transition:width .3s cubic-bezier(0.16, 1, 0.3, 1),background .15s;z-index:2}
.reveal-btn span{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:clip}
/* Tear-edge: driehoek aan rechter rand van button die de "afscheur"-vorm vormt */
.reveal-btn::after{content:"";position:absolute;right:-14px;top:0;bottom:0;width:0;border-left:14px solid #000;border-top:23px solid transparent;border-bottom:23px solid transparent;transition:right .3s cubic-bezier(0.16, 1, 0.3, 1),border-left-color .15s}
/* Hover: button krimpt → achterliggende code meer zichtbaar + button kleur verandert */
.coupon:hover .reveal-btn,.reveal-btn:hover{width:138px;background:var(--neo-red);color:#000;border-color:#000}
.coupon:hover .reveal-btn::after,.reveal-btn:hover::after{border-left-color:var(--neo-red)}

/* DEAL BUTTON: geen peel-effect, gewoon zwarte knop met geel text */
.deal-btn{display:inline-flex;align-items:center;justify-content:center;height:46px;padding:0 24px;background:#000;color:var(--neo-yellow);border:3px solid #000;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;font-family:"Space Grotesk",Inter,sans-serif;cursor:pointer;transition:background .15s;gap:6px}
.deal-btn:hover,.coupon:hover .deal-btn{background:var(--neo-red);color:#000}
.deal-btn .reveal-arrow{font-size:16px}

/* MODAL */
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal[hidden]{display:none}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);cursor:pointer}
.modal-panel{position:relative;background:#fffbf0;border:4px solid #000;box-shadow:8px 8px 0 0 #000;max-width:520px;width:100%;padding:32px;animation:modal-pop .25s cubic-bezier(0.34, 1.56, 0.64, 1)}
@keyframes modal-pop{from{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.modal-close{position:absolute;top:10px;right:10px;width:32px;height:32px;background:#000;color:#fff;border:0;font-size:14px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:var(--neo-red);color:#000}
.modal-head{display:flex;gap:16px;align-items:center;margin-bottom:24px}
.modal-logo-wrap{width:64px;height:64px;border:3px solid #000;background:#fff;display:flex;align-items:center;justify-content:center;padding:8px;flex-shrink:0}
.modal-logo-wrap img{max-width:100%;max-height:100%;object-fit:contain}
.modal-shop{font-size:22px;font-weight:800;margin:0 0 4px;font-family:"Space Grotesk",Inter,sans-serif}
.modal-title{font-size:14px;color:#525252;margin:0;font-weight:500;line-height:1.4}
.modal-reveal-zone{display:flex;align-items:stretch;gap:0;margin:20px 0}
.modal-code-slot{flex:1;background:#000;color:var(--neo-yellow);font-family:ui-monospace,Menlo,monospace;font-weight:800;font-size:24px;letter-spacing:.15em;text-transform:uppercase;padding:14px 18px;border:3px solid #000;text-align:center;overflow:hidden;position:relative}
.modal-code{display:inline-block;transform:translateY(120%);transition:transform .55s cubic-bezier(0.16, 1, 0.3, 1);transition-delay:.2s}
.modal.revealed .modal-code{transform:translateY(0)}
.modal-copy{background:var(--neo-yellow);color:#000;border:3px solid #000;border-left:0;padding:0 18px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:13px;cursor:pointer;font-family:"Space Grotesk",Inter,sans-serif;white-space:nowrap;transition:all .15s}
.modal-copy:hover{background:#000;color:var(--neo-yellow)}
.modal-copy.copied{background:var(--neo-green)}
.modal-hint{font-size:13px;color:#525252;text-align:center;margin:14px 0;font-weight:500;line-height:1.5}
.modal-go{display:block;width:100%;text-align:center;background:var(--neo-pink);color:#000;border:3px solid #000;box-shadow:var(--shadow);padding:14px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-family:"Space Grotesk",Inter,sans-serif;transition:all .15s;text-decoration:none}
.modal-go:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px)}

/* DEAL-only modal variant (geen code-slot) */
.modal.deal-mode .modal-reveal-zone{display:none}
.modal.deal-mode .modal-hint{margin-top:8px}

/* EDITOR PAGES — legacy components (in gebruik bij andere views) */
.editor-profile{display:flex;gap:24px;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow);padding:28px;margin-bottom:24px;align-items:center}
.editor-avatar{width:120px;height:120px;background:#000;color:var(--neo-yellow);border:3px solid #000;display:flex;align-items:center;justify-content:center;font-size:64px;font-weight:800;flex-shrink:0;font-family:"Space Grotesk",Inter,sans-serif}
.editor-info h1{font-size:32px;margin:0 0 4px;font-weight:800;letter-spacing:-.02em}
.editor-role{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#000;background:#fff;border:2px solid #000;display:inline-block;padding:3px 10px;margin:0 0 12px}
.editor-bio{font-size:15px;color:#000;margin:0 0 12px;line-height:1.55;font-weight:500}
.editor-stats{font-size:13px;color:#000;font-weight:600}
.editor-stats b{font-size:18px;font-weight:800}
.editor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:24px 0}
.editor-card{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:24px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;transition:all .15s;text-decoration:none;color:#000}
.editor-card:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px);background:var(--neo-yellow)}
.editor-card .editor-avatar{width:64px;height:64px;font-size:32px;margin-bottom:8px}
.editor-card h3{font-size:20px;margin:0;font-family:"Space Grotesk",Inter,sans-serif}
.editor-week{margin-top:32px}
.editor-week h2{margin-bottom:14px}

/* EDITOR PROFILE HERO — uitgebreid */
.editor-profile-hero{display:grid;grid-template-columns:160px 1fr;gap:28px;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow);padding:32px;margin:20px 0 28px;align-items:start}
.editor-avatar-big{width:160px;height:160px;background:#000;color:var(--neo-yellow);border:3px solid #000;display:flex;align-items:center;justify-content:center;font-size:80px;font-weight:800;flex-shrink:0;font-family:"Space Grotesk",Inter,sans-serif}
.editor-profile-hero .editor-info h1{font-size:42px;letter-spacing:-.025em;line-height:1.05;margin:8px 0 6px}
.editor-role-pill{display:inline-block;background:#000;color:var(--neo-yellow);padding:4px 12px;font-size:12px;font-weight:800;letter-spacing:.06em;font-family:"Space Grotesk",Inter,sans-serif;text-transform:uppercase}
.editor-meta-line{font-size:14px;color:#000;margin:0 0 14px;font-weight:500}
.editor-meta-line b{font-weight:800}
.editor-profile-hero .editor-bio{font-size:15px;margin-bottom:14px;line-height:1.6}
.editor-quote{background:#fff;border-left:6px solid #000;margin:14px 0;padding:12px 16px;font-style:italic;font-size:15px;color:#1a1a1a;font-weight:500;line-height:1.55}
.editor-expertise{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.exp-pill{display:inline-block;background:#fff;border:2px solid #000;padding:3px 10px;font-size:12px;font-weight:700;color:#000}

/* EDITOR COUNTERS — 4-grid live stats */
.editor-counters{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0}
.ec-card{padding:22px 18px;border:3px solid #000;box-shadow:var(--shadow);text-align:left;font-family:"Space Grotesk",Inter,sans-serif}
.ec-card b{display:block;font-size:42px;font-weight:800;line-height:1;letter-spacing:-.03em;color:#000}
.ec-card span{display:block;font-size:12px;margin-top:8px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;line-height:1.25;color:#000}
.ec-blue{background:var(--neo-blue)}
.ec-green{background:var(--neo-green)}
.ec-yellow{background:var(--neo-yellow)}
.ec-pink{background:var(--neo-pink)}

/* EDITOR TODAY LOG — live feed van wat een redacteur vandaag deed */
.editor-today-log,.live-feed,.editor-signature,.editor-method,.editor-others,.editor-contact{margin:28px 0;background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:24px}
.editor-today-log h2,.live-feed h2,.editor-signature h2,.editor-method h2,.editor-others h2{margin:0 0 8px;font-size:22px}
.ed-intro{font-size:14px;color:#525252;margin:0 0 18px;line-height:1.55;font-weight:500}
.today-log-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.tll-item{display:grid;grid-template-columns:130px 1fr;gap:14px;padding:10px 12px;border:2px solid rgba(0,0,0,.12);font-size:14px;background:#fffbf0;align-items:center}
.tll-item time{font-size:11px;color:#525252;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-family:"Space Grotesk",Inter,sans-serif}
.tll-item .tll-action{color:#000;font-weight:500;line-height:1.4}
.tll-item .tll-action a{color:#000;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.tll-item .tll-editor{background:var(--neo-yellow);padding:1px 6px;border:2px solid #000;font-weight:700}
.tll-verify{border-left:6px solid var(--neo-green)}
.tll-test{border-left:6px solid var(--neo-blue)}
.tll-add{border-left:6px solid var(--neo-yellow)}
.tll-rotate{border-left:6px solid var(--neo-pink)}
.tll-fix{border-left:6px solid var(--neo-red)}
.tll-sale,.tll-update,.tll-check,.tll-compare,.tll-audit{border-left:6px solid #525252}

/* SIGNATURE STORES GRID — favoriete winkels per editor */
.sig-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.sig-card{display:flex;align-items:center;gap:12px;background:#fffbf0;border:2px solid #000;padding:12px;transition:all .15s;text-decoration:none;color:#000}
.sig-card:hover{background:var(--neo-yellow);transform:translate(2px,2px)}
.sig-card .logo{width:48px;height:48px;font-size:18px;flex-shrink:0;box-shadow:none}
.sig-card b{display:block;font-size:14px;font-family:"Space Grotesk",Inter,sans-serif}
.sig-card span{display:block;font-size:12px;color:#525252;font-weight:600;margin-top:2px}

/* METHOD GRID — hoe werkt deze editor */
.method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.method-step{background:#fffbf0;border:2px solid #000;padding:18px;position:relative}
.method-step h3{font-size:16px;margin:8px 0 6px;font-family:"Space Grotesk",Inter,sans-serif}
.method-step p{font-size:13px;color:#1a1a1a;margin:0;line-height:1.55;font-weight:500}
.ms-num{width:32px;height:32px;background:#000;color:var(--neo-yellow);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;font-family:"Space Grotesk",Inter,sans-serif}

/* OTHER EDITORS — kleine cross-link cards onderaan editor-page */
.other-editors{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.oe-card{display:flex;align-items:center;gap:10px;background:#fffbf0;border:2px solid #000;padding:10px 12px;text-decoration:none;color:#000;transition:all .15s}
.oe-card:hover{background:var(--neo-yellow)}
.oe-avatar{width:42px;height:42px;background:#000;color:var(--neo-yellow);border:2px solid #000;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex-shrink:0;font-family:"Space Grotesk",Inter,sans-serif}
.oe-card b{display:block;font-size:14px;font-family:"Space Grotesk",Inter,sans-serif}
.oe-card span{display:block;font-size:12px;color:#525252;font-weight:600}

/* REDACTIE HERO — index pagina */
.redactie-hero,.about-hero{display:grid;grid-template-columns:1fr 360px;gap:32px;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow);padding:32px;margin:20px 0 28px;align-items:start}
.rh-pill,.ah-pill{display:inline-block;background:#000;color:var(--neo-yellow);padding:4px 12px;font-size:11px;font-weight:800;letter-spacing:.08em;font-family:"Space Grotesk",Inter,sans-serif;margin-bottom:12px}
.rh-text h1,.ah-text h1{font-size:36px;letter-spacing:-.025em;line-height:1.05;margin:0 0 14px}
.rh-text p,.ah-text p,.ah-lead{font-size:15px;color:#000;font-weight:500;line-height:1.6;margin:0}
.rh-counters,.ah-counters{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rh-c{padding:18px 16px;border:3px solid #000;text-align:left;font-family:"Space Grotesk",Inter,sans-serif;box-shadow:var(--shadow-sm)}
.rh-c b{display:block;font-size:28px;font-weight:800;line-height:1;letter-spacing:-.02em}
.rh-c span{display:block;font-size:11px;margin-top:6px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;line-height:1.2}
.rh-c-blue{background:var(--neo-blue)}
.rh-c-green{background:var(--neo-green)}
.rh-c-yellow{background:#fff}
.rh-c-pink{background:var(--neo-pink)}

/* TEAM GRID — bigger team-cards op /redactie/ + over-ons */
.team-grid-section{margin:32px 0}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:24px 0}
.team-card{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column;gap:12px;text-decoration:none;color:#000;transition:all .15s}
.team-card:hover{transform:translate(2px,2px);box-shadow:var(--shadow-sm);background:var(--neo-yellow)}
.tc-top{display:flex;gap:14px;align-items:center}
.tc-avatar{width:56px;height:56px;background:#000;color:var(--neo-yellow);border:3px solid #000;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:26px;flex-shrink:0;font-family:"Space Grotesk",Inter,sans-serif}
.tc-top h3{font-size:20px;margin:0;font-family:"Space Grotesk",Inter,sans-serif}
.tc-role{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#525252}
.tc-bio{font-size:13px;line-height:1.55;color:#1a1a1a;margin:0;font-weight:500}
.tc-stats{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:#525252;font-weight:600;border-top:2px dashed rgba(0,0,0,.15);padding-top:10px}
.tc-stats b{color:#000;font-weight:800}
.tc-expertise{display:flex;flex-wrap:wrap;gap:4px}

/* PIPELINE DETAILED — Hoe werkt het 3-stappen layout */
.pipeline-detailed{display:flex;flex-direction:column;gap:18px;margin:24px 0 32px}
.pld-card{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:24px 28px;position:relative}
.pld-num{position:absolute;top:-16px;left:24px;background:#000;color:var(--neo-yellow);width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;border:3px solid #000;font-family:"Space Grotesk",Inter,sans-serif}
.pld-card h2{margin:8px 0 12px;font-size:22px}
.pld-card ul{padding-left:20px;list-style:disc;margin:0 0 12px;line-height:1.65}
.pld-card ul li{font-size:14px;color:#1a1a1a;font-weight:500;margin-bottom:6px}
.pld-foot{font-size:13px;color:#525252;font-style:italic;font-weight:500;margin-top:14px;padding-top:12px;border-top:2px dashed rgba(0,0,0,.15)}

/* PIPELINE compact (in over-ons) */
.pipeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin:18px 0}
.pl-step{background:#fffbf0;border:2px solid #000;padding:16px}
.pl-step b{display:block;font-size:15px;margin-bottom:6px;font-family:"Space Grotesk",Inter,sans-serif}
.pl-step p{font-size:13px;color:#1a1a1a;line-height:1.55;margin:0;font-weight:500}

/* LEGAL TABLE — KvK en company-info layout */
.legal-table{width:100%;border-collapse:collapse;margin:14px 0 24px;font-size:14px}
.legal-table th{text-align:left;padding:10px 14px;background:var(--neo-yellow);border:2px solid #000;font-weight:700;width:35%;font-family:"Space Grotesk",Inter,sans-serif}
.legal-table td{padding:10px 14px;border:2px solid #000;background:#fff;font-weight:500}

/* COUPON-ACTION on mobile */
@media (max-width:640px){
  .coupon-bottom{flex-direction:column;align-items:stretch}
  .coupon-vote{justify-content:center}
  .coupon-action{justify-content:space-between;width:100%}
  .reveal-btn{flex:1;justify-content:center}
}
.logo{width:90px;height:90px;background:var(--neo-yellow);border:3px solid #000;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:32px;color:#000;overflow:hidden;text-align:center;font-family:"Space Grotesk",Inter,sans-serif}
.logo.has-bg{color:#fff}
.logo.logo-sm{font-size:22px}
.logo.logo-xs{font-size:14px;letter-spacing:.02em;padding:4px}
.logo .name{display:block;width:100%;font-size:9px;line-height:1;margin-top:4px;font-weight:600;letter-spacing:.02em}
.card-body{min-width:0}
.card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;padding:3px 8px;border:2px solid #000;letter-spacing:.04em;text-transform:uppercase;font-family:"Space Grotesk",Inter,sans-serif}
.badge-code{background:var(--neo-green);color:#000}
.badge-deal{background:var(--neo-blue);color:#000}
.badge-verified{background:#fff;color:#000}
.badge-fresh{background:var(--neo-yellow);color:#000;letter-spacing:0}
.badge-success{background:var(--neo-pink);color:#000;letter-spacing:0}
.badge-toppick{background:var(--neo-red);color:#000;letter-spacing:.04em}
.badge-discount{background:var(--neo-red);color:#000;letter-spacing:.06em}
.badge-expired{background:#d4d4d4;color:#525252}
.card h3{font-size:17px;font-weight:700;margin:0 0 6px;line-height:1.3}
.card .desc{font-size:13px;color:#525252;margin:0 0 10px;line-height:1.45}
.card-foot{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:#525252}
.card-foot span{display:inline-flex;align-items:center;gap:4px;font-weight:500}
.card-foot b{color:#000;font-weight:700}
.card-action{display:flex;flex-direction:column;align-items:flex-end;gap:10px;min-width:140px}
.discount-tag{font-size:24px;font-weight:800;color:#000;line-height:1;letter-spacing:-.02em;background:var(--neo-red);border:3px solid #000;padding:4px 10px;box-shadow:var(--shadow-sm);font-family:"Space Grotesk",Inter,sans-serif}
.discount-tag.small{font-size:14px;padding:2px 6px}
.card-action .btn{min-width:140px}

/* CODE REVEAL */
.code-reveal{position:relative;display:flex;align-items:stretch;gap:0;min-width:140px}
.code-reveal button{flex:1;background:var(--neo-yellow);color:#000;height:44px;font-weight:800;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;border:3px solid #000;text-transform:uppercase;letter-spacing:.04em;box-shadow:var(--shadow-sm);font-family:"Space Grotesk",Inter,sans-serif}
.code-reveal button:hover{box-shadow:1px 1px 0 0 #000;transform:translate(1px,1px)}
.code-reveal[data-revealed="1"] button{background:#000;color:#fff}
.code-reveal .codeval{display:none;background:#f5f5f5;color:#000;font-family:ui-monospace,"SF Mono",Menlo,monospace;font-weight:800;padding:0 14px;height:44px;align-items:center;border:3px solid #000;border-right:0;font-size:15px;letter-spacing:.1em;text-transform:uppercase}
.code-reveal[data-revealed="1"] .codeval{display:inline-flex}
.code-reveal[data-revealed="1"] button{padding:0 14px}

/* KPI DASHBOARD */
.dashboard{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}
.kpi{text-align:center;background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:36px 24px;font-family:"Space Grotesk",Inter,sans-serif;transition:transform .15s,box-shadow .15s}
.kpi:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 #000}
.kpi.k1{background:var(--neo-blue)}
.kpi.k2{background:var(--neo-green)}
.kpi.k3{background:var(--neo-yellow)}
.kpi.k4{background:var(--neo-pink)}
.kpi b{display:block;font-size:48px;font-weight:800;color:#000;line-height:1;letter-spacing:-.03em}
.kpi span{display:block;font-size:13px;color:#000;margin-top:14px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;line-height:1.2}

/* BREADCRUMB */
.breadcrumb{font-size:13px;color:#525252;padding:14px 0 6px;display:flex;flex-wrap:wrap;gap:6px;font-weight:500}
.breadcrumb a{color:#525252}
.breadcrumb a:hover{color:#000;text-decoration:underline}
.breadcrumb span[aria-current]{color:#000;font-weight:700}
.breadcrumb i{color:#a3a3a3;font-style:normal}

/* STORE HERO — subtiel, geen omkadering */
.store-hero{background:transparent;border:0;box-shadow:none;padding:8px 0 18px;margin-bottom:10px;display:grid;grid-template-columns:96px 1fr;gap:18px;align-items:center;position:relative;border-bottom:3px solid #000}
.store-hero .logo{width:96px;height:96px;font-size:34px;background:#fff;box-shadow:var(--shadow-sm);border:3px solid #000}
.store-hero h1{font-size:28px;font-weight:800;letter-spacing:-.018em;line-height:1.15;margin-bottom:6px;color:#000}
.store-hero .store-hero-bio{color:#1a1a1a;font-size:14px;line-height:1.5;margin:0 0 10px;font-weight:500;max-width:760px}
.store-hero p.lede{color:#000;font-size:15px;margin-bottom:12px;font-weight:500}
/* COMPACT VARIANT — als ergens nog gebruikt, fall in line met nieuwe baseline */
.store-hero.compact{padding:8px 0 16px;margin-bottom:10px;grid-template-columns:96px 1fr;gap:18px}
.store-hero.compact .logo{width:96px;height:96px;font-size:34px}
.store-hero.compact h1{font-size:24px;line-height:1.18;margin-bottom:6px;letter-spacing:-.015em}
.store-hero.compact .store-hero-body{min-width:0}
.store-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;color:#000;align-items:center;margin-top:4px}
.store-meta>span,.store-meta .badge{background:#fff;border:2px solid #000;padding:3px 9px;font-weight:700;font-size:12px}
.store-meta b{color:#000;font-weight:800}
.store-hero.compact .store-meta{gap:6px;font-size:12px}
.store-hero.compact .store-meta>span{padding:3px 8px}
.rating{display:inline-flex;align-items:center;gap:6px}
.rating .stars{color:#000;letter-spacing:.05em;font-weight:800}

/* DISCLOSURE (groot, deprecated voor store-page maar in gebruik op homepage/category) */
.disclosure{background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);padding:10px 14px;font-size:13px;color:#000;display:flex;align-items:flex-start;gap:8px;margin-bottom:18px;font-weight:600}

/* DISCLOSURE MINI — 1-regel, lichter, voor store-page boven hero */
.disclosure-mini{font-size:12px;color:#525252;padding:6px 0 10px;line-height:1.5;display:flex;align-items:center;gap:6px;font-weight:500}
.disclosure-mini b{color:#000;font-weight:700}
.disclosure-mini a{color:#000;font-weight:700;text-decoration:underline;text-underline-offset:2px}

/* BYLINE */
.byline{font-size:13px;color:#525252;padding:8px 0 14px;font-weight:500}
.byline a{color:#000;font-weight:700;text-decoration:underline;text-underline-offset:2px}

/* STATS STRIP — vervangt de 4 grote KPI-blokken op de store-page voor codes-boven-fold.
   .kpi class is voor SEO-validatie (I22) — overrides die styling hier expliciet. */
.stats-strip{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px;font-size:13px;font-weight:600}
.stats-strip .ss-item,.stats-strip .kpi{display:inline-flex;align-items:center;gap:6px;background:#fff;border:3px solid #000;padding:6px 12px;box-shadow:var(--shadow-sm);font-family:"Space Grotesk",Inter,sans-serif;text-align:left;font-size:13px;line-height:1.3}
.stats-strip .kpi b{display:inline;font-size:14px;font-weight:800;color:#000;letter-spacing:0;line-height:1.3}
.stats-strip .kpi span{display:inline;font-size:13px;margin:0;text-transform:none;letter-spacing:0;font-weight:600}
.stats-strip .ss-green,.stats-strip .kpi.ss-green{background:var(--neo-green)}
.stats-strip .ss-yellow,.stats-strip .kpi.ss-yellow{background:var(--neo-yellow)}
.stats-strip .ss-pink,.stats-strip .kpi.ss-pink{background:var(--neo-pink)}
.stats-strip .kpi:hover{transform:none;box-shadow:var(--shadow-sm)}

/* TOP-PICK HERO — eerste code direct boven de fold met dikke flag */
.top-pick-hero{margin:0 0 22px;position:relative}
.top-pick-hero .tph-flag{display:inline-block;background:var(--neo-red);color:#000;border:3px solid #000;padding:5px 14px;font-size:12px;font-weight:800;letter-spacing:.06em;font-family:"Space Grotesk",Inter,sans-serif;box-shadow:var(--shadow-sm);margin-bottom:-3px;position:relative;z-index:2;text-transform:uppercase}
.top-pick-hero .coupon{box-shadow:6px 6px 0 0 #000}
.top-pick-hero .coupon:hover{box-shadow:3px 3px 0 0 #000}

/* INTELLIGENCE BRIEFING — onderaan, secondary plek */
.intel-briefing{background:#0a0a0a;color:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:18px 22px 20px;margin:24px 0;position:relative}
.intel-briefing .intel-tag{display:inline-block;background:var(--neo-green);color:#000;border:2px solid #000;padding:3px 10px;font-size:10px;font-weight:800;letter-spacing:.08em;font-family:"Space Grotesk",Inter,sans-serif;margin-bottom:10px}
.intel-briefing h2{color:#fff;font-size:18px;margin:0 0 8px;line-height:1.25}
.intel-briefing p{color:#d4d4d4;font-size:14px;line-height:1.6;margin:0;font-weight:500}

/* CATEGORIEËN ONDERAAN — chip-grid horizontaal, vervangt sidebar-blok */
.categories-bottom{margin:32px 0 24px;background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:22px 24px}
.categories-bottom h2{margin:0 0 14px;font-size:20px}
.cat-grid{display:flex;flex-wrap:wrap;gap:8px}
.cat-grid a{display:inline-flex;align-items:center;padding:8px 14px;background:#fff;border:2px solid #000;font-size:13px;font-weight:700;color:#000;font-family:"Space Grotesk",Inter,sans-serif;transition:all .15s}
.cat-grid a:hover{background:var(--neo-yellow);transform:translate(1px,1px)}
.cat-grid a.active{background:var(--neo-blue);box-shadow:var(--shadow-sm)}

/* GOED OM TE WETEN — Acties.nl-stijl praktische bullets */
.goedomteweten{background:var(--neo-blue);border:3px solid #000;box-shadow:var(--shadow);padding:22px 24px;margin:24px 0}
.goedomteweten h2{font-size:22px;margin-bottom:14px}
.got-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px 24px;padding:0;list-style:none;margin:0}
.got-list li{font-size:14px;color:#000;line-height:1.55;padding:6px 0;border-bottom:2px solid rgba(0,0,0,.15);font-weight:500}
.got-list li:last-child{border-bottom:0}
.got-list b{font-weight:800}

/* HOWTO BLOCK — genummerde stappen */
.howto-block{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:22px 24px;margin:24px 0}
.howto-block h2{font-size:22px;margin-bottom:16px}
.howto-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.howto-steps li{display:flex;gap:14px;align-items:flex-start}
.howto-num{flex-shrink:0;width:36px;height:36px;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;font-family:"Space Grotesk",Inter,sans-serif}
.howto-steps li>div{flex:1;padding-top:4px}
.howto-steps li b{display:block;font-size:15px;color:#000;font-family:"Space Grotesk",Inter,sans-serif;margin-bottom:2px}
.howto-steps li p{font-size:13px;color:#1a1a1a;margin:0;line-height:1.55;font-weight:500}

/* LEGAL BLOCK (footer) — KvK/BTW/adres voor trust + wettelijke vereiste art. 6:230m BW */
.site-footer .legal-block{background:#1a1a1a;border:2px solid #404040;padding:14px 18px;margin-bottom:14px;font-size:13px;line-height:1.7;color:#d4d4d4;font-weight:500}
.site-footer .legal-block b{color:#fff;font-weight:700}
.site-footer .bottom-mini{font-size:12px;color:#a3a3a3;line-height:1.55}

/* ACTIVITY */
.activity{background:var(--neo-pink);border:3px solid #000;box-shadow:var(--shadow);padding:18px;margin-bottom:18px}
.activity .side-title{margin-bottom:10px}
.activity ul{display:flex;flex-direction:column;gap:10px}
.activity li{font-size:13px;color:#000;display:flex;align-items:baseline;gap:8px;line-height:1.45;border-bottom:2px solid rgba(0,0,0,.2);padding-bottom:8px;font-weight:600}
.activity li:last-child{border-bottom:0;padding-bottom:0}
.activity li .dot{width:10px;height:10px;background:#000;flex-shrink:0;margin-right:2px;position:relative;top:1px}
.activity li time{color:#525252;font-size:11px;margin-left:auto;font-weight:700;text-transform:uppercase}

/* FAQ */
details.faq{border:3px solid #000;background:#fff;padding:0;margin-bottom:10px;box-shadow:var(--shadow-sm)}
details.faq summary{padding:14px 18px;font-weight:700;font-size:15px;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;font-family:"Space Grotesk",Inter,sans-serif}
details.faq summary::after{content:"+";color:#000;font-size:22px;line-height:1;font-weight:800}
details.faq[open] summary::after{content:"−"}
details.faq summary::-webkit-details-marker{display:none}
details.faq[open] summary{border-bottom:3px solid #000;background:var(--neo-yellow)}
details.faq .answer{padding:14px 18px;font-size:14px;color:#000;line-height:1.65;font-weight:500}

/* EDITORIAL */
.editorial{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:28px;margin:24px 0;font-size:15px;line-height:1.7;color:#1a1a1a}
.editorial h2,.editorial h3{margin-top:1.4em}
.editorial h2{font-size:24px}
.editorial h3{font-size:18px;color:#000}
.editorial ul{padding-left:24px;list-style:disc;margin:0 0 1em}
.editorial ul li{margin-bottom:.4em}
.editorial p{margin-bottom:1em}

/* HACKS */
.hacks{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:16px}
.hack{background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);padding:16px}
.hack:nth-child(2n){background:var(--neo-green)}
.hack:nth-child(3n){background:var(--neo-pink)}
.hack:nth-child(4n){background:var(--neo-blue)}
.hack h4{font-size:15px;margin-bottom:8px;color:#000;display:flex;align-items:center;gap:6px;font-family:"Space Grotesk",Inter,sans-serif}
.hack p{font-size:13px;color:#000;margin:0;line-height:1.55;font-weight:500}

/* EXPIRED */
.expired-section{margin-top:32px}
.expired-section h2{color:#525252;font-size:20px;margin-bottom:14px;font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.expired-section .card{background:#f5f5f5}
.expired-section .card .codeval{display:inline-flex;background:#fff;color:#525252;padding:6px 12px;border:2px solid #000;font-family:ui-monospace,Menlo,monospace;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}

/* RELATED */
.related{margin-top:32px}
.related h2{font-size:22px;margin-bottom:14px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.related-grid a{background:#fff;border:3px solid #000;box-shadow:var(--shadow-sm);padding:14px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:700;color:#000}
.related-grid a:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px)}
.related-grid .logo{width:40px;height:40px;font-size:14px;box-shadow:none}

/* SORT BAR */
.sort-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.sort-bar label{font-size:13px;color:#000;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.sort-bar .pills{display:flex;gap:8px;flex-wrap:wrap}
.sort-bar .pill{padding:6px 12px;background:#fff;border:3px solid #000;font-size:13px;font-weight:700;color:#000;cursor:pointer;box-shadow:var(--shadow-sm)}
.sort-bar .pill.active,.sort-bar .pill[aria-pressed="true"]{background:#000;color:#fff}
.verifications{font-size:12px;color:#525252;margin-top:6px;display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-weight:600}
.verifications:hover{color:#000;text-decoration:underline}

/* FOOTER */
.site-footer{background:#000;color:#fff;padding:56px 0 24px;margin-top:64px;font-size:14px;border-top:8px solid var(--neo-blue)}
.site-footer .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-bottom:32px}
.site-footer h4{color:var(--neo-yellow);font-size:18px;margin-bottom:14px;font-family:"Space Grotesk",Inter,sans-serif;letter-spacing:-.01em}
.site-footer .col-2 h4{color:var(--neo-pink)}
.site-footer .col-3 h4{color:var(--neo-green)}
.site-footer .col-4 h4{color:var(--neo-blue)}
.site-footer a{color:#d4d4d4;display:block;padding:4px 0;font-size:14px;font-weight:500}
.site-footer a:hover{color:#fff;text-decoration:underline}
.site-footer .bottom{border-top:1px solid #404040;padding-top:20px;font-size:12px;color:#a3a3a3;text-align:left}

/* CATEGORIE */
.cat-hero{padding:40px 0 24px}
.cat-hero h1{font-size:42px;letter-spacing:-.02em;margin-bottom:8px;background:var(--neo-yellow);border:3px solid #000;display:inline-block;padding:6px 14px;box-shadow:var(--shadow)}
.cat-hero p{font-size:16px;color:#000;max-width:640px;font-weight:500;margin-top:14px}
.store-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.store-card{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:18px;display:flex;align-items:center;gap:14px;transition:all .15s}
.store-card:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px);background:var(--neo-yellow)}
.store-card .logo{width:56px;height:56px;font-size:22px;box-shadow:none}
.store-card .info b{display:block;font-size:16px;color:#000;margin-bottom:2px;font-weight:700;font-family:"Space Grotesk",Inter,sans-serif}
.store-card .info span{font-size:12px;color:#525252;font-weight:600}

/* REDACTIE WEEK */
.redactie-week{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:24px;margin:24px 0;position:relative}
.redactie-week::before{content:"REDACTIE";position:absolute;top:-13px;left:18px;background:#000;color:var(--neo-yellow);border:3px solid #000;padding:3px 12px;font-size:11px;font-weight:800;letter-spacing:.08em;font-family:"Space Grotesk",Inter,sans-serif}
.redactie-week h2{font-size:22px;margin-bottom:10px}
.redactie-intro{font-size:14px;color:#525252;margin-bottom:20px;line-height:1.55;font-weight:500}
.redactie-days{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0;border-top:2px solid #000}
.redactie-day{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:14px 0;border-bottom:2px solid #e5e5e5}
.redactie-day:last-child{border-bottom:0}
.redactie-day.today{background:var(--neo-yellow);margin:0 -14px;padding:14px;border-radius:0;border:3px solid #000;border-top:0;box-shadow:var(--shadow-sm)}
.redactie-day.today + .redactie-day{margin-top:6px}
.redactie-date{font-family:"Space Grotesk",Inter,sans-serif}
.redactie-date b{display:block;font-size:15px;color:#000;text-transform:capitalize;font-weight:800}
.redactie-date span{display:block;font-size:12px;color:#525252;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.redactie-events{list-style:none;padding:0;margin:0}
.redactie-events li{font-size:14px;color:#000;line-height:1.55;padding:3px 0;font-weight:500}
.redactie-events li a{color:#000;text-decoration:underline;text-underline-offset:2px;font-weight:700}
.redactie-events li a:hover{background:var(--neo-yellow)}

/* AZ-INDEX (op aparte /winkels-az/ pagina) */
.az-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-top:14px}
.az-grid a{display:flex;align-items:center;justify-content:space-between;gap:8px;border:3px solid #000;background:#fff;padding:10px 12px;font-size:13px;font-weight:700;color:#000}
.az-grid a:hover{background:var(--neo-yellow)}
.az-grid .az-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;padding:1px 6px;background:var(--neo-yellow);border:2px solid #000;font-size:11px;font-weight:800;color:#000;font-family:"Space Grotesk",Inter,sans-serif}
.az-letters{display:flex;flex-wrap:wrap;gap:4px;margin:20px 0;padding:14px;background:#fff;border:3px solid #000;box-shadow:var(--shadow);position:sticky;top:72px;z-index:20}
.az-letters a{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:2px solid #000;background:#fff;color:#000;font-weight:800;font-family:"Space Grotesk",Inter,sans-serif;font-size:14px}
.az-letters a:hover{background:var(--neo-yellow)}
.az-letter-group{margin:32px 0}
.az-letter-h{font-size:28px;background:#000;color:var(--neo-yellow);display:inline-block;padding:6px 18px;margin-bottom:14px;font-family:"Space Grotesk",Inter,sans-serif}

/* CATEGORIE OVERVIEW op homepage (vervangt AZ-grid) */
.category-overview{margin:32px 0;background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:28px}
.category-overview h2{font-size:24px;margin:0 0 6px;font-family:"Space Grotesk",Inter,sans-serif}
.cat-overview-lede{font-size:14px;color:#525252;margin:0 0 22px;line-height:1.55;font-weight:500;max-width:720px}
.cat-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.cat-overview-card{display:flex;flex-direction:column;gap:8px;padding:20px 18px;background:#fffbf0;border:3px solid #000;box-shadow:var(--shadow-sm);text-decoration:none;color:#000;transition:all .15s;position:relative}
.cat-overview-card:hover{box-shadow:var(--shadow);transform:translate(-2px,-2px);background:var(--neo-yellow)}
.cat-overview-card:nth-child(2n){background:#eef9ff}
.cat-overview-card:nth-child(3n){background:#fef3e7}
.cat-overview-card:nth-child(4n){background:#fce7f3}
.cat-overview-card:hover{background:var(--neo-yellow)}
.cat-overview-card h3{font-size:18px;margin:0;font-family:"Space Grotesk",Inter,sans-serif;letter-spacing:-.01em}
.cat-overview-card p{font-size:13px;color:#1a1a1a;margin:0;line-height:1.5;font-weight:500;flex:1}
.cat-overview-count{font-size:14px;font-weight:800;color:#000;font-family:"Space Grotesk",Inter,sans-serif;display:inline-flex;align-items:center;gap:4px}
.cat-overview-count b{font-size:18px}

/* RESPONSIVE */
@media (max-width:920px){
  .layout{grid-template-columns:1fr;gap:18px}
  /* Sidebar uitgeklapt onder de codes ipv 2-kolommen-grid die overflow gaf */
  .sidebar{position:static;display:flex;flex-direction:column;gap:14px;min-width:0}
  .sidebar>*{min-width:0;max-width:100%}
  .side-block{margin-bottom:0}
  .hero{padding:32px 0 16px}
  .hero h1{font-size:36px}
  .hero .sub{font-size:16px}
  .search{order:3;flex-basis:100%;max-width:none}
  .site-header .wrap{padding:12px 16px;flex-wrap:wrap;min-height:0}
  .dashboard{grid-template-columns:repeat(2,1fr);gap:12px}
  .kpi b{font-size:22px}
  .store-hero{grid-template-columns:80px 1fr;padding:18px;gap:14px}
  .store-hero .logo{width:80px;height:80px;font-size:32px}
  .store-hero h1{font-size:24px}
  .card{grid-template-columns:60px 1fr;padding:14px;gap:12px}
  .card-action{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center;border-top:3px dashed #000;padding-top:12px;min-width:0;margin-top:6px}
  .logo{width:60px;height:60px;font-size:22px}
  .site-footer .grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .nav-popular{display:none}
  /* Code-box (TOON CODE) responsive: geen vaste 190px die overflow forceert */
  .code-box{width:100%;max-width:220px;min-width:140px}
  .reveal-btn{width:75%}
  .coupon{padding:16px}
  .coupon-title{font-size:18px}
  /* Stats-strip op mobile: wrap goed */
  .stats-strip{gap:6px}
  .stats-strip .ss-item,.stats-strip .kpi{padding:5px 10px;font-size:12px}
  /* Activity-li in sidebar: text mag wrappen, time op eigen regel */
  .activity li{display:block;padding-bottom:10px;border-bottom:2px solid rgba(0,0,0,.2)}
  .activity li:last-child{border-bottom:0}
  .activity li .dot{display:inline-block;margin-right:6px;vertical-align:middle}
  .activity li time{display:block;margin-top:4px;font-size:10px}
  /* Cat-list items in sidebar mogen text breken indien nodig */
  .cat-list a{white-space:normal;word-break:break-word}
  /* Tabs scrolling op kleinste viewports */
  .tabs{font-size:13px}
  .tabs a{padding:8px 12px}
  /* Site-hero op mobile compacter */
  .editor-profile-hero,.redactie-hero,.about-hero{grid-template-columns:1fr;padding:18px;gap:14px}
  .editor-avatar-big{width:80px;height:80px;font-size:40px}
  .editor-profile-hero .editor-info h1,.rh-text h1,.ah-text h1{font-size:24px}
  .editor-counters,.rh-counters,.ah-counters{grid-template-columns:repeat(2,1fr);gap:8px}
  .ec-card{padding:14px 12px}
  .ec-card b{font-size:26px}
  .rh-c{padding:14px 12px}
  .rh-c b{font-size:22px}
  /* Daily log items wrap */
  .tll-item{grid-template-columns:1fr;gap:4px;padding:8px 10px}
  .tll-item time{font-size:10px}
  /* Pipeline-detailed niet te krap */
  .pld-card{padding:18px 16px}
  .pld-card h2{font-size:18px}
  /* Method-grid 1 kol */
  .method-grid{grid-template-columns:1fr}
  /* Howto block compacter */
  .howto-block,.goedomteweten,.intel-briefing{padding:16px}
  .howto-steps li{gap:10px}
  /* Legal table responsive */
  .legal-table th{width:40%;font-size:12px;padding:8px 10px}
  .legal-table td{font-size:13px;padding:8px 10px}
  /* Pipeline compact */
  .pipeline{grid-template-columns:1fr}
  /* Categorie-overview op homepage compacter */
  .category-overview{padding:18px}
  .cat-overview-grid{grid-template-columns:1fr}
  /* AZ-letters sticky disable op mobile */
  .az-letters{position:static;padding:10px;gap:3px}
  .az-letters a{width:28px;height:28px;font-size:13px}
  .az-letter-h{font-size:22px;padding:5px 12px}
}
@media (max-width:540px){
  .sidebar{grid-template-columns:1fr}
  .brand-pills{gap:6px}
  .brand-pill{padding:6px 12px 6px 6px;font-size:13px}
  .hero h1{font-size:28px}
  .dashboard{padding:0;gap:10px}
  .kpi{padding:14px;font-size:14px}
  .kpi b{font-size:18px}
  .site-footer .grid{grid-template-columns:1fr 1fr}
  /* Compact store-hero op mobile: kleiner logo, kleinere H1, geen border ervoor */
  .store-hero,.store-hero.compact{padding:8px 0 14px;grid-template-columns:64px 1fr;gap:14px}
  .store-hero .logo,.store-hero.compact .logo{width:64px;height:64px;font-size:22px}
  .store-hero h1,.store-hero.compact h1{font-size:20px;line-height:1.2;margin-bottom:4px}
  .store-hero .store-hero-bio{font-size:13px;line-height:1.4;margin-bottom:6px}
  .stats-strip{gap:6px}
  .stats-strip .ss-item{padding:4px 8px;font-size:11px}
  .top-pick-hero .tph-flag{font-size:11px;padding:4px 10px}
  .goedomteweten,.howto-block{padding:16px}
  .got-list{grid-template-columns:1fr}
  /* Editor pages mobile */
  .editor-profile-hero,.redactie-hero,.about-hero{grid-template-columns:1fr;padding:20px;gap:16px}
  .editor-avatar-big{width:90px;height:90px;font-size:44px}
  .editor-profile-hero .editor-info h1{font-size:28px}
  .rh-text h1,.ah-text h1{font-size:26px}
  .editor-counters{grid-template-columns:repeat(2,1fr);gap:10px}
  .ec-card{padding:14px 12px}
  .ec-card b{font-size:28px}
  .rh-counters,.ah-counters{grid-template-columns:repeat(2,1fr)}
  .tll-item{grid-template-columns:1fr;gap:4px;padding:10px}
}

/* ================================================================
   V2 REDESIGN (mei 2026) — Ticket-Stub coupon-systeem
   Gebruikt nieuwe semantische tokens (--yellow, --green, --pink, --blue).
   Legacy .coupon-* rules hierboven blijven werken voor pages die nog
   niet zijn gemigreerd; nieuwe templates renderen .ticket structuur.
   ================================================================ */

/* === Body achtergrond — frisser, neutraler ivory (was vies-geel) === */
body{background:#fefcf3}

/* === Store hero wrap — combineert logo+naam+intro met byline+stats in 1 blok === */
.store-hero-wrap{
  background:var(--paper);
  border:var(--bd) solid var(--ink);
  box-shadow:var(--shadow);
  margin:var(--s-5) 0 var(--s-6);
  overflow:hidden;
}
.store-hero-wrap .store-hero,
.store-hero-wrap .store-hero.compact{
  background:transparent;border:0;box-shadow:none;padding:var(--s-5) var(--s-5) var(--s-4);margin:0;
}
.store-hero-wrap .store-hero-foot{
  padding:var(--s-3) var(--s-5) var(--s-4);
  border-top:1.5px dashed rgba(0,0,0,.15);
  background:transparent;
  display:flex;flex-direction:column;gap:var(--s-3);
}
.store-hero-wrap .byline{margin:0;font-size:13px;color:var(--muted)}
.store-hero-wrap .stats-strip,
.store-hero-wrap .dashboard{margin:0;flex-wrap:wrap;gap:var(--s-2)}

/* === Brand-name fix: geen rode 'Hub' meer === */
.brand-name{position:relative}
.brand-name b{color:inherit;font-weight:800}
.brand-name::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--pink)}

/* === Shop hero (v2) === */
.shop-hero{
  margin:var(--s-5) 0 var(--s-6);
  background:var(--paper);
  border:var(--bd) solid var(--ink);
  box-shadow:var(--shadow);
  display:grid;grid-template-columns:auto 1fr auto;gap:var(--s-6);
  padding:var(--s-5) var(--s-6);align-items:center;
}
.shop-hero .shop-logo{
  width:96px;height:96px;background:var(--paper);
  border:var(--bd) solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  padding:8px;flex-shrink:0;overflow:hidden;
}
.shop-hero .shop-logo svg,.shop-hero .shop-logo img{width:100%;height:100%;display:block;object-fit:contain}
.shop-hero .shop-info h1{font-size:30px;margin-bottom:var(--s-2);font-family:var(--f-display);letter-spacing:-.02em}
.shop-hero .shop-info p{margin:0;font-size:14.5px;color:#333;line-height:1.55;max-width:560px}
.shop-pills{display:flex;flex-wrap:wrap;gap:var(--s-2);margin-top:var(--s-3)}
.shop-pills .pill{
  display:inline-flex;align-items:center;gap:5px;
  border:var(--bd-2) solid var(--ink);
  padding:3px 10px;font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  font-family:var(--f-display);background:var(--paper);
}
.shop-pills .pill.green{background:var(--green)}
.shop-pills .pill.blue{background:var(--blue)}
.shop-pills .pill.yellow{background:var(--yellow)}
.shop-pills .pill .star{color:#fb923c}
.shop-hero .shop-stats{
  display:flex;flex-direction:column;gap:var(--s-2);
  min-width:170px;padding-left:var(--s-5);
  border-left:3px dashed rgba(0,0,0,.15);
}
.shop-hero .shop-stats .stat{display:flex;flex-direction:column}
.shop-hero .shop-stats .stat .num{font-family:var(--f-display);font-size:24px;font-weight:800;line-height:1;letter-spacing:-.02em}
.shop-hero .shop-stats .stat .lab{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-top:3px;font-family:var(--f-display)}

/* === Main grid (1fr + 260px sidebar) — alias voor .layout/.sidebar === */
.main-grid{
  display:grid;grid-template-columns:1fr 260px;gap:var(--s-6);
  padding-bottom:var(--s-8);align-items:start;
}
.main-grid > .main{min-width:0}
.main-grid > .side{position:sticky;top:84px;display:flex;flex-direction:column;gap:var(--s-4)}

/* === Tab-row & sectie-headers v2 === */
.tab-row{
  display:flex;align-items:flex-end;justify-content:space-between;
  border-bottom:var(--bd) solid var(--ink);
  margin-bottom:var(--s-5);flex-wrap:wrap;gap:var(--s-3);
}
.tab-row .tabs{display:flex;gap:0;border-bottom:0;padding:0;margin:0}
.tab-row .tabs a{
  padding:10px 18px;
  font-family:var(--f-display);font-weight:800;font-size:13px;
  text-transform:uppercase;letter-spacing:.05em;color:#525252;
  border:var(--bd) solid transparent;border-bottom:0;
  position:relative;top:var(--bd);
}
.tab-row .tabs a.active{
  background:var(--yellow);color:var(--ink);border-color:var(--ink);
  box-shadow:4px -2px 0 0 var(--ink);
}
.tab-row .tabs a .ct{font-weight:600;color:#525252;margin-left:4px;font-size:12px}
.tab-row .tabs a.active .ct{color:var(--ink)}
.main .section-h{
  display:flex;align-items:baseline;gap:var(--s-2);
  font-size:22px;font-weight:800;
  margin:var(--s-5) 0 var(--s-4);
  padding-top:8px;
  font-family:var(--f-display);letter-spacing:-.02em;
}
.main .section-h:first-of-type{margin-top:var(--s-3)}
.main .section-h .ct,
.main .section-h .count{
  font-size:12px;font-weight:800;
  background:var(--yellow);border:var(--bd-2) solid var(--ink);
  padding:2px 8px;text-transform:uppercase;letter-spacing:.06em;line-height:1.5;
}
.main .section-h .sub{
  margin-left:auto;font-size:12px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.05em;font-family:var(--f-display);
}

/* ================================================================
   TICKET COUPON (v2) — vervangt .coupon in geüpdatete templates
   ================================================================ */
.cards{display:flex;flex-direction:column;gap:var(--s-5)}
.ticket{
  --notch:9px;
  --stub-w:184px;
  --gap-h:32px;
  position:relative;background:var(--paper);
  border:var(--bd) solid var(--ink);
  box-shadow:var(--shadow);
  display:grid;grid-template-columns:1fr var(--stub-w);
  /* Override legacy .coupon padding. Horizontale gap voor witruimte tussen
     content-deel en zwarte stub; verticale gap blijft 0. */
  padding:0;column-gap:var(--gap-h);row-gap:0;
  min-height:170px;
  transition:transform .15s,box-shadow .15s;
}
.ticket:hover{transform:translate(2px,2px);box-shadow:var(--shadow-sm)}
/* Verticale dashed perforatielijn in het midden van de witruimte tussen
   tk-content en tk-stub. Schaartje (.scissors) zit erop. */
.ticket::before{
  content:"";
  position:absolute;
  top:0;bottom:0;
  /* Plaats de lijn in het midden van de ZICHTBARE witruimte tussen content-tekst
     en zwarte stub. Die witruimte = column-gap + content-padding-right (= s-5).
     De extra +s-5/2 schuift de lijn LINKS naar het visuele midden ipv het
     column-gap-midden. -0.75px centreert de 1.5px-line zelf binnen die positie. */
  right:calc(var(--stub-w) + var(--gap-h) / 2 + var(--s-5) / 2 - 0.75px);
  width:0;
  border-left:1.5px dashed var(--ink);
  z-index:1;
  pointer-events:none;
}
.ticket.featured::before{border-left-color:var(--pink)}
.ticket.expired::before{border-left-color:#a3a3a3}
/* Dunne horizontale stippellijn tussen aangrenzende tickets — versterkt
   "afscheurbare bon" suggestie tussen de kaarten. */
.cards > .ticket + .ticket::after{
  content:"";
  position:absolute;
  /* Lijn precies in het midden van de .cards gap (= --s-5 = 24px), dus -12px
     boven de ticket-top. -1px voor de eigen 2px-line-dikte. */
  top:calc(var(--s-5) / -2 - 1px);
  left:24px;right:24px;
  border-top:2px dashed rgba(0,0,0,.3);
  pointer-events:none;
  z-index:1;
}
/* Schaartje op de verticale perforatie-naad binnen elke ticket —
   versterkt "scheur hier af" gevoel zonder ruimte tussen kaarten te eten.
   Witte achtergrond doorbreekt de dashed-line zodat het schaartje EROP zit. */
.ticket .scissors{
  position:absolute;
  top:50%;
  /* Plaats het MIDDELPUNT in het midden van de witruimte tussen tk-content
     en tk-stub (= midden van column-gap). Transparante achtergrond — de
     dashed lijn loopt zichtbaar door het schaartje heen. */
  right:calc(var(--stub-w) + var(--gap-h) / 2 + var(--s-5) / 2 - 0.75px);
  margin-top:-12px;
  margin-right:-12px;
  width:24px;height:24px;
  background:transparent;
  display:flex;align-items:center;justify-content:center;
  color:#262626;
  z-index:3;
  pointer-events:none;
}
.ticket .scissors svg{width:16px;height:16px;display:block;transform:rotate(90deg)}
.ticket.expired .scissors{background:#f0f0ed;color:#737373}

.ticket.featured{background:var(--paper);border-width:4px;box-shadow:7px 7px 0 0 var(--pink),7px 7px 0 4px var(--ink)}
.ticket.featured:hover{transform:translate(3px,3px);box-shadow:4px 4px 0 0 var(--pink),4px 4px 0 4px var(--ink)}
/* Featured = pink dashed seam (via .ticket.featured::before hierboven). */
.ticket.featured .scissors{color:#c026d3}

.ticket-ribbon{
  position:absolute;top:-16px;left:-4px;
  background:var(--pink);color:var(--ink);
  padding:6px 14px;font-size:11.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;
  border:var(--bd) solid var(--ink);
  font-family:var(--f-display);z-index:3;
  box-shadow:3px 3px 0 0 var(--ink);
}
.ticket-ribbon::before{content:"★ ";margin-right:2px}

.tk-content{
  padding:var(--s-5);
  /* Verticale perforatie wordt nu door .ticket::before gerenderd in het
     midden van de column-gap, niet meer als border-right. */
  display:flex;flex-direction:column;gap:var(--s-3);min-width:0;
}
.tk-top{display:flex;gap:var(--s-4);align-items:flex-start}
.tk-logo{
  width:56px;height:56px;flex-shrink:0;
  background:var(--paper);border:var(--bd-2) solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  padding:4px;overflow:hidden;
}
.tk-logo svg,.tk-logo img{width:100%;height:100%;display:block;object-fit:contain}
.tk-logo .tk-logo-fallback{display:none;width:100%;height:100%;align-items:center;justify-content:center;font-weight:800;font-size:14px;background:var(--yellow);color:var(--ink);font-family:var(--f-display)}
.tk-logo img.failed{display:none}
.tk-logo img.failed + .tk-logo-fallback{display:flex}

.tk-meta{flex:1;min-width:0}
.tk-pills{display:flex;flex-wrap:wrap;gap:5px;align-items:center;margin-bottom:4px}
.tk-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  font-family:var(--f-display);
  border:var(--bd-2) solid var(--ink);
}
.tk-pill.verified{background:var(--green);color:var(--ink)}
.tk-pill.verified::before{content:"✓";font-weight:800}
.tk-pill.verified.broken{background:#fecaca;color:#7f1d1d}
.tk-pill.verified.broken::before{content:"✕"}
.tk-pill.cat{background:var(--blue);color:var(--ink)}
.tk-pill.fresh{background:var(--paper);color:var(--ink)}
.tk-pill.fresh::before{content:"●";color:var(--green);font-size:8px}
.tk-pill.deal{background:var(--yellow);color:var(--ink)}

.tk-title{font-size:21px;font-weight:800;line-height:1.22;margin:8px 0 6px;color:var(--ink);font-family:var(--f-display);letter-spacing:-.015em}
.ticket.featured .tk-title{font-size:23px}
.tk-byline{font-size:12.5px;color:var(--muted);font-weight:500;line-height:1.4;margin:0}
.tk-byline b{color:var(--ink);font-weight:700}

.tk-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:var(--s-3);
  padding-top:var(--s-3);border-top:1.5px dashed rgba(0,0,0,.15);
  margin-top:auto;
  font-size:12px;color:var(--muted);font-weight:500;
}
/* Stem-widget: pill ("89% werkt · 9") + plus/min-knoppen horen visueel bij elkaar. */
.tk-vote-group{
  display:inline-flex;align-items:center;gap:var(--s-2);
  padding:4px 6px;
  background:rgba(0,0,0,.03);
  border:1.5px solid rgba(0,0,0,.1);
}
.tk-success{font-weight:700;color:#0a7a3b}
.tk-success b{font-weight:800}
.tk-bottom .restrict{font-style:italic}

.tk-stub{
  background:var(--ink);color:#fff;
  display:flex;flex-direction:column;align-items:stretch;
  padding:var(--s-5) var(--s-4);text-align:center;gap:var(--s-4);
  /* Wit randje rondom het zwarte blok (top/right/bottom). Links zit al
     witruimte door de column-gap met dashed perforatie. */
  margin:var(--s-2) var(--s-2) var(--s-2) 0;
}
.tk-stub-top{display:flex;flex-direction:column;align-items:center;gap:4px}
.stub-label{font-size:9.5px;color:#a3a3a3;font-weight:800;text-transform:uppercase;letter-spacing:.16em;font-family:var(--f-display)}
.stub-value{font-size:36px;font-weight:800;line-height:.95;color:var(--yellow);font-family:var(--f-display);letter-spacing:-.03em}
.stub-value small{font-size:.55em;font-weight:800}

/* === Peel (code-reveal in stub) === */
.peel{
  position:relative;width:100%;height:42px;
  overflow:hidden;cursor:pointer;margin-top:auto;
  border:0;padding:0;background:transparent;
  display:block;
}
.peel-code{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:flex-end;
  padding:0 var(--s-2);
  background:var(--paper);color:var(--ink);
  font-family:var(--f-mono);
  font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  border:var(--bd-2) solid var(--paper);
}
.peel-btn{
  position:absolute;top:0;left:0;bottom:0;
  width:88%;
  background:var(--yellow);color:var(--ink);
  display:flex;align-items:center;justify-content:center;gap:4px;
  font-size:11.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  font-family:var(--f-display);
  /* Geen border-right: de driehoek-tip (::after) zou anders een 2px zwarte
     verticale lijn ertussen tonen. Top/bottom/left wel om de knop af te bakenen. */
  border:var(--bd-2) solid var(--ink);
  border-right:0;
  transition:width .35s cubic-bezier(.16,1,.3,1),background .15s;
  z-index:2;
}
.peel-btn::after{
  content:"";position:absolute;
  right:-10px;
  top:0;bottom:0;
  width:0;height:0;
  border-left:10px solid var(--yellow);
  border-top:21px solid transparent;
  border-bottom:21px solid transparent;
  transition:border-left-color .15s;
}
.ticket:hover .peel-btn,.peel:hover .peel-btn,.peel:focus-within .peel-btn{width:84%;background:var(--green)}
.ticket:hover .peel-btn::after,.peel:hover .peel-btn::after{border-left-color:var(--green)}

/* === Deal-only variant: zwart-geel button (geen code) === */
.ticket.deal .peel-btn{background:var(--ink);color:var(--yellow);border-color:var(--yellow)}
.ticket.deal .peel-btn::after{border-left-color:var(--ink)}
.ticket.deal:hover .peel-btn{background:var(--green);color:var(--ink);border-color:var(--ink)}
.ticket.deal:hover .peel-btn::after{border-left-color:var(--green)}
.ticket.deal .peel-code{justify-content:center;font-family:var(--f-display);font-size:11.5px;letter-spacing:.06em}

/* === Expired tickets === */
.ticket.expired{background:#f0f0ed;box-shadow:var(--shadow-sm);opacity:.85}
.ticket.expired:hover{transform:none;box-shadow:var(--shadow-sm)}
/* (legacy scallop ::before/::after background no-op verwijderd) */
.ticket.expired .tk-title{color:#525252}
.ticket.expired .tk-pill.verified{background:#d4d4d4;color:#525252;border-color:#525252}
.ticket.expired .tk-pill.verified::before{content:"✕"}
.ticket.expired .tk-stub{background:#525252;color:#d4d4d4}
.ticket.expired .stub-value{color:#d4d4d4}
.ticket.expired .stub-label{color:#a3a3a3}
.ticket.expired .peel{cursor:default;pointer-events:none}
.ticket.expired .peel-btn{background:#737373;color:#d4d4d4;border-color:#525252}
.ticket.expired .peel-btn::after{border-left-color:#737373}
.ticket.expired .peel-code{background:#f0f0ed;color:#737373}

/* === Over-deze-winkel — nieuw gekaderd blok === */
.main .editorial-frame{
  background:var(--paper);
  border:var(--bd-2) solid var(--ink);
  box-shadow:var(--shadow-sm);
  padding:var(--s-5);
  margin-bottom:var(--s-5);
}
.main .editorial-frame .editorial-prose p{margin:0 0 var(--s-3);font-size:14.5px;color:#262626;line-height:1.7}
.main .editorial-frame .editorial-prose p:last-child{margin-bottom:0}
.main .editorial-frame .editorial-prose h3{font-family:var(--f-display);font-weight:800;font-size:16px;margin:var(--s-4) 0 var(--s-2)}

/* Legacy .editorial (homepage etc.) blijft transparant/clean */
.main .editorial{background:transparent;border:0;box-shadow:none;padding:0 0 var(--s-3);margin-bottom:var(--s-5)}
.main .editorial p{margin:0 0 var(--s-3);font-size:15px;color:#262626;line-height:1.7;max-width:780px}
.main .editorial p:last-child{margin-bottom:0}
.main .editorial h2,.main .editorial h3{font-family:var(--f-display);font-weight:800}
.main .editorial-stats{
  display:flex;flex-wrap:wrap;gap:var(--s-2);
  margin-top:var(--s-3);padding-top:var(--s-4);
  border-top:1.5px dashed rgba(0,0,0,.15);
}
.editorial-stat{
  display:inline-flex;flex-direction:column;
  padding:var(--s-2) var(--s-3);
  border:var(--bd-2) solid var(--ink);min-width:140px;
}
.editorial-stat.b{background:var(--blue)}
.editorial-stat.y{background:var(--yellow)}
.editorial-stat.g{background:var(--green)}
.editorial-stat .num{font-family:var(--f-display);font-weight:800;font-size:20px;line-height:1;letter-spacing:-.02em}
.editorial-stat .lab{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#262626;margin-top:4px;font-family:var(--f-display)}

/* === Info grid (Goed om te weten) — icon links naast titel === */
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--s-3);margin-bottom:var(--s-5)}
.info-card{
  background:var(--paper);
  border:var(--bd-2) solid var(--ink);
  box-shadow:var(--shadow-sm);
  padding:var(--s-4);
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-areas:"icon title" "body body";
  column-gap:var(--s-3);row-gap:var(--s-2);
  align-items:center;
}
.info-card .ic-icon{
  grid-area:icon;
  width:34px;height:34px;
  background:var(--yellow);border:var(--bd-2) solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);flex-shrink:0;
}
.info-card .ic-icon svg{width:20px;height:20px;display:block}
.info-card h3{grid-area:title;font-size:15px;margin:0;font-family:var(--f-display);font-weight:800;line-height:1.2}
.info-card p{grid-area:body;font-size:13px;margin:0;color:#404040;line-height:1.55}

/* === Howto pipeline === */
.howto-pipeline{display:flex;flex-direction:column;gap:var(--s-3);margin-bottom:var(--s-5)}
.step-card{
  background:var(--paper);border:var(--bd) solid var(--ink);box-shadow:var(--shadow-sm);
  padding:var(--s-4) var(--s-4) var(--s-4) calc(var(--s-7) + var(--s-2));
  position:relative;
}
.step-card .step-num{
  position:absolute;left:calc(var(--bd) * -1);top:calc(var(--bd) * -1);
  width:var(--s-7);height:var(--s-7);
  background:var(--ink);color:var(--yellow);
  border:var(--bd) solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-weight:800;font-size:22px;letter-spacing:-.02em;
}
.step-card h3{font-size:15px;margin:0 0 4px;font-family:var(--f-display);font-weight:800}
.step-card p{font-size:13.5px;margin:0;color:#262626;line-height:1.55}

/* === Tips grid (4 brand-kleuren cyclen) === */
.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--s-3);margin-bottom:var(--s-5)}
.tip-card{border:var(--bd) solid var(--ink);box-shadow:var(--shadow);padding:var(--s-4)}
.tip-card .tip-icon{
  width:38px;height:38px;border:var(--bd-2) solid var(--ink);
  background:var(--paper);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:var(--s-3);color:var(--ink);
}
.tip-card .tip-icon svg{width:22px;height:22px;display:block}
.tip-card h3{font-size:15px;margin:0 0 6px;font-family:var(--f-display);font-weight:800;color:var(--ink)}
.tip-card p{font-size:13px;margin:0;line-height:1.5;color:var(--ink);font-weight:500}
.tip-card.y{background:var(--yellow)}
.tip-card.g{background:var(--green)}
.tip-card.p{background:var(--pink)}
.tip-card.b{background:var(--blue)}

/* === FAQ === */
.faq-list{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-5)}
.faq-item{background:var(--paper);border:var(--bd) solid var(--ink);box-shadow:var(--shadow-sm);overflow:hidden}
.faq-item summary{
  cursor:pointer;list-style:none;
  padding:var(--s-3) var(--s-4);
  font-family:var(--f-display);font-weight:800;font-size:15px;
  display:flex;justify-content:space-between;align-items:center;gap:var(--s-3);
  color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-family:var(--f-display);font-weight:800;font-size:22px;
  width:30px;height:30px;flex-shrink:0;
  background:var(--ink);color:var(--yellow);
  display:flex;align-items:center;justify-content:center;line-height:1;
  transition:background .15s;
}
.faq-item summary:hover::after{background:var(--green);color:var(--ink)}
.faq-item[open] summary{background:var(--yellow);border-bottom:var(--bd-2) solid var(--ink)}
.faq-item[open] summary::after{content:"−";background:var(--green);color:var(--ink)}
.faq-item .answer{padding:var(--s-3) var(--s-4) var(--s-4);font-size:14px;color:#262626;line-height:1.6}
.faq-item .answer p{margin:0 0 var(--s-2)}
.faq-item .answer p:last-child{margin-bottom:0}

/* === App promo banner === */
.app-banner{
  background:var(--yellow);
  border:var(--bd) solid var(--ink);
  box-shadow:var(--shadow);
  padding:var(--s-5);margin-bottom:var(--s-5);
  display:grid;grid-template-columns:auto 1fr auto;
  gap:var(--s-4);align-items:center;
  position:relative;overflow:hidden;
}
.app-banner::before{
  content:"";position:absolute;right:-30px;top:-30px;
  width:120px;height:120px;background:var(--pink);
  border:var(--bd) solid var(--ink);transform:rotate(8deg);z-index:0;
}
.app-banner > *{position:relative;z-index:1}
.app-banner .app-icon{
  width:60px;height:60px;background:var(--ink);color:var(--yellow);
  border:var(--bd) solid var(--ink);box-shadow:var(--shadow-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:30px;font-family:var(--f-display);font-weight:800;
}
.app-banner h3{font-size:20px;margin:0 0 4px;font-family:var(--f-display)}
.app-banner p{margin:0;font-size:13.5px;color:var(--ink);font-weight:500}
.app-banner .cta{
  background:var(--ink);color:var(--yellow);
  border:var(--bd) solid var(--ink);box-shadow:var(--shadow-sm);
  padding:var(--s-3) var(--s-4);
  font-family:var(--f-display);font-weight:800;font-size:12px;
  text-transform:uppercase;letter-spacing:.06em;
  text-decoration:none;white-space:nowrap;
}
.app-banner .cta:hover{background:var(--pink);color:var(--ink)}

/* === Affiliate / trust disclosure (onderaan content) === */
.affiliate-notice{
  background:var(--paper);
  border:var(--bd-2) solid var(--ink);
  border-left:6px solid var(--green);
  box-shadow:var(--shadow-sm);
  padding:var(--s-4) var(--s-5);
  margin:var(--s-5) 0 var(--s-4);
  display:flex;gap:var(--s-3);align-items:flex-start;
  font-size:13px;line-height:1.6;color:#262626;
}
.affiliate-notice .an-icon{
  flex-shrink:0;width:32px;height:32px;
  background:var(--green);border:var(--bd-2) solid var(--ink);
  display:flex;align-items:center;justify-content:center;color:var(--ink);
}
.affiliate-notice .an-icon svg{width:18px;height:18px}
.affiliate-notice b{font-family:var(--f-display);font-weight:800;color:var(--ink);display:block;margin-bottom:2px;font-size:14px}
.affiliate-notice a{text-decoration:underline;text-underline-offset:2px;font-weight:700;color:var(--ink)}

/* === Expired collapse-wrap === */
.expired-wrap{margin-bottom:var(--s-5)}
.expired-wrap summary{list-style:none;cursor:pointer}
.expired-wrap summary::-webkit-details-marker{display:none}
.expired-toggle{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--paper);border:var(--bd-2) solid var(--ink);
  padding:var(--s-2) var(--s-3);
  font-family:var(--f-display);font-weight:800;font-size:12px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--ink);
}
.expired-toggle:hover{background:var(--yellow)}
.expired-toggle .chev{transition:transform .2s}
.expired-wrap[open] .expired-toggle .chev{transform:rotate(180deg)}
.expired-list{display:flex;flex-direction:column;gap:var(--s-3);margin-top:var(--s-3)}

/* === Sidebar (v2) — gebruikt .side-block in .main-grid > .side === */
.side .side-block{background:var(--paper);border:var(--bd) solid var(--ink);box-shadow:var(--shadow);padding:var(--s-4)}
.side .side-h{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:var(--s-3);font-family:var(--f-display);
  display:flex;align-items:center;gap:6px;
  padding-bottom:var(--s-2);border-bottom:var(--bd-2) solid var(--ink);
}
.side .activity-list{display:flex;flex-direction:column;gap:var(--s-3)}
.side .activity-item{display:grid;grid-template-columns:auto 1fr;gap:var(--s-2);font-size:12.5px;line-height:1.45}
.side .activity-item .dot{width:8px;height:8px;background:var(--green);border:2px solid var(--ink);border-radius:50%;margin-top:5px;flex-shrink:0}
.side .activity-item.fresh .dot{background:var(--pink)}
.side .activity-item .txt{color:var(--ink);font-weight:600}
.side .activity-item .time{display:block;font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-family:var(--f-display)}
.side .nl-block{
  background:var(--ink);color:#fff;
  padding:var(--s-4);border:var(--bd) solid var(--ink);box-shadow:var(--shadow);
  border-top:6px solid var(--yellow);
}
.side .nl-block h3{color:var(--yellow);font-size:16px;margin-bottom:4px;font-family:var(--f-display)}
.side .nl-block p{margin:0 0 var(--s-3);font-size:12.5px;color:#d4d4d4;line-height:1.5}
.side .nl-block input{width:100%;height:38px;padding:0 var(--s-3);border:var(--bd-2) solid var(--yellow);background:#fff;font-size:13px;font-weight:500;margin-bottom:var(--s-2);border-radius:0;font-family:var(--f-body)}
.side .nl-block button{width:100%;height:40px;background:var(--yellow);color:var(--ink);border:var(--bd-2) solid var(--yellow);font-family:var(--f-display);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.06em;cursor:pointer}
.side .nl-block button:hover{background:#fff}

/* Related-stores (sidebar) — kleine cat-marks */
.side .related-list{display:flex;flex-direction:column;gap:6px}
.side .related-list a{
  display:flex;justify-content:space-between;align-items:center;gap:var(--s-2);
  padding:6px 10px;border:var(--bd-2) solid var(--ink);background:var(--paper);
  font-size:13px;font-weight:700;transition:background .12s;
}
.side .related-list a:hover{background:var(--blue)}
.side .related-list a .row{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.side .related-list a .label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side .related-list a .n{font-family:var(--f-mono);font-size:11px;color:var(--muted);font-weight:700;flex-shrink:0}
.side .related-list a:hover .n{color:var(--ink)}
.cat-mark{
  width:22px;height:22px;flex-shrink:0;
  border:var(--bd-2) solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-weight:800;font-size:10px;
  color:#fff;background:var(--ink);letter-spacing:-.02em;overflow:hidden;
}
.cat-mark img{width:100%;height:100%;object-fit:contain}

/* === Footer (v2) — visueel iets rustiger === */
.site-footer{border-top:var(--bd) solid var(--ink)}

/* ================================================================
   RESPONSIVE (v2)
   ================================================================ */
@media (max-width:980px){
  .main-grid{grid-template-columns:1fr}
  .main-grid > .side{position:static;top:auto}
  .shop-hero{grid-template-columns:1fr;text-align:left;padding:var(--s-4)}
  .shop-hero .shop-stats{flex-direction:row;flex-wrap:wrap;border-left:0;border-top:3px dashed rgba(0,0,0,.15);padding-left:0;padding-top:var(--s-3);gap:var(--s-5)}
  .shop-hero .shop-info h1{font-size:24px}
}
@media (max-width:640px){
  .ticket{grid-template-columns:1fr;--stub-w:0}
  .ticket::before{display:none} /* verticale dashed verbergen op mobile (geen seam) */
  .tk-content{border-right:0;border-bottom:var(--bd) dashed var(--ink)}
  .tk-stub{flex-direction:row;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4)}
  .tk-stub-top{flex-direction:row;align-items:baseline;gap:var(--s-2);padding-top:0}
  .stub-value{font-size:24px}
  .peel{flex:1;height:38px;margin-top:0}
  .tab-row .tabs a{padding:8px 12px;font-size:12px}
  .shop-hero{padding:var(--s-3)}
  .shop-hero .shop-logo{width:64px;height:64px}
  .app-banner{grid-template-columns:1fr;gap:var(--s-3)}
  .app-banner::before{width:80px;height:80px}
  .step-card{padding:var(--s-7) var(--s-4) var(--s-4)}
  .step-card .step-num{left:var(--s-3);top:calc(var(--bd) * -1)}
  .ticket.featured .tk-content{padding-left:calc(var(--s-4) + 6px)}
}

/* ================================================================
   CONTENT PAGES (over-ons, hoe-werkt-het, redactie)
   Neobrutalist styling — black borders, hard shadows, bold display type.
   ================================================================ */
.content-page{padding-top:24px;padding-bottom:64px;max-width:1080px}
.content-page .breadcrumb{margin-bottom:24px;font-size:13px;color:#525252}
.content-page .breadcrumb a{color:#000;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.content-page .breadcrumb i{margin:0 8px;font-style:normal;color:#a3a3a3}

.page-hero{margin-bottom:48px;max-width:780px}
.page-pill{display:inline-block;background:var(--neo-yellow);border:2px solid #000;box-shadow:var(--shadow-sm);padding:6px 12px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-display);margin-bottom:16px}
.page-hero h1{font-size:48px;font-weight:800;font-family:var(--f-display);line-height:1.05;letter-spacing:-.02em;margin:0 0 16px}
.page-hero h1 .hl{background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);padding:0 8px;display:inline-block;transform:skewY(-1deg)}
.page-hero .lede{font-size:17px;line-height:1.6;color:#1a1a1a;margin:0}

.stats-strip-2{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:32px 0 48px;border:3px solid #000;background:#fff;box-shadow:var(--shadow);padding:0}
.stats-strip-2 .stat-box{padding:20px 16px;text-align:center;border-right:2px solid #000}
.stats-strip-2 .stat-box:last-child{border-right:0}
.stats-strip-2 .stat-box b{display:block;font-family:var(--f-display);font-size:32px;font-weight:800;line-height:1;margin-bottom:6px;color:#000}
.stats-strip-2 .stat-box span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#525252}

.section-h{font-size:28px;font-weight:800;font-family:var(--f-display);margin:48px 0 8px;letter-spacing:-.01em}
.section-sub{font-size:15px;color:#525252;margin:0 0 24px}

.redactie-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-bottom:48px}
.redactie-card{display:flex;gap:16px;padding:20px;background:#fff;border:3px solid #000;box-shadow:var(--shadow);text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s}
.redactie-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 #000}
.redactie-avatar{flex:0 0 60px;width:60px;height:60px;background:#000;color:var(--neo-yellow);border:3px solid #000;display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:900;font-size:28px}
.redactie-body{flex:1;min-width:0}
.redactie-body h3{font-size:20px;font-weight:800;font-family:var(--f-display);margin:0 0 4px}
.redactie-role{display:inline-block;background:var(--neo-yellow);border:2px solid #000;padding:2px 8px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-display);margin-bottom:8px}
.redactie-meta{font-size:12px;color:#525252;margin:0 0 8px;font-weight:600}
.redactie-quote{font-size:13px;line-height:1.5;color:#1a1a1a;font-style:italic;margin:0;border-left:3px solid #000;padding-left:10px}

.mission-box{background:var(--neo-card);border:3px solid #000;box-shadow:var(--shadow);padding:24px 28px;margin-bottom:32px}
.mission-box p{font-size:15px;line-height:1.65;margin:0 0 12px}
.mission-box p:last-child{margin-bottom:0}

.legal-card{background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:20px 24px;margin-bottom:32px;font-size:14px;line-height:1.7}
.legal-card a{text-decoration:underline;font-weight:700}

/* How-it-works steps */
.how-steps{list-style:none;padding:0;margin:0 0 48px;display:grid;gap:20px}
.how-step{display:flex;gap:20px;background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:24px}
.how-step .step-num{flex:0 0 56px;width:56px;height:56px;background:var(--neo-yellow);color:#000;border:3px solid #000;display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:900;font-size:28px}
.how-step .step-body{flex:1}
.how-step .step-body h3{font-size:22px;font-weight:800;font-family:var(--f-display);margin:0 0 8px}
.how-step .step-body p{font-size:15px;line-height:1.65;margin:0;color:#1a1a1a}

.anatomy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:32px}
.anatomy-card{background:#fff;border:3px solid #000;box-shadow:var(--shadow-sm);padding:18px}
.anatomy-card .anatomy-pill{display:inline-flex;align-items:center;gap:4px;border:2px solid #000;color:#000;padding:4px 10px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-display);margin-bottom:12px}
.anatomy-card p{font-size:13.5px;line-height:1.55;margin:0;color:#1a1a1a}

@media (max-width:640px){
  .page-hero h1{font-size:32px}
  .stats-strip-2{grid-template-columns:repeat(2,1fr)}
  .stats-strip-2 .stat-box{border-right:0;border-bottom:2px solid #000}
  .stats-strip-2 .stat-box:nth-child(odd){border-right:2px solid #000}
  .stats-strip-2 .stat-box:nth-last-child(-n+2){border-bottom:0}
  .stats-strip-2 .stat-box b{font-size:24px}
  .how-step{padding:16px;gap:14px}
  .how-step .step-num{flex-basis:42px;width:42px;height:42px;font-size:22px}
}

/* ================================================================
   BLOG — neobrutalism: thick borders, hard shadows, no rounding
   ================================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin:32px 0}
.blog-card{display:flex;flex-direction:column;background:#fff;border:3px solid #000;box-shadow:var(--shadow);padding:20px;text-decoration:none;color:#000;transition:transform .15s,box-shadow .15s;position:relative}
.blog-card:hover{box-shadow:var(--shadow-hover);transform:translate(2px,2px)}
.blog-card:focus-visible{outline:3px solid var(--neo-pink);outline-offset:4px}
.blog-card-emoji{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;font-size:34px;line-height:1;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);margin-bottom:14px}
.blog-card:nth-child(3n+1) .blog-card-emoji{background:var(--neo-yellow)}
.blog-card:nth-child(3n+2) .blog-card-emoji{background:var(--neo-green)}
.blog-card:nth-child(3n+3) .blog-card-emoji{background:var(--neo-pink)}
.blog-card-cat{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:#000;background:#fff;border:2px solid #000;padding:3px 8px;margin-bottom:10px;font-family:var(--f-display)}
.blog-card-title{font-size:18px;line-height:1.25;margin:0 0 10px;font-weight:800;font-family:var(--f-display);color:#000;letter-spacing:-.01em}
.blog-card-desc{font-size:14px;line-height:1.55;color:#525252;margin:0 0 14px;flex:1}
.blog-card-meta{font-size:12px;color:#525252;font-weight:600;margin-top:auto;padding-top:10px;border-top:2px solid #000}

/* Blog index hero */
.blog-empty{background:var(--neo-card);border:3px solid #000;box-shadow:var(--shadow);padding:28px;margin:24px 0}
.blog-empty h2{font-family:var(--f-display);font-size:24px;margin:0 0 10px}

/* Blog article — detail page */
.blog-article{max-width:780px}
.breadcrumb{font-size:13px;color:#525252;font-weight:600;margin:20px 0 16px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.breadcrumb a{color:#000;text-decoration:none;border-bottom:2px solid transparent;transition:border-color .1s}
.breadcrumb a:hover{border-bottom-color:#000}
.breadcrumb span[aria-current],.breadcrumb>span:last-child{color:#525252}
.blog-header{margin:0 0 32px;padding:24px;background:var(--neo-card);border:3px solid #000;box-shadow:var(--shadow)}
.blog-header .blog-card-cat{background:var(--neo-yellow)}
.blog-header h1{font-size:38px;line-height:1.15;margin:12px 0 14px;font-family:var(--f-display);font-weight:900;letter-spacing:-.02em}
.blog-header .sub{font-size:18px;line-height:1.55;color:#1a1a1a;margin:0 0 16px}
.blog-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:#525252;font-weight:600;padding-top:14px;border-top:2px solid #000}
.blog-meta a{color:#000;border-bottom:2px solid #000}
.blog-lead{font-size:19px;line-height:1.65;margin:24px 0 36px;font-weight:600;background:#fff;border:3px solid #000;box-shadow:var(--shadow-sm);padding:20px 24px;border-left:8px solid var(--neo-yellow)}
.blog-section{margin:36px 0}
.blog-section h2{font-size:26px;line-height:1.25;margin:0 0 14px;font-family:var(--f-display);font-weight:800;letter-spacing:-.01em;display:inline-block;background:var(--neo-yellow);border:3px solid #000;box-shadow:var(--shadow-sm);padding:4px 12px}
.blog-section p{font-size:16px;line-height:1.75;margin:14px 0;color:#1a1a1a}
.blog-section ul{margin:16px 0;padding:0;list-style:none;background:#fff;border:3px solid #000;box-shadow:var(--shadow-sm)}
.blog-section ul li{font-size:15.5px;line-height:1.65;padding:12px 16px 12px 42px;border-bottom:2px solid #000;position:relative}
.blog-section ul li:last-child{border-bottom:0}
.blog-section ul li::before{content:"✓";position:absolute;left:14px;top:12px;width:20px;height:20px;background:var(--neo-green);border:2px solid #000;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;color:#000}

/* FAQ accordeon */
.blog-faq{margin:48px 0;padding-top:28px;border-top:3px solid #000}
.blog-faq h2{font-family:var(--f-display);font-size:28px;margin:0 0 20px;display:inline-block;background:var(--neo-pink);border:3px solid #000;box-shadow:var(--shadow-sm);padding:4px 14px}
.blog-faq details{background:#fff;border:3px solid #000;box-shadow:var(--shadow-sm);margin:0 0 12px;overflow:hidden;transition:box-shadow .15s,transform .15s}
.blog-faq details[open]{box-shadow:var(--shadow);transform:translate(-1px,-1px)}
.blog-faq summary{font-family:var(--f-display);font-weight:800;font-size:16px;padding:14px 18px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;color:#000}
.blog-faq summary::-webkit-details-marker{display:none}
.blog-faq summary::after{content:"+";font-size:24px;font-weight:900;width:28px;height:28px;background:var(--neo-yellow);border:2px solid #000;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.blog-faq details[open] summary::after{content:"−";background:var(--neo-pink)}
.blog-faq details p{margin:0;padding:0 18px 16px;font-size:15px;line-height:1.65;color:#1a1a1a;border-top:2px solid #000;padding-top:14px}

/* Related posts */
.blog-related{margin:56px 0 32px;padding-top:28px;border-top:3px solid #000}
.blog-related h2{font-family:var(--f-display);font-size:24px;margin:0 0 18px}

@media (max-width:640px){
  .blog-grid{grid-template-columns:1fr;gap:16px}
  .blog-card{padding:16px}
  .blog-header{padding:18px}
  .blog-header h1{font-size:28px}
  .blog-header .sub{font-size:16px}
  .blog-section h2{font-size:22px}
  .blog-lead{font-size:17px;padding:16px 18px}
  .blog-faq summary{font-size:15px;padding:12px 14px}
}

/* COOKIE BANNER — AVG/Consent Mode v2 */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;background:var(--neo-yellow);border:4px solid #000;box-shadow:8px 8px 0 0 #000;opacity:0;transform:translateY(20px);transition:opacity .2s,transform .2s;max-width:760px;margin:0 auto}
.cookie-banner[hidden]{display:none}
.cookie-banner.revealed{opacity:1;transform:translateY(0)}
.cookie-banner-inner{display:flex;align-items:center;gap:20px;padding:18px 22px;flex-wrap:wrap}
.cookie-text{flex:1;min-width:240px}
.cookie-text h3{font-family:"Space Grotesk",Inter,sans-serif;font-size:18px;font-weight:800;margin:0 0 4px;color:#000;letter-spacing:-.01em}
.cookie-text p{font-size:13.5px;line-height:1.5;color:#000;margin:0;font-weight:500}
.cookie-text a{color:#000;font-weight:800;text-decoration:underline;text-underline-offset:2px}
.cookie-text a:hover{background:#000;color:var(--neo-yellow);text-decoration:none}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-actions .btn{height:42px;padding:0 16px;font-size:13px}
.cookie-prefs-btn{background:none;border:0;padding:0;font:inherit;color:inherit;cursor:pointer;text-align:left}
@media (max-width:640px){
  .cookie-banner{left:8px;right:8px;bottom:8px;box-shadow:5px 5px 0 0 #000}
  .cookie-banner-inner{padding:14px 16px;gap:14px}
  .cookie-text h3{font-size:16px}
  .cookie-text p{font-size:13px}
  .cookie-actions{width:100%}
  .cookie-actions .btn{flex:1}
}

/* ================================================================
   MOBILE FIXES (iPhone 8 ~375px) — ticket layout + header compact
   Added na mobile-review: voorkomt dat .restrict-tekst tot 1 woord
   per regel ingedrukt wordt naast de vote-pill, en dat de zwarte
   stub-kolom de helft van de viewport opslokt.
   ================================================================ */
@media (max-width:640px){
  /* Header: logo + search BLIJVEN naast elkaar op 1 regel — flex-wrap uit
     en search krijgt min-width:0 zodat hij de resterende ruimte vult ipv
     wrappen onder het logo. */
  .site-header .wrap{padding-top:10px;padding-bottom:10px;min-height:0;gap:10px;flex-wrap:nowrap}
  .search{flex:1;min-width:0;max-width:none}
  .search input{height:36px;font-size:13px;padding:0 12px 0 34px;border-width:2px;box-shadow:1.5px 1.5px 0 0 #000}
  .search svg{width:14px;height:14px;left:11px;stroke-width:2}

  /* Ticket: smallere stub-kolom op mobile, anders houdt content geen ruimte over. */
  .ticket{--stub-w:128px;--gap-h:18px;min-height:0}
  .tk-content{padding:14px 0 14px 14px}
  .tk-stub{padding:14px 10px;margin:6px;gap:10px}
  .stub-value{font-size:30px}
  .stub-label{font-size:9px;letter-spacing:.12em}
  .tk-logo{width:44px;height:44px}
  .tk-top{gap:10px}
  .tk-title{font-size:17px;line-height:1.22;margin:4px 0}
  .ticket.featured .tk-title{font-size:18px}
  .tk-byline{font-size:11.5px}

  /* tk-bottom stack: vote-pill bovenaan op volle breedte, restrict eronder
     leesbaar in plaats van 1-woord-per-regel naast de pill. */
  .tk-bottom{flex-direction:column;align-items:stretch;gap:8px;padding-top:10px}
  .tk-vote-group{align-self:flex-start;padding:3px 5px}
  .tk-bottom .restrict{font-size:11.5px;line-height:1.4;color:#525252;font-style:normal}

  /* Verify-pill (95% WERKT · 132) iets compacter — past binnen smalle content-kolom. */
  .verify-pill{font-size:11px;padding:4px 8px}
  .vote-btn{width:30px;height:30px;font-size:18px}

  /* Ticket-ribbon: steekt links uit het ticket — geeft "opgeplakt" sticker-gevoel.
     Hogere overhang (-10px) en grotere shadow zodat het visueel duidelijk
     boven en buiten de kaart hangt. */
  .ticket.featured{border-width:3px;box-shadow:5px 5px 0 0 var(--pink),5px 5px 0 3px var(--ink)}
  .ticket-ribbon{font-size:10px;padding:4px 10px;top:-10px;left:-10px;box-shadow:3px 3px 0 0 var(--ink);transform:rotate(-3deg);transform-origin:left center}

  /* Thin grey dashed line boven de 97% pill: weg op mobile — de hoofdperforatie
     onder de fineprint doet het visuele scheidingswerk al. */
  .tk-bottom{border-top:0;padding-top:6px}

  /* Schaartje op mobile uit — perforatielijn alleen is rustiger. */
  .ticket .scissors{display:none}

  /* Hero compacter op mobile — was 518px hoog (77% van iPhone 8 viewport).
     Kleinere h1 + minder padding zodat eerste content boven de fold komt. */
  .hero{padding:20px 0 12px}
  .hero h1{font-size:24px;line-height:1.12;margin-bottom:12px}
  .hero-pill{font-size:11px;padding:5px 10px;margin-bottom:12px;letter-spacing:.03em}
  .hero .sub{font-size:15px;margin-bottom:18px;line-height:1.5}
  .hero h1 .hl{padding:0 6px}

  /* Blog-lead minder gewicht — was 17px / 600 wat als bold-blok aanvoelde
     bij elke lange paragraaf onder de titel. */
  .blog-lead{font-size:16px;font-weight:500;line-height:1.6;margin:18px 0 28px;padding:14px 16px}
  .blog-header{padding:16px}
  .blog-header h1{font-size:24px;line-height:1.18}
  .blog-header .sub{font-size:15px;line-height:1.5}
  .blog-section{margin:28px 0}
  .blog-section h2{font-size:20px;padding:3px 10px}
  .blog-section p{font-size:15.5px;line-height:1.7;margin:12px 0}
  .blog-section ul li{font-size:15px;padding:10px 14px 10px 38px}
  .blog-section ul li::before{left:12px;top:11px;width:18px;height:18px;font-size:12px}

  /* Breadcrumb minder bovenmarge op mobile — de header heeft al een grote
     visual break onder, extra padding-top maakt content laag op de fold. */
  .breadcrumb{padding:10px 0 4px;font-size:12px}
}

