/* Shoppo-huisstijl — mobiel-first */
:root {
  --shoppo-blauw: #2590D9;
  --shoppo-oranje: #F5A623;
  --shoppo-donker: #14507A;
  --shoppo-licht: #F1F5F8;
  --shoppo-groen: #1E9E5A;
  --tekst: #24313b;
  --radius: 14px;
}
* { box-sizing: border-box; }
body {
  margin: 0; color: var(--tekst); background: #fff;
  font-family: 'Nunito Sans', 'Segoe UI', -apple-system, sans-serif;
  padding-bottom: 64px; /* ruimte voor onderbalk */
}
h1, h2, h3 { font-family: 'Quicksand', 'Trebuchet MS', sans-serif; color: var(--shoppo-donker); }
a { color: var(--shoppo-blauw); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { max-width: 1080px; margin: 0 auto; padding: 0 14px; }

/* Header met logo, AI-zoekbalk, bell */
.topbar {
  position: sticky; top: 0; z-index: 20; background: #fff;
  border-bottom: 1px solid var(--shoppo-licht);
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
}
.topbar .logo img { height: 34px; display: block; }
.searchwrap { flex: 1; position: relative; }
.searchwrap input {
  width: 100%; padding: 10px 14px 10px 38px; border: 2px solid var(--shoppo-licht);
  border-radius: 999px; background: var(--shoppo-licht); font-size: 15px; outline: none;
}
.searchwrap input:focus { border-color: var(--shoppo-blauw); background: #fff; }
.searchwrap .sparkle { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--shoppo-oranje); font-size: 16px; text-decoration: none; }
.bell { font-size: 20px; background: none; border: none; cursor: pointer; color: var(--shoppo-donker); }

/* Onderbalk met tabs */
.tabbar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 20;
  display: flex; background: #fff; border-top: 1px solid var(--shoppo-licht);
}
.tabbar a {
  flex: 1; text-align: center; padding: 10px 4px 12px; font-size: 12.5px;
  color: #7b8a96; font-weight: 600;
}
.tabbar a.actief { color: var(--shoppo-blauw); }
.tabbar .ticon { display: block; font-size: 20px; }

