/* ==========================================================================
   New content sections (Phase 2): channel categories, how-it-works,
   device grid, guarantee band, why-us. Light orange theme, matches tokens.
   ========================================================================== */

/* ---- Channel categories with counts ---- */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.cat-card {
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-lg);
  padding: var(--sp-4);
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.cat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); }
.cat-card__icon {
  width: 50px; height: 50px; border-radius: var(--r-md);
  background: var(--c-tint-1); color: var(--c-accent);
  display: grid; place-items: center; margin-bottom: var(--sp-3);
}
.cat-card__icon svg { width: 26px; height: 26px; }
.cat-card__head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.cat-card__head h3 { font-size: var(--fz-h4); }
.cat-card__count {
  font-family: var(--font-heading); font-weight: 700; font-size: 1.15rem; color: var(--c-primary);
}
.cat-card p { font-size: var(--fz-sm); }
@media (max-width: 980px) { .cat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .cat-grid { grid-template-columns: 1fr; } }

/* ---- How it works (4 steps) ---- */
.how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); counter-reset: step; }
.how-step { position: relative; padding-top: var(--sp-2); text-align: center; }
.how-step__num {
  width: 54px; height: 54px; border-radius: 50%;
  background: var(--c-primary); color: #fff;
  font-family: var(--font-heading); font-weight: 700; font-size: 1.5rem;
  display: grid; place-items: center; margin: 0 auto var(--sp-3);
  box-shadow: var(--shadow-cta);
}
.how-step h3 { font-size: var(--fz-h5); margin-bottom: 6px; }
.how-step p { font-size: var(--fz-sm); }
/* connector line between steps on desktop, centered on the circle (padding-top + radius) */
.how-grid .how-step:not(:last-child)::after {
  content: ""; position: absolute;
  top: calc(var(--sp-2) + 27px); transform: translateY(-50%);
  left: calc(50% + 34px); right: calc(-50% + 34px);
  height: 2px; background: var(--c-tint-2); z-index: 0;
}
.how-step__num { position: relative; z-index: 1; }
@media (max-width: 880px) { .how-grid { grid-template-columns: repeat(2, 1fr); } .how-grid .how-step::after { display: none; } }
@media (max-width: 460px) { .how-grid { grid-template-columns: 1fr; } }

/* ---- Device compatibility grid ---- */
.device-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--sp-3); }
.device-card {
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-2); text-align: center;
  transition: border-color var(--t-fast) var(--ease), transform var(--t-base) var(--ease);
}
.device-card:hover { border-color: var(--c-primary); transform: translateY(-2px); }
.device-card__icon { color: var(--c-accent); display: grid; place-items: center; margin-bottom: 8px; }
.device-card__icon svg { width: 30px; height: 30px; }
.device-card h3 { font-size: 0.95rem; }
.device-card p { font-size: var(--fz-xs); color: var(--c-text-3); margin-top: 2px; }
.device-apps { text-align: center; margin-top: var(--sp-4); color: var(--c-text-2); }
.device-apps strong { color: var(--c-text); }
@media (max-width: 1024px) { .device-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .device-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---- Guarantee / stats band ---- */
.guarantee-band { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); text-align: center; }
.guarantee__big {
  display: block; font-family: var(--font-heading); font-weight: 700;
  font-size: 2.4rem; color: var(--c-primary); line-height: 1.05;
}
.guarantee__title { font-size: var(--fz-h5); margin: 6px 0 4px; }
.guarantee p { font-size: var(--fz-sm); color: var(--c-text-3); }
/* On the dark guarantee band the sub-text must be light, not muted grey */
.section--dark .guarantee p { color: var(--c-on-dark-2); }
@media (max-width: 760px) { .guarantee-band { grid-template-columns: repeat(2, 1fr); } }

/* ---- Why us ---- */
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.why-card { display: flex; flex-direction: column; }
.why-card__icon {
  width: 48px; height: 48px; border-radius: var(--r-md);
  background: var(--c-tint-1); color: var(--c-accent);
  display: grid; place-items: center; margin-bottom: var(--sp-3);
}
.why-card__icon svg { width: 24px; height: 24px; }
.why-card h3 { font-size: var(--fz-h5); margin-bottom: 6px; }
.why-card p { font-size: var(--fz-sm); }
@media (max-width: 880px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .why-grid { grid-template-columns: 1fr; } }

/* ---- Homepage contact block ---- */
.home-contact { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.home-contact__card {
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-lg);
  padding: var(--sp-4); text-align: center;
}
.home-contact__icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--c-tint-1); color: var(--c-accent);
  display: grid; place-items: center; margin: 0 auto var(--sp-3);
}
.home-contact__icon svg { width: 24px; height: 24px; }
.home-contact h3 { font-size: var(--fz-h5); margin-bottom: 4px; }
.home-contact p { font-size: var(--fz-sm); margin-bottom: var(--sp-2); }
@media (max-width: 760px) { .home-contact { grid-template-columns: 1fr; } }

/* ---- City grid (homepage) ---- */
.city-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-3); }
.city-chip {
  display: inline-flex; align-items: center; gap: 10px;
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-md);
  padding: 14px 18px; font-family: var(--font-heading); font-weight: 600;
  color: var(--c-text);
  transition: border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-base) var(--ease);
}
.city-chip svg { width: 18px; height: 18px; color: var(--c-accent); flex: none; }
.city-chip:hover { border-color: var(--c-primary); color: var(--c-accent); transform: translateY(-2px); }
@media (max-width: 880px) { .city-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .city-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---- City page: wijken list ---- */
.wijken-list { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 18px; list-style: none; padding: 0; margin: 0; }
.wijken-list li { position: relative; padding-left: 18px; font-size: var(--fz-sm); color: var(--c-text-2); }
.wijken-list li::before { content: ""; position: absolute; left: 0; top: 9px; width: 6px; height: 6px; border-radius: 50%; background: var(--c-primary); }
@media (max-width: 420px) { .wijken-list { grid-template-columns: 1fr; } }