/* Knoppen & labels */
.btn {
  display: inline-block; background: var(--shoppo-blauw); color: #fff; border: none;
  padding: 10px 18px; border-radius: 999px; font-weight: 700; cursor: pointer; font-size: 15px;
}
.btn:hover { filter: brightness(1.06); text-decoration: none; }
.btn.klein { padding: 6px 12px; font-size: 13px; }
.btn.oranje { background: var(--shoppo-oranje); }
.btn.stil { background: var(--shoppo-licht); color: var(--shoppo-donker); }
.label { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.label.deal { background: var(--shoppo-oranje); color: #fff; }
.label.groen { background: var(--shoppo-groen); color: #fff; }
.label.grijs { background: var(--shoppo-licht); color: var(--shoppo-donker); }

/* Kaarten/grids */
.grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 700px) { .grid { grid-template-columns: repeat(4, 1fr); } }
.kaart {
  background: #fff; border: 1px solid var(--shoppo-licht); border-radius: var(--radius);
  padding: 12px; display: flex; flex-direction: column; gap: 6px;
}
.kaart img.foto { width: 100%; height: 120px; object-fit: contain; background: var(--shoppo-licht); border-radius: 10px; }
.kaart .foto-leeg { width: 100%; height: 120px; display:flex; align-items:center; justify-content:center; background: var(--shoppo-licht); border-radius: 10px; font-size: 34px; }
.kaart .titel { font-weight: 700; color: var(--shoppo-donker); font-size: 14px; }
.kaart .prijs { font-size: 16px; font-weight: 800; }
.kaart .shops { font-size: 12.5px; color: var(--shoppo-groen); font-weight: 600; }

/* Chips (categorieën/thema's) */
.chips { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0; }
.chips a {
  background: var(--shoppo-licht); color: var(--shoppo-donker); padding: 7px 14px;
  border-radius: 999px; font-size: 13.5px; font-weight: 600;
}

/* Offer-tabel op productpagina */
.offers { display: flex; flex-direction: column; gap: 10px; margin: 14px 0; }
.offer {
  display: flex; align-items: center; gap: 12px; border: 1px solid var(--shoppo-licht);
  border-radius: var(--radius); padding: 12px;
}
.offer.top { border-color: var(--shoppo-oranje); background: #fffaf1; }
.offer .winkel { flex: 1; font-weight: 700; color: var(--shoppo-donker); }
.offer .prijs { font-size: 18px; font-weight: 800; }
.offer .uitverkocht { color: #b04a4a; font-size: 13px; }

/* Tabellen (portalen) */
table.data { width: 100%; border-collapse: collapse; font-size: 14px; }
table.data th, table.data td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--shoppo-licht); }
table.data th { color: var(--shoppo-donker); background: var(--shoppo-licht); }

/* Formulieren */
form.net { display: flex; flex-direction: column; gap: 10px; max-width: 420px; }
form.net input, form.net select, form.net textarea {
  padding: 10px 12px; border: 2px solid var(--shoppo-licht); border-radius: 10px;
  font-size: 15px; background: var(--shoppo-licht); outline: none;
}
form.net input:focus { border-color: var(--shoppo-blauw); background: #fff; }
.inline-form { display: inline; }

/* Diversen */
.intro { background: var(--shoppo-licht); border-radius: var(--radius); padding: 14px 16px; line-height: 1.55; }
.faq details { border-bottom: 1px solid var(--shoppo-licht); padding: 8px 0; }
.faq summary { font-weight: 700; color: var(--shoppo-donker); cursor: pointer; }
.melding { background: #eefaf2; border: 1px solid var(--shoppo-groen); border-radius: 10px; padding: 12px 14px; margin: 12px 0; }
.fout { background: #fdeeee; border: 1px solid #b04a4a; border-radius: 10px; padding: 12px 14px; margin: 12px 0; }
.voetnoot { color: #7b8a96; font-size: 12.5px; }
.tagline { color: var(--shoppo-blauw); font-weight: 700; }
.tagline .punt { color: var(--shoppo-oranje); }
.nb-blok { background: var(--shoppo-donker); color: #fff; border-radius: var(--radius); padding: 18px; margin: 22px 0; }
.nb-blok h2 { color: #fff; margin-top: 0; }
.nb-blok form { display: flex; gap: 8px; }
.nb-blok input { flex: 1; padding: 10px 12px; border-radius: 999px; border: none; font-size: 15px; }
.prijshist { font-size: 13px; color: #7b8a96; }
.portaalnav { display: flex; gap: 12px; flex-wrap: wrap; margin: 10px 0 18px; }
.kop-rij { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }

/* Vraag Shoppo — AI-concierge (mobiel-first chat) */
.geo-banner {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  flex-wrap: wrap; background: var(--shoppo-licht); border-radius: var(--radius);
  padding: 10px 14px; margin: 12px 0; font-size: 14px;
}
.geo-banner .geo-knoppen { display: flex; gap: 8px; }
.ask-chat { display: flex; flex-direction: column; gap: 10px; margin: 14px 0; }
.bubble {
  max-width: 92%; padding: 10px 14px; border-radius: var(--radius);
  font-size: 15px; line-height: 1.45; white-space: pre-line;
}
.bubble.user { align-self: flex-end; background: var(--shoppo-blauw); color: #fff; border-bottom-right-radius: 4px; }
.bubble.bot { align-self: flex-start; background: var(--shoppo-licht); color: var(--tekst); border-bottom-left-radius: 4px; }
.bubble.bot .antwoord { margin: 0 0 6px; }
.bubble.bot .bron { margin: 8px 0 0; font-size: 12px; color: #7b8a96; }
.bubble.bot .clarify-q { margin: 0 0 6px; font-weight: 700; color: var(--shoppo-donker); }
.bubble.typing span {
  display: inline-block; width: 7px; height: 7px; margin-right: 4px;
  background: #9db2c0; border-radius: 50%; animation: ask-stip 1s infinite;
}
.bubble.typing span:nth-child(2) { animation-delay: .18s; }
.bubble.typing span:nth-child(3) { animation-delay: .36s; }
@keyframes ask-stip { 0%,60%,100% { opacity: .3; } 30% { opacity: 1; } }
.clarify-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
.clarify-chips .chip {
  background: #fff; border: 1.5px solid var(--shoppo-blauw); color: var(--shoppo-blauw);
  padding: 6px 13px; border-radius: 999px; font-size: 13.5px; font-weight: 700; cursor: pointer;
}
.clarify-chips .chip:hover { background: var(--shoppo-blauw); color: #fff; }
.ask-cards { display: flex; gap: 10px; overflow-x: auto; margin-top: 8px; padding-bottom: 4px; }
.ask-kaart {
  min-width: 170px; max-width: 190px; background: #fff; border: 1px solid #dde7ee;
  border-radius: var(--radius); padding: 10px; display: flex; flex-direction: column;
  gap: 5px; font-size: 13px;
}
.ask-kaart.aanrader { border: 2px solid var(--shoppo-oranje); }
.ask-kaart img.foto { width: 100%; height: 90px; object-fit: contain; background: var(--shoppo-licht); border-radius: 8px; }
.ask-kaart .titel { font-weight: 700; color: var(--shoppo-donker); }
.ask-kaart .prijs { font-size: 15px; font-weight: 800; }
.ask-kaart .winkel { color: #7b8a96; }
.ask-kaart .voucher { color: var(--shoppo-groen); font-weight: 700; }
.ask-kaart .btn { text-align: center; margin-top: 4px; }
.ask-form { display: flex; gap: 8px; margin-top: 10px; }
.ask-form input {
  flex: 1; padding: 11px 16px; border: 2px solid var(--shoppo-licht);
  border-radius: 999px; font-size: 15px; outline: none; background: var(--shoppo-licht);
}
.ask-form input:focus { border-color: var(--shoppo-oranje); background: #fff; }
.ask-voetnoot { font-size: 12px; color: #7b8a96; margin-top: 8px; }

/* Visueel zoeken — zoeken met een foto (/foto-zoeken) */
.searchwrap input { padding-right: 38px; }
.searchwrap .camera { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 16px; text-decoration: none; }
.dropzone {
  border: 2px dashed var(--shoppo-blauw); border-radius: var(--radius);
  background: var(--shoppo-licht); text-align: center; padding: 26px 16px; margin: 14px 0;
}
.dropzone.sleep { border-color: var(--shoppo-oranje); background: #fff7f0; }
.dropzone .dz-icoon { font-size: 40px; }
.dropzone .dz-hint { color: #7b8a96; margin: 8px 0 12px; font-size: 14px; }
.dropzone .dz-knoppen { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.dropzone .dz-knoppen .btn { cursor: pointer; }
.foto-stappen { display: flex; gap: 8px; list-style: none; padding: 0; margin: 14px 0; }
.foto-stappen li {
  flex: 1; text-align: center; font-size: 13px; font-weight: 600; color: #7b8a96;
  background: var(--shoppo-licht); border-radius: 999px; padding: 8px 6px;
}
.foto-stappen li.actief { background: var(--shoppo-oranje); color: #fff; animation: foto-puls 1.1s ease-in-out infinite; }
.foto-stappen li.klaar { background: var(--shoppo-groen); color: #fff; }
@keyframes foto-puls { 0%, 100% { opacity: 1; } 50% { opacity: .6; } }
.foto-fout { background: #fdeeee; border: 1px solid #b04a4a; border-radius: 10px; padding: 12px 14px; margin: 12px 0; }
.herkend { background: #eefaf2; border: 1px solid var(--shoppo-groen); border-radius: 10px; padding: 10px 14px; margin: 12px 0; font-weight: 600; }
.bubble.bot .herkend { margin: 0 0 6px; font-size: 13px; padding: 6px 10px; }
.verfijn-form { margin: 10px 0; }
.foto-acties { display: flex; gap: 8px; margin: 8px 0 14px; }
.ask-form .foto-knop { cursor: pointer; display: flex; align-items: center; }

/* Vergelijker-basics: filter-/sorteerbalk (mobiel-first) */
.filterbalk { margin: 12px 0; }
.filter-rij { display: flex; flex-direction: column; gap: 8px; }
@media (min-width: 700px) { .filter-rij { flex-direction: row; align-items: flex-start; } }
.filter-sorteer { font-size: 13.5px; font-weight: 600; color: var(--shoppo-donker); }
.filter-sorteer select, .filter-panel select {
  padding: 7px 10px; border: 2px solid var(--shoppo-licht); border-radius: 999px;
  background: var(--shoppo-licht); font-size: 13.5px; margin-left: 4px;
}
.filter-panel { flex: 1; border: 1px solid var(--shoppo-licht); border-radius: var(--radius); padding: 8px 12px; }
.filter-panel summary { font-weight: 700; color: var(--shoppo-donker); cursor: pointer; font-size: 13.5px; }
.filter-groepen { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin-top: 10px; }
.filter-groepen fieldset { border: 1px solid var(--shoppo-licht); border-radius: 10px; padding: 8px 10px; min-width: 0; }
.filter-groepen legend { font-size: 12.5px; font-weight: 700; color: var(--shoppo-donker); text-transform: capitalize; }
.filter-groepen input[type=number] { width: 84px; padding: 6px 8px; border: 2px solid var(--shoppo-licht); border-radius: 8px; background: var(--shoppo-licht); }
.filter-optie { display: block; font-size: 13.5px; padding: 2px 0; }
.filter-acties { display: flex; gap: 12px; align-items: center; margin-top: 10px; }

/* Kies-om-te-vergelijken op kaarten + sticky vergelijkbalk */
.kaart-wrap { position: relative; }
.kaart-wrap .kaart { height: 100%; }
.vgl-kies {
  position: absolute; top: 8px; right: 8px; z-index: 2; background: #fff;
  border: 1px solid var(--shoppo-licht); border-radius: 999px; padding: 3px 8px;
  font-size: 12.5px; cursor: pointer; color: var(--shoppo-donker); font-weight: 700;
}
.vgl-kies input { vertical-align: middle; }
.vgl-balk {
  position: fixed; left: 0; right: 0; bottom: 64px; z-index: 25;
  display: flex; gap: 10px; align-items: center; justify-content: center;
  background: var(--shoppo-donker); color: #fff; padding: 10px 14px;
}
.vgl-scroll { overflow-x: auto; }
.vgl-tabel th:first-child { white-space: nowrap; text-transform: capitalize; }
.vgl-tabel td, .vgl-tabel th { vertical-align: top; }

/* Prijsgeschiedenis + "goede prijs?"-oordeel */
.prijsgrafiek { margin: 8px 0; background: var(--shoppo-licht); border-radius: var(--radius); padding: 10px 12px; }
.prijsgrafiek svg { display: block; }
.oordeel { border-radius: 10px; padding: 10px 14px; font-weight: 600; background: var(--shoppo-licht); }
.oordeel.goed { background: #eefaf2; border: 1px solid var(--shoppo-groen); }
.oordeel.hoog { background: #fdf3e6; border: 1px solid var(--shoppo-oranje); }

/* Reviewfoto's */
.reviewfoto { max-width: 84px; max-height: 84px; border-radius: 8px; margin: 4px 6px 0 0; object-fit: cover; background: var(--shoppo-licht); }

/* Fase F — PWA-installatiehint (subtiel, dismissbaar; nooit een native popup)
   + web-push-bel: aan-status in huisstijl-oranje. */
.install-hint {
  position: sticky; top: 0; z-index: 30;
  display: flex; gap: 10px; align-items: center;
  background: var(--shoppo-licht); border-bottom: 1px solid #dbe7f0;
  padding: 8px 12px; font-size: .9em;
}
.install-hint .hint-text { flex: 1; }
.install-hint .hint-action {
  background: var(--shoppo-blauw); color: #fff; border: none;
  border-radius: 8px; padding: 6px 12px; font-weight: 700; cursor: pointer;
}
.install-hint .hint-close {
  background: none; border: none; font-size: 18px; cursor: pointer;
  color: var(--shoppo-donker); padding: 0 4px;
}
#push-bell.push-aan { filter: none; }
#push-bell.push-aan::after {
  content: ""; display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--shoppo-oranje);
  vertical-align: super; margin-left: -6px;
}
