
:root{
  --r2s-lime:#c9ff2f;
  --r2s-lime-dark:#a5e600;
  --r2s-navy:#0b1320;
  --r2s-navy-2:#111b2c;
  --r2s-border:#e8edf5;
  --r2s-text:#0b1320;
  --r2s-muted:#5b677a;
  --r2s-radius:18px;

  /* Brand palette (Return2Sender) */
  --r2s-brand-blue:#0B3C8C;
  --r2s-brand-green:#1EC98A;
  --r2s-brand-bg:#F4F6F8;
  --r2s-brand-text:#1F2937;
}

/* iOS Safari: prevent automatic text resizing that can break button layout */
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;}

/* Base typography for R2S UI */
.r2s-wrap, .r2s-wrap *{
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  box-sizing: border-box;
}

.r2s-wrap{max-width:980px;margin:0 auto;padding:48px 16px;}

/* Ambassador invite banner (homepage when arriving via ?ref=CODE) */
.r2s-invite-banner{max-width:1120px;margin:14px auto 0;padding:0 16px;}
.r2s-invite-inner{display:flex;gap:14px;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--r2s-border);border-radius:18px;box-shadow:0 10px 24px rgba(11,19,32,.06);padding:14px 14px;}
.r2s-invite-title{font-weight:900;color:var(--r2s-brand-text);font-size:15px;line-height:1.2;}
.r2s-invite-sub{color:#6B7280;font-weight:700;font-size:13px;margin-top:2px;}
.r2s-invite-cta{display:flex;gap:10px;align-items:center;position:relative;flex-shrink:0;}
.r2s-invite-arrow{width:42px;height:auto;opacity:.95;transform:translateY(2px);}

@media (max-width:640px){
  .r2s-invite-inner{flex-direction:column;align-items:flex-start;}
  .r2s-invite-cta{width:100%;justify-content:flex-start;}
  .r2s-invite-arrow{position:absolute;right:10px;top:-8px;width:48px;opacity:.9;}
}
.r2s-title{font-size:42px;line-height:1.05;margin:0 0 8px;font-weight:800;color:var(--r2s-text);}
.r2s-sub{margin:0 0 18px;color:var(--r2s-muted);font-size:16px;}
.r2s-h2{font-size:28px;margin:0 0 12px;font-weight:800;}
.r2s-h3{font-size:18px;margin:0 0 10px;font-weight:800;}
.r2s-muted{color:var(--r2s-muted);}
.r2s-muted-dark{color:rgba(255,255,255,.88);}
/* Better readability for small labels and empty-state text */
.r2s-panel-body{color:var(--r2s-brand-text);} 
.r2s-card{color:var(--r2s-brand-text);} 
.r2s-label{font-weight:800;font-size:14px;color:#4B5563;}

/* Abonnement-tab: zorg dat plannaam/empty-title altijd goed leesbaar zijn */
.r2s-sub-plan-title,
.r2s-sub-empty-title{color:var(--r2s-brand-text); opacity:1;}

.r2s-tip{margin-top:14px;color:#6c778a;font-size:14px;}
.r2s-link{color:#2b6cb0;text-decoration:underline;}

.r2s-card{background:transparent;}
.r2s-card--light .r2s-card-inner{background:#fff;border:1px solid var(--r2s-border);}
.r2s-card-inner{border-radius:26px;padding:28px 28px;box-shadow:0 12px 35px rgba(11,19,32,.08);}

.r2s-panel{background:#fff;border:1px solid var(--r2s-border);border-radius:28px;box-shadow:0 14px 40px rgba(11,19,32,.10);overflow:hidden;}
.r2s-tabs{display:flex;gap:10px;padding:18px 18px 0;background:#fff;}
.r2s-tab{display:inline-block;padding:10px 14px;border-radius:12px;color:var(--r2s-brand-blue);text-decoration:none;background:#ffffff;border:1px solid rgba(11,60,140,.22);font-weight:800;}
.r2s-tab:hover{background:#eef3fb;}
.r2s-tab.is-active{background:var(--r2s-brand-green);border-color:var(--r2s-brand-green);color:#ffffff;}
.r2s-panel-body{padding:18px;background:#fff;}
.r2s-panel-footer{padding:14px 18px;background:#f6f8fc;border-top:1px solid var(--r2s-border);}
.r2s-btn-logout{padding:8px 12px;font-size:13px;}

.r2s-alert{padding:12px 14px;border-radius:14px;margin-bottom:14px;font-weight:700;}
.r2s-alert-success{background:#eaffea;border:1px solid #b7f5b7;}
.r2s-alert-warning{background:#fff5db;border:1px solid #ffd48a;}
.r2s-alert-danger{background:#ffe9ee;border:1px solid rgba(239,68,68,.35);color:#1F2937;}
.r2s-alert-danger strong{color:#111827;}


.r2s-btn-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.r2s-btn-stack{display:flex;flex-direction:column;gap:12px;align-items:stretch;}
.r2s-btn-stack .r2s-btn{width:100%;}
.r2s-btn--push-right{margin-left:auto;}
.r2s-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;border-radius:999px;text-decoration:none;font-weight:800;border:1px solid transparent;cursor:pointer;line-height:1;}

/* Force true pill buttons even if the theme overrides anchor styles */
.r2s-btn, .r2s-panel .r2s-btn, .r2s-btn:link, .r2s-btn:visited{border-radius:9999px !important;}

.r2s-btn-primary{background:var(--r2s-brand-green);color:#ffffff;box-shadow:0 10px 28px rgba(30,201,138,.30);}
.r2s-btn-primary:hover{filter:brightness(0.96);}
.r2s-btn-secondary{background:var(--r2s-brand-blue);color:#ffffff;border-color:transparent;box-shadow:0 10px 28px rgba(11,60,140,.18);}
.r2s-btn-secondary:hover{filter:brightness(1.04);}
button.r2s-btn{appearance:none}



/* iOS Safari: prevent automatic text resizing that can push text out of pill buttons */
html{ -webkit-text-size-adjust:100%; }

.r2s-form{margin-top:10px;}
.r2s-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px;}
.r2s-field{flex:1;min-width:240px;}
.r2s-field label{display:block;font-weight:800;margin:0 0 8px;color:#0b1320;}
.r2s-field input,.r2s-field select,.r2s-field textarea{
  width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--r2s-border);background:#fff;
  outline:none;
}
.r2s-field textarea{resize:vertical;}
.r2s-help{margin:8px 0 0;color:#6c778a;font-size:13px;}

.r2s-radio{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
.r2s-radio label{font-weight:700;margin:0;display:flex;gap:8px;align-items:center;}

.r2s-kv{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px;}
.r2s-kv div{padding:12px 14px;border:1px solid var(--r2s-border);border-radius:14px;background:#f8fbff;}
.r2s-kv span{display:block;color:#6c778a;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;}
.r2s-kv strong{font-size:15px;}

.r2s-placeholder{padding:14px;border:1px dashed #cfd8ea;border-radius:14px;background:#f8fbff;}

.r2s-wizard{background:linear-gradient(180deg,var(--r2s-navy),var(--r2s-navy-2));border-radius:28px;box-shadow:0 14px 40px rgba(0,0,0,.22);overflow:hidden;}
.r2s-wizard-head{padding:22px 22px 0;color:#fff;}
.r2s-wizard-head .r2s-h2{color:#fff;}
.r2s-steps{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;padding-bottom:14px;}
.r2s-step{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);color:#cfe0ff;font-weight:800;font-size:13px;}
.r2s-step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  font-family:inherit;
  line-height:1;
}
.r2s-step:focus{outline:2px solid rgba(11,60,140,.35); outline-offset:2px;}
.r2s-step.is-active{background:rgba(201,255,47,.14);border-color:rgba(201,255,47,.45);color:#eaffb8;}
.r2s-wizard-body{padding:18px;background:rgba(0,0,0,.0);color:#fff;}
.r2s-wizard-body .r2s-field label{color:#fff;}
.r2s-wizard-body .r2s-field input,.r2s-wizard-body .r2s-field select,.r2s-wizard-body .r2s-field textarea{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#fff;}
.r2s-wizard-body .r2s-help{color:rgba(255,255,255,.7);}
.r2s-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:10px 0 16px;}
@media (max-width:720px){.r2s-grid{grid-template-columns:1fr}.r2s-kv{grid-template-columns:1fr}}
.r2s-checkcard{display:flex;gap:10px;align-items:center;padding:14px 14px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);cursor:pointer;font-weight:900;}
.r2s-checkcard input{width:16px;height:16px;}
.r2s-summary{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;}
.r2s-summary .r2s-h3{color:#fff;}
.r2s-summary .r2s-placeholder{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#fff;}


/* --- v1.3.3 fixes: dropdown readability + focus styles --- */
.r2s-card, .r2s-card-inner, .r2s-wizard, .r2s-wizard * { box-sizing: border-box; }

.r2s-btn:focus, .r2s-btn:focus-visible,
.r2s-card a:focus, .r2s-card a:focus-visible{
  outline: none !important;
}

.r2s-wizard-body .r2s-field select,
.r2s-wizard-body .r2s-field input[type="date"],
.r2s-wizard-body .r2s-field input[type="time"],
.r2s-wizard-body .r2s-field input[type="text"],
.r2s-wizard-body .r2s-field textarea{
  background:#ffffff !important;
  color:#0b1220 !important;
  border:1px solid rgba(11,18,32,.15) !important;
  border-radius:16px !important;
}

.r2s-wizard-body .r2s-field select option{
  background:#ffffff !important;
  color:#0b1220 !important;
}

/* Make native date picker icon visible on dark backgrounds (Chrome/Safari) */
.r2s-wizard-body input[type="date"]::-webkit-calendar-picker-indicator{
  opacity: 1;
  cursor: pointer;
}

/* Avoid weird theme borders around our main blocks */
.r2s-panel, .r2s-card-inner, .r2s-wizard { border: 0 !important; }


/* --------------------------------------------------------------------------
   Step 5 — Wizard (Nieuw ophaalverzoek) light theme
   Match the fresh "Mijn omgeving" look using brand palette.
   -------------------------------------------------------------------------- */

/* Main container */
.r2s-wizard{
  background: var(--r2s-brand-bg) !important;
  box-shadow: 0 14px 40px rgba(11,19,32,.10) !important;
}

/* Head */
.r2s-wizard-head{
  color: #fff !important;
}
.r2s-wizard-head .r2s-h2{
  color: var(--r2s-brand-text) !important;
}

/* Step pills */
.r2s-step{
  background: rgba(11,60,140,.14) !important;
  border: 1px solid rgba(11,60,140,.35) !important;
  color: #fff !important;
}
.r2s-step.is-active{
  background: rgba(30,201,138,1) !important;
  border-color: rgba(30,201,138,.70) !important;
  color: var(--r2s-brand-text) !important;
}

/* Body */
.r2s-wizard-body{
  color: var(--r2s-brand-text) !important;
}
.r2s-wizard-body .r2s-help{
  color: rgba(31,41,55,.75) !important;
}

/* Inputs */
.r2s-wizard-body .r2s-field label{ color: var(--r2s-brand-text) !important; }
.r2s-wizard-body .r2s-field input,
.r2s-wizard-body .r2s-field select,
.r2s-wizard-body .r2s-field textarea{
  background: #fff !important;
  border: 1px solid rgba(11,60,140,.16) !important;
  color: var(--r2s-brand-text) !important;
}

/* Carrier tiles (checkbox cards) */
.r2s-checkcard{
  background: #fff !important;
  border: 1px solid rgba(11,60,140,.16) !important;
  color: var(--r2s-brand-text) !important;
}
.r2s-checkcard:hover{
  border-color: rgba(30,201,138,.55) !important;
  box-shadow: 0 10px 20px rgba(11,19,32,.06) !important;
}
.r2s-wizard input[type="checkbox"]{ accent-color: var(--r2s-brand-green); }


/* Make checkboxes look like small oval toggles */
.r2s-checkcard{
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 14px !important;
}
.r2s-checkcard input[type="checkbox"]{
  position:absolute !important;
  opacity:0 !important;
  width:1px !important;
  height:1px !important;
  pointer-events:none !important;
}
.r2s-checkcard span{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  font-weight:700 !important;
}
.r2s-checkcard span:before{
  content:"";
  width:14px;
  height:14px;
  border-radius:999px;
  border:2px solid rgba(11,60,140,.35);
  background:#fff;
  box-shadow:0 1px 2px rgba(11,19,32,.06);
  flex:0 0 14px;
}
.r2s-checkcard input[type="checkbox"]:checked + span:before{
  background: var(--r2s-brand-green);
  border-color: var(--r2s-brand-green);
  box-shadow:0 0 0 4px rgba(30,201,138,.18);
}
.r2s-checkcard input[type="checkbox"]:checked + span{
  color: var(--r2s-brand-text) !important;
}
.r2s-checkcard:has(input[type="checkbox"]:checked){
  border-color: rgba(30,201,138,.55) !important;
  background: rgba(30,201,138,.06) !important;
}
.r2s-checkcard:has(input[type="checkbox"]:focus-visible){
  box-shadow: 0 0 0 4px rgba(11,60,140,.12) !important;
}

/* Summary boxes */
.r2s-summary{
  background: #fff !important;
  border: 1px solid rgba(11,60,140,.16) !important;
}
.r2s-summary .r2s-h3{ color: var(--r2s-brand-text) !important; }
.r2s-summary .r2s-placeholder{
  background: var(--r2s-brand-bg) !important;
  border-color: rgba(11,60,140,.14) !important;
  color: var(--r2s-brand-text) !important;
}

/* Confirmation step: show summary lines as pill rows */
.r2s-summary-pills{display:flex;flex-direction:column;gap:10px;}
.r2s-pill{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px;
  background:#fff;
  border:1px solid rgba(11,60,140,.14);
  border-radius:999px;
  box-shadow:0 1px 2px rgba(11,19,32,.05);
}
.r2s-pill-label{font-weight:800;color:var(--r2s-brand-text);white-space:nowrap;}
.r2s-pill-value{color:var(--r2s-brand-text);opacity:.9;text-align:right;max-width:68%;word-break:break-word;}

@media (max-width: 720px){
  .r2s-pill{border-radius:18px;}
  .r2s-pill-label{font-size:13px;}
  .r2s-pill-value{font-size:13px;max-width:62%;}
}

/* Wizard buttons */
.r2s-wizard .r2s-btn,
.r2s-wizard .r2s-btn-primary,
.r2s-wizard .r2s-btn-secondary{
  border-radius: 999px !important; /* force pill on all devices/themes (incl. blue "Terug") */
}
.r2s-wizard .r2s-btn-primary{
  background: var(--r2s-brand-green) !important;
  color: #fff !important;
  box-shadow: 0 10px 28px rgba(30,201,138,.22) !important;
}
.r2s-wizard .r2s-btn-primary:hover{ filter: brightness(.95); }

.r2s-wizard .r2s-btn-secondary{
  background: var(--r2s-brand-blue) !important;
  color: #fff !important;
  border-color: transparent !important;
}
.r2s-wizard .r2s-btn-secondary:hover{ filter: brightness(.95); }

/* Mobile spacing inside the wizard */
@media (max-width: 720px){
  .r2s-wizard-head{ padding: 16px 16px 0 !important; }
  .r2s-wizard-body{ padding: 14px !important; }
}




/* --- My pickups list --- */
.r2s-table-wrap{overflow:auto;margin-top:14px;border:1px solid rgba(255,255,255,.10);border-radius:14px;}
.r2s-table{width:100%;border-collapse:collapse;font-size:14px;}
.r2s-table th,.r2s-table td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10);text-align:left;white-space:nowrap;}
.r2s-table th{color:#fff;font-weight:700;background:rgba(255,255,255,.04);}
.r2s-badge{display:inline-block;padding:4px 10px;border-radius:999px;background:rgba(200,255,47,.20);border:1px solid rgba(200,255,47,.35);color:#fff;font-weight:700;}
.r2s-alert a{color:#0b1220;font-weight:800;text-decoration:underline;}


/* Status badges */
.r2s-badge.r2s-status-in_behandeling{border-color:rgba(255,255,255,.25);}
.r2s-badge.r2s-status-gepland{border-color:rgba(200,255,47,.6);}
.r2s-badge.r2s-status-onderweg{border-color:rgba(0,180,255,.6);}
.r2s-badge.r2s-status-afgerond{border-color:rgba(60,220,120,.6);}



/* =========================================================
   R2S Styling polish (v1.4.5) — higher contrast + R2S look
   (Only visual overrides; no functional changes)
========================================================= */
.r2s-wrap{max-width:980px;margin:0 auto;padding:56px 16px;}
/* Light card (dashboard / mijn gegevens) */
.r2s-card--light .r2s-card-inner{
  background:#ffffff;
  border:1px solid rgba(11,19,32,.10);
  box-shadow:0 18px 50px rgba(11,19,32,.10);
}
.r2s-title{color:#0b1320 !important;letter-spacing:-0.02em;}
.r2s-sub,.r2s-tip{color:rgba(11,19,32,.75) !important;}
/* Alerts: always readable */
.r2s-alert{
  border-radius:16px;
  padding:14px 16px;
  font-weight:700;
  line-height:1.3;
}
.r2s-alert a{color:inherit;text-decoration:underline;}
.r2s-alert-success{
  background:rgba(201,255,47,.22);
  border:1px solid rgba(165,230,0,.45);
  color:#0b1320;
}
.r2s-alert-warning{
  background:#fff4cf;
  border:1px solid rgba(245,158,11,.35);
  color:#0b1320;
}
.r2s-alert-info{
  background:#e7f3ff;
  border:1px solid rgba(59,130,246,.25);
  color:#0b1320;
}
/* Buttons: R2S pill look */
.r2s-btn{
  border-radius:999px;
  padding:12px 18px;
  font-weight:800;
  letter-spacing:.01em;
  box-shadow:none;
  font-size:14px;
  line-height:1.1;
}



.r2s-btn-primary{
  background:var(--r2s-brand-green);
  color:#ffffff;
  border:1px solid rgba(11,19,32,.08);
}
.r2s-btn-primary:hover{filter:brightness(0.95);}
.r2s-btn-secondary{
  background:var(--r2s-brand-blue);
  color:#ffffff;
  border:1px solid rgba(11,60,140,.10);
}
.r2s-btn-secondary:hover{filter:brightness(1.05);}
.r2s-btn[disabled], .r2s-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
  filter:none;
}

/* In the wizard we keep disabled buttons readable ("Terug" in step 1) */
.r2s-wizard .r2s-btn:disabled,
.r2s-wizard .r2s-btn[disabled]{
  opacity: 1;
}

/* Typography: less "WP-ish" in forms */
.r2s-field input,
.r2s-field select,
.r2s-field textarea{
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
}
.r2s-wizard .r2s-btn-secondary[disabled],
.r2s-wizard .r2s-btn-secondary:disabled{
  background:#f6f8fc;
  border-color:var(--r2s-border);
  color:#6c778a;
}
.r2s-btn:focus{outline:none;box-shadow:0 0 0 4px rgba(201,255,47,.25);}

/* We keep everything light (Picnic-ish) – forms are naturally readable */
.r2s-field select option{color:#0b1320;background:#ffffff;}

/* Tables: spacing + zebra for readability */
.r2s-table-wrap{overflow:auto;}
.r2s-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
}
.r2s-table th{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--r2s-muted);
  padding:10px 12px;
  border-bottom:1px solid var(--r2s-border);
}
.r2s-table td{
  padding:12px 12px;
  border-bottom:1px solid var(--r2s-border);
  color:var(--r2s-text);
}
.r2s-table tr:nth-child(even) td{background:#f6f8fc;}

/* ====== Mijn ophaalverzoeken (cards instead of table) ====== */
.r2s-pickup-cards{
  margin-top:14px;
  margin-bottom:18px; /* space before back button */
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
}

.r2s-pickup-card{
  background:#ffffff;
  border:1px solid var(--r2s-border);
  border-radius:18px;
  padding:14px;
  box-shadow:0 10px 22px rgba(11,19,32,.06);
}

.r2s-pickup-card__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}

.r2s-pickup-card__title{
  font-weight:900;
  color:#0F172A;
  font-size:16px;
  opacity:1;
}

.r2s-pickup-card__meta{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
}

.r2s-pickup-pill{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border:1px solid #E5E7EB;
  border-radius:999px;
  background:#FFFFFF;
  width: 230px; /* uniform pill width */
  max-width: 100%;
}

@media (max-width: 480px){
  .r2s-pickup-pill{width:100%;}
}

.r2s-pickup-pill__label{
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#64748B;
  opacity:1;
}

.r2s-pickup-pill__value{
  font-weight:700;
  color:#1F2937;
  opacity:1;
}

@media (min-width: 820px){
  .r2s-pickup-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Status badges */
.r2s-badge{border-radius:999px;padding:7px 10px;font-weight:800;font-size:12px;}
.r2s-badge--in_behandeling{background:#fff5db;border:1px solid #ffd48a;color:#0b1320;}
.r2s-badge--gepland{background:#e7f0ff;border:1px solid #b6d2ff;color:#0b1320;}
.r2s-badge--onderweg{background:#f3e8ff;border:1px solid #d8b4fe;color:#0b1320;}
.r2s-badge--afgerond{background:#eaffea;border:1px solid #b7f5b7;color:#0b1320;}

/* Backwards compat: older markup uses r2s-status-* */
.r2s-badge.r2s-status-in_behandeling{background:#fff5db;border:1px solid #ffd48a;color:#0b1320;}
.r2s-badge.r2s-status-gepland{background:#e7f0ff;border:1px solid #b6d2ff;color:#0b1320;}
.r2s-badge.r2s-status-onderweg{background:#f3e8ff;border:1px solid #d8b4fe;color:#0b1320;}
.r2s-badge.r2s-status-afgerond{background:#eaffea;border:1px solid #b7f5b7;color:#0b1320;}

/* Cards inside panels should never inherit a dark background */
.r2s-panel-body .r2s-card{
  background:#ffffff;
  border:1px solid var(--r2s-border);
  border-radius:22px;
  padding:22px;
  box-shadow:0 10px 24px rgba(11,19,32,.06);
}

/* Admin metabox readability (WP backend) */
#r2s_pickup_details .inside table{width:100%;}
#r2s_pickup_details .inside td{padding:8px 10px;}


/* Danger button (used for unsubscribe confirm) */
.r2s-btn-danger{background:#b00020;color:#fff;border-color:#b00020;}
.r2s-btn-danger:hover{filter:brightness(0.95);} 


/* v159: lichter beheerblok op abonnementen */
.r2s-manage-card .r2s-card-inner{padding:22px 22px;}
.r2s-manage-card .r2s-btn-row{gap:10px;}
.r2s-manage-card .r2s-btn-link{padding:10px 14px;}

/* ====== R2S Subscription / Abonnementen polish (v161) ====== */
/* Link-button used for subtle actions like 'Abonnement opzeggen' */
.r2s-btn-link{
  background:transparent;
  border-color:transparent;
  color:#2b6cb0;
  padding:10px 10px;
  font-weight:800;
  text-decoration:underline;
  box-shadow:none;
}
.r2s-btn-link:hover{opacity:.85;}

/* Manage header on /abonnementen/ */
.r2s-manage-card .r2s-card-inner{
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff,#fbfcff);
  border:1px solid #e6ecf7;
  box-shadow:0 10px 28px rgba(11,19,32,.06);
}
.r2s-manage-card strong{font-size:15px;}

/* v162: new subscription manage header (cleaner) */
.r2s-sub-manage{max-width:980px;margin:0 auto;padding:0 16px;}
.r2s-sub-manage-inner{
  background:linear-gradient(180deg,#ffffff,#fbfcff);
  border:1px solid #e6ecf7;
  border-radius:22px;
  box-shadow:0 10px 28px rgba(11,19,32,.06);
  padding:18px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.r2s-sub-manage-title{font-weight:900;color:var(--r2s-text);}
.r2s-sub-manage-sub{color:#6c778a;font-size:13px;margin-top:2px;}
.r2s-sub-manage-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
@media (max-width:620px){
  .r2s-sub-manage-actions{width:100%;}
  .r2s-sub-manage-actions .r2s-btn{flex:1;}


}

/* Abonnementen Manager layout */
.r2s-abos{max-width:980px;margin:0 auto;padding:26px 16px;}
.r2s-abo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;align-items:stretch;}
@media (max-width: 920px){
  .r2s-abo-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 620px){
  .r2s-abo-grid{grid-template-columns:1fr;}
}

.r2s-abo-card{
  background:#fff;
  border:1px solid var(--r2s-border);
  border-radius:22px;
  box-shadow:0 12px 35px rgba(11,19,32,.06);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:100%;
}

.r2s-abo-card h3,
.r2s-abo-card h2,
.r2s-abo-card h1{margin:0;}

.r2s-abo-card .r2s-abo-content{padding:18px 18px 16px;}
.r2s-abo-card .r2s-abo-price{padding:16px 18px 0;}
.r2s-abo-card .r2s-amount{font-size:22px;font-weight:900;}
.r2s-abo-card .r2s-period{color:#6c778a;font-weight:700;margin-left:6px;}

.r2s-abo-card .r2s-abo-features{margin:10px 0 0;padding-left:18px;}
.r2s-abo-card .r2s-abo-features li{margin:6px 0;}

.r2s-abo-card .r2s-abo-choose-form{margin-top:auto;padding:16px 18px 18px;}
.r2s-abo-card .r2s-abo-choose-form .r2s-btn{width:100%;}



/* Make the chosen plan feel highlighted (if manager adds an active class) */
.r2s-abo-card.is-current,
.r2s-abo-card.current,
.r2s-abo-card[data-current="1"]{
  border-color:rgba(201,255,47,.65);
  box-shadow:0 14px 45px rgba(201,255,47,.18);
}

/* Slightly soften the heavy dark tab header (keeps brand but less harsh) */
.r2s-panel{box-shadow:0 10px 28px rgba(11,19,32,.16);}
.r2s-tabs{padding:16px 16px 0;}
.r2s-tab{border-radius:14px;}

/* Reduce giant empty feel on wide screens */
.r2s-wrap{padding-top:34px;}

/* =========================================================
   R2S Visual polish pack (v163)
   Goal: more "Picnic/R2S" feel — cleaner, lighter, consistent.
   (CSS-only)
========================================================= */

/* Subscription manage header: smaller, cleaner, less boxy */
.r2s-sub-manage{padding:0 16px;margin:14px auto 18px;}
.r2s-sub-manage-inner{
  max-width:760px;
  margin:0 auto;
  padding:16px 16px;
  border-radius:20px;
  background:#ffffff;
  border:1px solid rgba(11,19,32,.10);
  box-shadow:0 16px 50px rgba(11,19,32,.10);
  /* iOS Safari hit-testing fix:
     Sometimes a flex-wrap container can end up "covering" the content below,
     causing taps on the plan buttons to do nothing. We allow clicks only on
     the actual action buttons. */
  pointer-events:none;
}
.r2s-sub-manage-title{font-size:15px;letter-spacing:-.01em;}
.r2s-sub-manage-sub{display:none;}

/* Re-enable pointer events for the real clickable elements */
.r2s-sub-manage-inner a,
.r2s-sub-manage-inner button{
  pointer-events:auto;
}

/* Make sure the manage buttons render correctly on iPhone (text stays inside) */
.r2s-sub-manage-actions .r2s-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1.2;
  min-height:44px; /* iOS tap target */
  white-space:nowrap;
}



/* Make "Terug" feel like a calm secondary, and "opzeggen" like a soft ghost action */
.r2s-sub-manage-actions .r2s-btn-secondary{
  background:#ffffff;
  color:#0b1320;
  border-color:rgba(11,19,32,.18);
}
.r2s-sub-manage-actions .r2s-btn-secondary:hover{background:#f6f8fc;}

.r2s-btn-link{
  background:transparent;
  border:1px solid #ffb4bb;
  color:#b00020;
  text-decoration:none;
  padding:12px 16px;
}
.r2s-btn-link:hover{background:#fff5f6;opacity:1;}

/* Abonnement cards: align CTA at bottom & improve rhythm */
.r2s-abo-card{border-radius:22px;}
.r2s-abo-card .r2s-abo-content{padding:18px 18px 10px;}
.r2s-abo-card .r2s-abo-price{padding:18px 18px 0;}
.r2s-abo-card .r2s-btn-row{margin-top:auto;padding:14px 18px 18px;}
.r2s-abo-card .r2s-btn-row .r2s-btn{width:100%;}



/* Headline spacing on subscription page (avoid huge top whitespace) */
.r2s-abos{padding-top:18px;}

/* Success message on plans page: make it look like R2S alert */
.r2s-abos .notice, .r2s-abos .updated, .r2s-abos .error{
  margin:0 0 14px !important;
  padding:14px 16px !important;
  border-radius:16px !important;
  border:1px solid rgba(165,230,0,.45) !important;
  background:rgba(201,255,47,.18) !important;
  color:#0b1320 !important;
  box-shadow:0 10px 28px rgba(11,19,32,.06);
}


/* --- Label scan block --- */
.r2s-scan-card{padding:14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);margin-top:12px}
.r2s-scan-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.r2s-scan-reader-wrap{margin-top:10px;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18)}
#r2s-scan-reader{width:100%}


/* Hide native file input (we trigger it via button) */
.r2s-hidden-file{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;}


/* Hide native file input (we trigger it via the green button) */
#r2s-label-photo{display:none !important;}

/* -------------------------
   Mobile responsiveness
   (safe CSS-only overrides)
-------------------------- */
@media (max-width: 520px){
  /* Global: prevent horizontal overflow */
  .r2s-wrap{padding-left:0 !important; padding-right:0 !important;}
  .r2s-panel{border-radius:16px;}
  .r2s-tabs{padding:12px 12px 0; flex-wrap:wrap;}
  .r2s-panel-body{padding:12px;}
  .r2s-panel-footer{padding:12px;}

  /* Headings scale down */
  .r2s-h1{font-size:30px; line-height:1.05;}
  .r2s-h2{font-size:22px; line-height:1.12;}

  /* Form rows: one column */
  .r2s-row{gap:12px;}
  .r2s-field{min-width:0 !important; flex: 1 1 100%;}

  /* Button rows: stack & full width */
  .r2s-btn-row{flex-direction:column; align-items:stretch;}
  .r2s-btn{width:100%; justify-content:center;}



  /* Tabs: allow wrapping without crushing */
  .r2s-tab{flex: 1 1 auto;}

  /* Wizard: reduce padding */
  .r2s-wizard{border-radius:20px;}
  .r2s-wizard-head{padding:16px 16px 0;}
  .r2s-wizard-body{padding:14px;}
  .r2s-steps{gap:8px;}
  .r2s-step{font-size:12px; padding:7px 10px;}

  /* Scan/upload actions */
  .r2s-scan-actions{flex-direction:column; align-items:stretch;}

  /* Media elements never overflow */
  .r2s-wrap img, .r2s-wrap video, .r2s-wrap canvas{max-width:100%; height:auto;}
}

/* -------------------------------------------------
   A2HS Modal (Add to Home Screen)
------------------------------------------------- */
.r2s-modal{position:fixed;inset:0;display:none;z-index:99999;align-items:center;justify-content:center;}
.r2s-modal.is-open{display:flex;}
.r2s-modal-overlay{position:fixed;inset:0;background:transparent;z-index:9998;}
.r2s-modal-card{z-index:9999;position:relative;max-width:520px;margin:0 auto;top:14vh;background:#fff;border-radius:18px;box-shadow:0 20px 70px rgba(0,0,0,.25);padding:18px 18px 16px;}
.r2s-modal-close{position:absolute;top:10px;right:10px;border:none;background:transparent;font-size:18px;line-height:1;padding:8px;border-radius:999px;cursor:pointer;color:#111827;}
.r2s-modal-close:active{transform:scale(.98);}

.r2s-a2hs-steps{margin:10px 0 0 18px;padding:0;}
.r2s-a2hs-steps li{margin:6px 0;}

/* Android manual instructions should look like helpful info — not a "button" */
.r2s-a2hs-info{background:#F4F6F8;border:1px solid rgba(31,41,55,.10);border-radius:16px;padding:12px 12px 10px;}
.r2s-a2hs-info-title{font-weight:700;color:#1F2937;margin-bottom:2px;}
.r2s-a2hs-info .r2s-a2hs-steps{margin-top:8px;}

@media (max-width:520px){
  .r2s-modal-card{z-index:9999;margin:0 14px;top:10vh;padding:16px 16px 14px;}
}

/* -------------------------
   Subgate ("Abonnement nodig")
   Keep the two action buttons nicely centered (also on mobile)
-------------------------- */
.r2s-subgate-actions{justify-content:center;}
.r2s-subgate-actions .r2s-btn{min-width:170px;}



@media (max-width: 520px){
  /* Override the global mobile rule that makes all buttons full-width */
  .r2s-subgate-actions{flex-direction:row; align-items:center; justify-content:center;}
  .r2s-subgate-actions .r2s-btn{width:auto;}


}


/* =========================================================
   Step 1 (Login / Account) — fresher light block + brand buttons
   Only visual changes. Scoped to: .r2s-wrap > .r2s-card
========================================================= */
.r2s-wrap > .r2s-card{
  background: var(--r2s-brand-bg);
  border-radius: 28px;
  padding: 56px 16px;
}

.r2s-wrap > .r2s-card .r2s-card-inner{
  max-width: 760px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(31,41,55,.10);
  box-shadow: 0 18px 50px rgba(11,19,32,.10);
}

.r2s-wrap > .r2s-card .r2s-h2,
.r2s-wrap > .r2s-card .r2s-content,
.r2s-wrap > .r2s-card p{
  color: var(--r2s-brand-text);
}

.r2s-wrap > .r2s-card .r2s-btn-row{gap:12px;}

/* Brand buttons (only in the login card) */
.r2s-wrap > .r2s-card .r2s-btn-primary{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
}
.r2s-wrap > .r2s-card .r2s-btn-primary:hover{
  filter: brightness(0.95);
}

.r2s-wrap > .r2s-card .r2s-btn-secondary{
  background: var(--r2s-brand-blue) !important;
  color: #ffffff !important;
  border-color: rgba(11,60,140,.12) !important;
  box-shadow: 0 12px 30px rgba(11,60,140,.18) !important;
}
.r2s-wrap > .r2s-card .r2s-btn-secondary:hover{
  filter: brightness(1.05);
}

@media (max-width: 720px){
  .r2s-wrap > .r2s-card{padding: 28px 12px; border-radius: 22px;}
  .r2s-wrap > .r2s-card .r2s-card-inner{padding: 22px 18px; border-radius: 20px;}
}

/*
  Fix: logged-out login card is returned without the .r2s-wrap wrapper
  (see ensure_logged_in_or_login_card()).
  So we also style the base .r2s-card when the visitor is NOT logged in.
  This keeps logged-in pages (which use .r2s-wrap) unchanged.
*/
body:not(.logged-in) .r2s-card{
  background: var(--r2s-brand-bg);
  border-radius: 28px;
  padding: 56px 16px;
}

body:not(.logged-in) .r2s-card .r2s-card-inner{
  max-width: 760px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(31,41,55,.10);
  box-shadow: 0 18px 50px rgba(11,19,32,.10);
}

body:not(.logged-in) .r2s-card .r2s-h2,
body:not(.logged-in) .r2s-card .r2s-content,
body:not(.logged-in) .r2s-card p{
  color: var(--r2s-brand-text);
}

body:not(.logged-in) .r2s-card .r2s-btn-row{gap:12px;}

/* v177 — Logged-out CTA buttons (mobile) should always fit inside the card */
body:not(.logged-in) .r2s-card .r2s-btn-row{
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}
body:not(.logged-in) .r2s-card .r2s-btn-row .r2s-btn{
  box-sizing: border-box;
  max-width: 100%;
}



@media (max-width: 600px){
  body:not(.logged-in) .r2s-card .r2s-btn-row{
    flex-direction: column;
  }
  body:not(.logged-in) .r2s-card .r2s-btn-row .r2s-btn{
    width: 100%;
  }


}

/* Logged-out CTA (e.g. header/top button) should match brand green */
body:not(.logged-in) .r2s-btn-primary{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
}
body:not(.logged-in) .r2s-btn-primary:hover{filter: brightness(0.95);}

/* Brand buttons (logged-out login card) */
body:not(.logged-in) .r2s-card .r2s-btn-primary{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
}
body:not(.logged-in) .r2s-card .r2s-btn-primary:hover{filter: brightness(0.95);}

body:not(.logged-in) .r2s-card .r2s-btn-secondary{
  background: var(--r2s-brand-blue) !important;
  color: #ffffff !important;
  border-color: rgba(11,60,140,.12) !important;
  box-shadow: 0 12px 30px rgba(11,60,140,.18) !important;
}
body:not(.logged-in) .r2s-card .r2s-btn-secondary:hover{filter: brightness(1.05);}

@media (max-width: 720px){
  body:not(.logged-in) .r2s-card{padding: 28px 12px; border-radius: 22px;}
  body:not(.logged-in) .r2s-card .r2s-card-inner{padding: 22px 18px; border-radius: 20px;}
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) force to brand green */
header a.wp-block-button__link[href*="/pakketomgeving"],
header a.button[href*="/pakketomgeving"],
header a.btn[href*="/pakketomgeving"],
header a.elementor-button[href*="/pakketomgeving"],
header a[role="button"][href*="/pakketomgeving"],
.site-header a.wp-block-button__link[href*="/pakketomgeving"],
.site-header a.button[href*="/pakketomgeving"],
.site-header a.btn[href*="/pakketomgeving"],
.site-header a.elementor-button[href*="/pakketomgeving"],
.site-header a[role="button"][href*="/pakketomgeving"],
.wp-site-blocks header a.wp-block-button__link[href*="/pakketomgeving"],
.wp-site-blocks header a.button[href*="/pakketomgeving"],
.wp-site-blocks header a.btn[href*="/pakketomgeving"],
.wp-site-blocks header a.elementor-button[href*="/pakketomgeving"],
.wp-site-blocks header a[role="button"][href*="/pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  border-color: rgba(0,0,0,.06) !important;
  color: #ffffff !important;
}

/* v219: Mobile header CTA "Mijn pakketomgeving" should stay a compact pill (no multi-line wrap) */
header a.wp-block-button__link[href*="/pakketomgeving"],
header a.button[href*="/pakketomgeving"],
header a.btn[href*="/pakketomgeving"],
header a.elementor-button[href*="/pakketomgeving"],
header a[role="button"][href*="/pakketomgeving"],
.site-header a.wp-block-button__link[href*="/pakketomgeving"],
.site-header a.button[href*="/pakketomgeving"],
.site-header a.btn[href*="/pakketomgeving"],
.site-header a.elementor-button[href*="/pakketomgeving"],
.site-header a[role="button"][href*="/pakketomgeving"],
.wp-site-blocks header a.wp-block-button__link[href*="/pakketomgeving"],
.wp-site-blocks header a.button[href*="/pakketomgeving"],
.wp-site-blocks header a.btn[href*="/pakketomgeving"],
.wp-site-blocks header a.elementor-button[href*="/pakketomgeving"],
.wp-site-blocks header a[role="button"][href*="/pakketomgeving"]{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  width: auto !important;
  line-height: 1.1 !important;
}

@media (max-width: 600px){
  header a.wp-block-button__link[href*="/pakketomgeving"],
  header a.button[href*="/pakketomgeving"],
  header a.btn[href*="/pakketomgeving"],
  header a.elementor-button[href*="/pakketomgeving"],
  header a[role="button"][href*="/pakketomgeving"],
  .site-header a.wp-block-button__link[href*="/pakketomgeving"],
  .site-header a.button[href*="/pakketomgeving"],
  .site-header a.btn[href*="/pakketomgeving"],
  .site-header a.elementor-button[href*="/pakketomgeving"],
  .site-header a[role="button"][href*="/pakketomgeving"],
  .wp-site-blocks header a.wp-block-button__link[href*="/pakketomgeving"],
  .wp-site-blocks header a.button[href*="/pakketomgeving"],
  .wp-site-blocks header a.btn[href*="/pakketomgeving"],
  .wp-site-blocks header a.elementor-button[href*="/pakketomgeving"],
  .wp-site-blocks header a[role="button"][href*="/pakketomgeving"]{
    font-size: 14px !important;
    padding: 10px 14px !important;
    border-radius: 999px !important;
    max-width: calc(100vw - 24px) !important;
  }
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) header a.button[href*="/pakketomgeving"],
body:not(.logged-in) header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.button[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a[role="button"][href*="/pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  text-decoration: none !important;
}

body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"]:hover,
body:not(.logged-in) .wp-site-blocks header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .wp-site-blocks header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .wp-site-blocks header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .wp-site-blocks header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .wp-site-blocks header a[role="button"][href*="/pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) header a.button[href*="/pakketomgeving"],
body:not(.logged-in) header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.button[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) .wp-site-blocks header a[role="button"][href*="/pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  border-color: rgba(0,0,0,.06) !important;
  color: #ffffff !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.22) !important;
}

body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) header a.button[href*="/pakketomgeving"],
body:not(.logged-in) header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  border-color: rgba(0,0,0,.06) !important;
  color: #ffffff !important;
}

body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) header a.button[href*="/pakketomgeving"],
body:not(.logged-in) header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"],
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.20) !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.wp-block-button__link[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.btn[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a.elementor-button[href*="/pakketomgeving"]:hover,
body:not(.logged-in) .site-header a[role="button"][href*="/pakketomgeving"]:hover{filter: brightness(0.95);}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"],
body:not(.logged-in) header a.button[href*="pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"],
body:not(.logged-in) .site-header a[href*="pakketomgeving"].wp-block-button__link{
  background: var(--r2s-brand-green) !important;
  border-color: rgba(0,0,0,.06) !important;
  color: #ffffff !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]:hover,
body:not(.logged-in) .site-header a[href*="pakketomgeving"].wp-block-button__link:hover{filter: brightness(0.95);}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"],
body:not(.logged-in) header a.button[href*="pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"],
body:not(.logged-in) header a.button[href*="pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"],
body:not(.logged-in) header a.button[href*="pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"],
body:not(.logged-in) header a.button[href*="pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170: Header CTA "Pakket laten ophalen" (theme-level button) -> brand green */
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"],
body:not(.logged-in) header a.button[href*="pakketomgeving"],
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"],
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) header a.wp-block-button__link[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a.elementor-button[href*="pakketomgeving"]:hover,
body:not(.logged-in) header a[role="button"][href*="pakketomgeving"]:hover{
  filter: brightness(0.95);
}

/* v170b: If the theme CTA is not inside <header>, match any button-like link to /pakketomgeving */
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a.button[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a.elementor-button[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn){
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a.button[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a.elementor-button[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn):hover{
  filter: brightness(0.95);
}

/* v170b: If the theme CTA is not inside <header>, match any button-like link to /pakketomgeving */
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a.button[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a.elementor-button[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn){
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a.button[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a.elementor-button[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn):hover{filter: brightness(0.95);}

/* v170b: Theme CTA not in <header> */
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn){
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn):hover{filter: brightness(0.95);}

/* v170b: Theme CTA not in <header> */
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn){
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn):hover{filter: brightness(0.95);}

/* v170b: Theme CTA not in <header> */
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn),
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn){
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border-color: rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
}
body:not(.logged-in) a.wp-block-button__link[href*="pakketomgeving"]:not(.r2s-btn):hover,
body:not(.logged-in) a[role="button"][href*="pakketomgeving"]:not(.r2s-btn):hover{filter: brightness(0.95);}

/* =========================================================
   Step 2 (v171) — Login form (username/password) polish
   Goal: match brand green + make "Registreren" + "Wachtwoord vergeten" small pill buttons.
   CSS-only.
========================================================= */

/* Primary submit buttons in Theme My Login / WP login forms */
body:not(.logged-in) .tml input[type="submit"],
body:not(.logged-in) .tml button[type="submit"],
body:not(.logged-in) .tml .button[type="submit"],
body:not(.logged-in) form#loginform input[type="submit"],
body:not(.logged-in) form#loginform button[type="submit"],
body:not(.logged-in) .login form input[type="submit"],
body:not(.logged-in) .login form button[type="submit"],
body:not(.logged-in) .wp-block-loginout a.wp-block-button__link{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  border-radius: 999px !important;
  padding: 12px 22px !important;
  font-weight: 800 !important;
  box-shadow: 0 12px 30px rgba(30,201,138,.25) !important;
  text-decoration: none !important;
  cursor: pointer;
}

body:not(.logged-in) .tml input[type="submit"]:hover,
body:not(.logged-in) .tml button[type="submit"]:hover,
body:not(.logged-in) form#loginform input[type="submit"]:hover,
body:not(.logged-in) form#loginform button[type="submit"]:hover,
body:not(.logged-in) .login form input[type="submit"]:hover,
body:not(.logged-in) .login form button[type="submit"]:hover{
  filter: brightness(0.95);
}

/* Small pill buttons for action links (register / lost password) */
body:not(.logged-in) .tml .tml-links a,
body:not(.logged-in) .tml .tml-action-links a,
body:not(.logged-in) .tml .tml-links li a,
body:not(.logged-in) .tml a[href*="wp-login.php?action=register"],
body:not(.logged-in) .tml a[href*="action=lostpassword"],
body:not(.logged-in) a[href*="wp-login.php?action=register"],
body:not(.logged-in) a[href*="action=lostpassword"]{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(11,60,140,.22) !important;
  background: #ffffff !important;
  color: var(--r2s-brand-blue) !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  line-height: 1;
}

body:not(.logged-in) .tml .tml-links a:hover,
body:not(.logged-in) .tml .tml-action-links a:hover,
body:not(.logged-in) .tml a[href*="wp-login.php?action=register"]:hover,
body:not(.logged-in) .tml a[href*="action=lostpassword"]:hover,
body:not(.logged-in) a[href*="wp-login.php?action=register"]:hover,
body:not(.logged-in) a[href*="action=lostpassword"]:hover{
  background: rgba(11,60,140,.06) !important;
  border-color: rgba(11,60,140,.30) !important;
}

/* Make the link list feel cleaner (remove bullet look if it is a <ul>) */
body:not(.logged-in) .tml .tml-links,
body:not(.logged-in) .tml .tml-action-links{
  margin-top: 14px !important;
}
body:not(.logged-in) .tml .tml-links ul,
body:not(.logged-in) .tml .tml-action-links ul,
body:not(.logged-in) .tml ul.tml-links{
  list-style: none !important;
  padding-left: 0 !important;
  margin: 10px 0 0 !important;
}
body:not(.logged-in) .tml .tml-links li,
body:not(.logged-in) .tml .tml-action-links li,
body:not(.logged-in) .tml ul.tml-links li{
  margin: 10px 0 !important;
}

/* =========================================================
   v172 — Pakketomgeving (dashboard) responsive polish
   - Mobile: buttons + text fit nicely
   - Desktop/Laptop: first two buttons side-by-side
   (CSS-only)
========================================================= */

/* Base: keep dashboard button row tidy */
.r2s-wrap .r2s-card--light .r2s-card-inner > .r2s-btn-row{
  gap: 12px;
}

/* Desktop/laptop: show first two buttons next to each other */
@media (min-width: 900px){
  .r2s-wrap .r2s-card--light .r2s-card-inner > .r2s-btn-row{
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
  }
  .r2s-wrap .r2s-card--light .r2s-card-inner > .r2s-btn-row .r2s-btn{
    flex: 1 1 calc(50% - 12px);
    min-width: 260px;
  }


  /* Third action goes to the next line (still neat) */
  .r2s-wrap .r2s-card--light .r2s-card-inner > .r2s-btn-row .r2s-btn:nth-child(3){
    flex-basis: calc(50% - 12px);
  }
}

/* Mobile: make title + buttons fit nicely */
@media (max-width: 600px){
  .r2s-wrap{padding: 34px 12px;}
  .r2s-wrap .r2s-card--light .r2s-card-inner{padding: 22px 18px;}
  .r2s-title{font-size: 34px; line-height: 1.08;}
  .r2s-sub{font-size: 15px; margin-bottom: 14px;}

  .r2s-wrap .r2s-card--light .r2s-card-inner > .r2s-btn-row{
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .r2s-wrap .r2s-card--light .r2s-card-inner > .r2s-btn-row .r2s-btn{
    width: 100%;
    padding: 12px 16px;
    font-size: 16px;
  }


}


/* Hide internal admin hints on customer-facing pages */
.r2s-help{display:none!important;}

/* =========================================================
   Step 7 — Wizard step 3 (Label) polish
   - Hide manual tracking code field (photo/scan only)
   - Tighten spacing so bottom buttons don't sit too low
   - Make "Scan label" the clear primary action
========================================================= */

/* Hide the manual tracking code row (backup input) */
#r2s-scan-status + .r2s-row{display:none !important;}

/* Remove leftover vertical whitespace from the (now hidden) upload/tip row,
   but keep the file input accessible for the scan button */
#r2s-scan-status + .r2s-row + .r2s-row{
  margin-top: 0 !important;
  padding: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* Ensure the file input is not display:none (label click compatibility) */
#r2s-label-photo{
  display: block !important;
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
}

/* Make the scan CTA a bit larger and more obvious */
#r2s-start-scan{
  padding: 14px 20px !important;
  font-size: 16px !important;
  font-weight: 900 !important;
}

/* Keep wizard footer buttons aligned consistently across steps */
.r2s-wizard-body > .r2s-btn-row{
  margin-top: 16px !important;
}

/* v180 — Step 7 (Label) desktop: prevent excessive empty space pushing footer down
   Some themes/overrides can impose a large min-height on the wizard body.
   Keep the wizard height content-driven and pull the footer closer to the step content.
*/
.r2s-wizard-body{
  min-height: unset !important;
  height: auto !important;
}

/* Slightly tighter spacing before the footer row on wider screens */
@media (min-width: 900px){
  .r2s-wizard-body > .r2s-btn-row{ margin-top: 12px !important; }
}


/* v181 — Step 7 (Label) tighten vertical whitespace on desktop */
.r2s-wizard-body .r2s-scan-card{
  padding-bottom: 6px !important;
  margin-bottom: 6px !important;
}
.r2s-wizard-body > .r2s-btn-row{
  margin-top: 10px !important;
}

/* Confirmation pills: label photo status */
.r2s-status{display:inline-flex;align-items:center;gap:6px;font-weight:700;}
.r2s-status-ok{color:var(--r2s-green,#1EC98A);}
.r2s-status-missing{color:#9CA3AF;}



/* --- Step11 hotfix: force correct brand colors for account tabs actions (theme CSS may override) --- */
.r2s-account-tabs .r2s-btn-primary{
  background: var(--r2s-brand-green) !important;
  color: #ffffff !important;
}
.r2s-account-tabs .r2s-btn-secondary{
  background: var(--r2s-brand-blue) !important;
  color: #ffffff !important;
}

/* --- Subgate ("Abonnement nodig") button layout ---
   On phones we want the buttons centered and compact (not full width).
*/
.r2s-subgate-actions{
  justify-content: center !important;
  gap: 12px !important;
}
.r2s-subgate-actions .r2s-btn{
  width: auto !important;
  min-width: 170px;
}


@media (max-width: 520px){
  .r2s-subgate-actions{
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
  }
  .r2s-subgate-actions .r2s-btn{
    flex: 0 0 auto !important;
  }


}


/* === R2S Subgate (abonnement nodig) – mobile buttons + light card (v192) === */
.r2s-subgate { display:flex; justify-content:center; width:100%; }
.r2s-subgate .r2s-card--light{
  background:#fff !important;
  border:1px solid #D9E2EF !important;
  box-shadow: 0 10px 30px rgba(0,0,0,.08) !important;
}
.r2s-subgate-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-start;
  align-items:center;
}
@media (max-width: 520px){
  .r2s-subgate-actions{
    flex-direction:column;
    align-items:center;
    justify-content:center;
  }
  .r2s-subgate-actions .r2s-btn{
    width:100%;
    max-width: 340px;
    text-align:center;
    justify-content:center;
  }


}

/* === Definitieve subgate styling (v193) ===
   Sommige oudere thema/CSS rules geven de card een donkere gradient.
   We forceren hier de lichte kaart + gecentreerde knoppen op alle devices.
*/
.r2s-subgate .r2s-card.r2s-card--subgate{
  background: #ffffff !important;
  color: #1F2937 !important;
  border: 1px solid #D9E2EF !important;
  box-shadow: 0 10px 30px rgba(0,0,0,.08) !important;
  max-width: 720px;
  width: 100%;
}
.r2s-subgate .r2s-card.r2s-card--subgate .r2s-card-title{
  color: #111827 !important;
}
.r2s-subgate .r2s-subgate-actions{
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
@media (max-width: 520px){
  .r2s-subgate .r2s-subgate-actions{
    flex-direction: column !important;
  }
  .r2s-subgate .r2s-subgate-actions .r2s-btn{
    width: 100% !important;
    max-width: 340px !important;
  }


}


/* === Return2Sender: Subgate (abonnement nodig) button/layout overrides (v1.9.4) === */
.r2s-subgate .r2s-btn-primary{
  background:#1EC98A !important;
  color:#fff !important;
}
.r2s-subgate .r2s-btn-secondary{
  background:#0B3C8C !important;
  color:#fff !important;
  border:0 !important;
}
.r2s-subgate .r2s-btn-secondary:hover{filter:brightness(0.95);}

.r2s-subgate .r2s-subgate-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.r2s-subgate .r2s-subgate-actions a{
  display:inline-flex;
  justify-content:center;
}

/*
  Samsung Fold / kleine viewports: soms wordt de @media-query niet getriggerd
  (door afwijkende viewport-schaal). Daarom forceren we hier ook zónder media
  query dat de knop nooit buiten de kaart kan vallen en altijd ovaal is.
*/
.r2s-subgate .r2s-subgate-actions a.r2s-btn{
  width: 100%;
  max-width: 360px;
  box-sizing: border-box;
  border-radius: 999px;
  padding-left: 26px;
  padding-right: 26px;
}



@media (max-width: 520px){
  .r2s-subgate .r2s-subgate-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .r2s-subgate .r2s-subgate-actions a{
    width:100%;
    max-width:320px;
    margin:0 auto;
  }
}


/* Ambassador / member-get-member */
.r2s-ambassador-teaser{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px;
  border:1px solid rgba(11,19,32,.10);
  border-radius:20px;
  background:#fff;
  box-shadow:0 12px 28px rgba(11,19,32,.06);
}
.r2s-ambassador-teaser-main{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  text-decoration:none;
  color:var(--r2s-brand-text);
  font-weight:950;
  letter-spacing:-0.01em;
  flex:1;
  min-width:0;
  background:rgba(11,60,140,.05);
  border:1px solid rgba(11,60,140,.10);
}
.r2s-ambassador-teaser-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.r2s-ambassador-teaser-arrow{opacity:.65;font-size:22px;line-height:1;}
.r2s-ambassador-teaser-wa{white-space:nowrap;}
@media(max-width:520px){
  .r2s-ambassador-teaser{flex-direction:column;align-items:stretch;}
  .r2s-ambassador-teaser-wa{width:100%;}
}

.r2s-ambassador-card .r2s-ambassador-actions{display:flex;flex-wrap:wrap;gap:12px;}
.r2s-ambassador-card .r2s-ambassador-linkbox{
  margin-top:6px;
  padding:12px 14px;
  border:1px dashed var(--r2s-border);
  border-radius:16px;
  background:var(--r2s-brand-bg);
  overflow:auto;
}
.r2s-ambassador-card .r2s-ambassador-linkbox code{font-size:13px;color:var(--r2s-brand-text);}

.r2s-ambassador-card .r2s-ambassador-progress{margin-top:16px;}
.r2s-ambassador-card .r2s-ambassador-progress-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;}
.r2s-progress{height:12px;border-radius:999px;background:rgba(11,60,140,.08);overflow:hidden;border:1px solid rgba(11,60,140,.10);}
.r2s-progress-bar{height:100%;border-radius:999px;background:var(--r2s-brand-green);box-shadow:0 10px 28px rgba(30,201,138,.30);}
.r2s-ambassador-next{margin-top:10px;font-size:14px;color:var(--r2s-brand-text);}
@media(max-width:520px){
  .r2s-ambassador-card .r2s-ambassador-actions{flex-direction:column;align-items:stretch;}
}



/* Ambassador bus UI */
.r2s-ambassador-bus-head{margin-bottom:10px;}
.r2s-ambassador-bus-title{margin:0 0 6px 0;}
.r2s-ambassador-bus-sub{margin:0;color:rgba(31,41,55,.82);font-weight:650;}
.r2s-ambassador-bus-actions{display:flex;gap:12px;align-items:center;margin:12px 0 10px;}
.r2s-ambassador-bus-status{
  margin:10px 0 14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(30,201,138,.08);
  border:1px solid rgba(30,201,138,.18);
  font-weight:800;
  color:var(--r2s-brand-text);
}

/* Mijn bus detail page (new markup classes) — keep copy readable (Option B) */
.r2s-bus-status{
  margin:10px 0 14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(30,201,138,.08);
  border:1px solid rgba(30,201,138,.18);
  color:#1F2937;
  font-weight:850;
}

.r2s-bus-progress-text{
  color:#1F2937;
  font-weight:800;
}

.r2s-bus-progress-goal{
  color:var(--r2s-muted);
  font-weight:650;
}

.r2s-bus-pricehint{
  margin-top:8px;
  display:flex;
  justify-content:flex-end;
  font-weight:900;
  color:var(--r2s-brand-blue);
  letter-spacing:-0.01em;
}
.r2s-bus-pricehint-sub{
  font-weight:750;
  color:rgba(31,41,55,.70);
  margin-left:6px;
  font-size:13px;
}
@media (max-width: 640px){
  .r2s-bus-pricehint{justify-content:flex-start;}
}

/* Desktop-only: keep the bus hero image inside the card (mobile already OK) */
@media (min-width: 1024px){
  .r2s-bus-hero{
    max-width: 440px;
    margin-left: auto;
  }
  .r2s-bus-hero img{
    width: 100%;
    height: auto;
    display: block;
  }
}
.r2s-ambassador-buses{display:flex;flex-direction:column;gap:12px;margin-top:6px;}
.r2s-bus-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(11,19,32,.10);
  background:#fff;
  box-shadow:0 10px 26px rgba(11,19,32,.06);
}
.r2s-bus-row-left{display:flex;align-items:center;gap:12px;min-width:160px;}
.r2s-bus-icon{
  width:44px;height:44px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(11,60,140,.06);
  border:1px solid rgba(11,60,140,.12);
}
.r2s-bus-svg{width:34px;height:20px;display:block;fill:var(--r2s-brand-blue);}
.r2s-bus-svg path:nth-child(1){fill:var(--r2s-brand-blue);}
.r2s-bus-svg path:nth-child(2), .r2s-bus-svg path:nth-child(3){fill:rgba(244,246,248,.95);}
.r2s-bus-svg circle{fill:rgba(11,19,32,.85);}
.r2s-bus-meta{display:flex;flex-direction:column;gap:2px;}
.r2s-bus-label{font-weight:900;letter-spacing:-0.01em;color:var(--r2s-brand-text);}
.r2s-bus-hint{font-size:13px;font-weight:700;color:rgba(31,41,55,.80);}


/* Emoji-based package progress (user preference) */
.r2s-pack-grid{
  display:grid;
  grid-template-columns:repeat(10, 22px);
  gap:10px;
  padding-top:6px;
  align-items:center;
}

.r2s-pack{
  width:22px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  background:transparent;
  box-shadow:none;
  font-size:20px;
  line-height:1;
  transform:translateZ(0);
  transition: transform .14s ease-out, filter .14s ease-out, opacity .14s ease-out;
}

.r2s-pack::before{ content:"📦"; }

.r2s-pack.is-empty{
  opacity:.22;
  filter: grayscale(1) saturate(.2);
}

.r2s-pack.is-filled{
  opacity:1;
  filter: drop-shadow(0 6px 10px rgba(11,19,32,.16)) saturate(1.05);
  animation: r2s-pack-pop .18s ease-out;
}

@keyframes r2s-pack-pop{
  0%{transform:scale(.92);} 
  100%{transform:scale(1);} 
}

@media (prefers-reduced-motion: reduce){
  .r2s-pack{transition:none;}
  .r2s-pack.is-filled{animation:none;}
}

.r2s-pack-grid--10{grid-template-columns:repeat(10, 22px);} 
.r2s-pack-grid--20{grid-template-columns:repeat(10, 22px);} 

@media (max-width: 768px){
  .r2s-pack-grid{grid-template-columns:repeat(10, 20px);gap:8px;}
  .r2s-pack{width:20px;height:20px;font-size:18px;}
}
    padding:10px 14px;
    border-radius:999px;
    border:1px solid #d6e2f5;
    background:#F4F6F8;
    color:#0B3C8C;
    font-weight:800;
    width:100%;
    max-width:360px;
    margin:0 auto;
  }
  .r2s-bus-detail .r2s-bus-back--split .r2s-btn-link:hover{
    opacity:1;
    filter:brightness(0.98);
  }
}

/* ===== Mijn bus – desktop polish (v222) ===== */
@media (min-width: 769px){
  /* Make WhatsApp CTA a touch more prominent on desktop */
  .r2s-bus-detail .r2s-bus-actions .r2s-btn-primary{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:14px 22px;
    font-size:16px;
    line-height:1.1;
    min-height:48px;
    width:100%;
    max-width:420px;
    margin:0 auto;
  }

  /* Turn the info link into a proper pill button on the bus page only */
  .r2s-bus-detail .r2s-bus-back--split .r2s-btn-link,
  .r2s-bus-detail .r2s-bus-info-row .r2s-btn-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 14px;
    border-radius:999px;
    border:1px solid rgba(11,60,140,.35);
    background:#F4F6F8;
    color:#0B3C8C;
    text-decoration:none;
    font-weight:850;
    box-shadow:none;
  }
  .r2s-bus-detail .r2s-bus-back--split .r2s-btn-link:hover,
  .r2s-bus-detail .r2s-bus-info-row .r2s-btn-link:hover{
    opacity:1;
    filter:brightness(0.98);
  }

  /* Place the info pill directly under the bus image, centered */
  .r2s-bus-detail .r2s-bus-info-row{
    display:flex;
    justify-content:center;
    margin:10px 0 2px;
  }

  /* Give the split row a cleaner alignment on wider screens */
  .r2s-bus-detail .r2s-bus-back--split{
    display:flex;
    flex-direction:column;
    gap:12px;
    align-items:center;
    justify-content:center;
  }
}


/* --- Bus uitlegknop: subtiele pill op mobiel --- */
@media (max-width: 768px){
  .r2s-bus-back--split .r2s-btn-link,
  .r2s-bus-info-row .r2s-btn-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 14px;
    border-radius:999px;
    border:1px solid rgba(11,60,140,.35);
    background:#F4F6F8;
    color:#0B3C8C;
    text-decoration:none;
    font-weight:700;
    line-height:1;
    white-space:nowrap;
    margin:0;
  }

  .r2s-bus-detail .r2s-bus-info-row{
    display:flex;
    justify-content:center;
    margin:10px 0 2px;
  }

  /* On smaller screens, stack buttons with a bit more breathing room */
  .r2s-bus-detail .r2s-bus-back--split{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:12px;
  }
  .r2s-bus-detail .r2s-bus-back--split .r2s-btn{
    width:100%;
    margin:0;
  }



  /* Ensure both buttons are pills, consistent with the rest of the app */
  .r2s-bus-detail .r2s-bus-back--split .r2s-btn,
  .r2s-bus-detail .r2s-bus-back--split .r2s-btn-link{
    border-radius:999px;
  }
}

/* Safety net: if the wrapper class differs, keep the bus footer buttons pill-shaped */
.r2s-bus-back--split .r2s-btn,
.r2s-bus-back--split .r2s-btn-link,
.r2s-bus-info-row .r2s-btn-link{
  border-radius:999px;
}

/* --- Overlay (modal) --- */
.r2s-overlay{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
}
.r2s-overlay[aria-hidden="false"]{ display:block; }
.r2s-overlay-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
}
.r2s-overlay-panel{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(92vw, 720px);
  max-height:min(82vh, 720px);
  background:#fff;
  border-radius:18px;
  box-shadow:0 22px 60px rgba(0,0,0,.28);
  overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
}
.r2s-overlay-title{
  padding:18px 18px 0 18px;
  font-weight:800;
  font-size:18px;
  color:#111827;
}
.r2s-overlay-body{
  padding:14px 18px 18px 18px;
  overflow:auto;
  max-height:calc(min(82vh, 720px) - 60px);
  color:#111827;
}

/* Make embedded page content in overlay readable (some pages use muted/low-contrast helpers) */
.r2s-overlay-body p,
.r2s-overlay-body li,
.r2s-overlay-body span,
.r2s-overlay-body div{
  color:rgba(17,24,39,.90);
}
.r2s-overlay-body li{ opacity:1; }
.r2s-overlay-body h1,
.r2s-overlay-body h2,
.r2s-overlay-body h3{
  color:#111827;
}

/* Overlay readability: force normal contrast for imported page content */
.r2s-overlay-body,
.r2s-overlay-body p,
.r2s-overlay-body li,
.r2s-overlay-body td,
.r2s-overlay-body span{
  color:rgba(17,24,39,.90) !important;
  opacity:1 !important;
}
.r2s-overlay-body h1,
.r2s-overlay-body h2,
.r2s-overlay-body h3{
  color:#111827 !important;
}
.r2s-overlay-close{
  position:absolute;
  right:12px;
  top:12px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:#F4F6F8;
  color:#0B3C8C;
  font-size:22px;
  line-height:1;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.r2s-overlay-loading,
.r2s-overlay-error{
  padding:14px;
  border-radius:14px;
  background:#F4F6F8;
  border:1px solid rgba(0,0,0,.08);
  font-weight:700;
}

/* Prevent background scroll when overlay is open */
html.r2s-overlay-open,
body.r2s-overlay-open{
  overflow:hidden !important;
  height:100%;
}

@media (max-width: 420px){
  .r2s-overlay-panel{
    width:94vw;
    border-radius:16px;
  }
}



/* === v226: Pickup mobile overflow + chips styling fix === */
@media (max-width: 720px){
  /* Prevent horizontal swipe on pickup wizard screens */
  html, body{ overflow-x:hidden; }

  /* Make rows stack (Time slot -> Location) */
  .r2s-row{ flex-direction:column; gap:12px; }
  .r2s-row > .r2s-field{ width:100% !important; max-width:100% !important; }

  /* Choice chips: ensure they never overflow and look like buttons */
  .r2s-choicechips{
    display:flex;
    flex-direction:column;
    gap:10px;
    width:100%;
    max-width:100%;
    overflow:hidden;
  }
  .r2s-choicechips .r2s-chip{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    max-width:100%;
    box-sizing:border-box;
    padding:12px 14px;
    border-radius:999px;
    border:1px solid rgba(11,60,140,.22);
    background:#F4F6F8;
    color:#1F2937;
    font-weight:700;
    text-align:center;
    cursor:pointer;
    user-select:none;
  }
  .r2s-choicechips .r2s-chip input{ display:none !important; }
  .r2s-choicechips .r2s-chip span{ display:block; width:100%; }

  /* Active state (when selected) */
  .r2s-choicechips .r2s-chip:has(input:checked){
    background:rgba(30,201,138,.14);
    border-color:rgba(30,201,138,.55);
  }

  /* Extra guardrails for common wrappers */
  .r2s-wrap, .r2s-wizard-body, .r2s-card, .r2s-panel, .r2s-content{
    max-width:100%;
    overflow-x:hidden;
  }
}


/* Terms acceptance block (Mijn gegevens) */
.r2s-terms-accept{
  margin: 10px 0 12px 0;
  padding: 10px 12px;
  background: #F4F6F8;
  border: 1px solid rgba(11,60,140,0.12);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.r2s-terms-accept__label{
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 13px;
  color: #1F2937;
}
.r2s-terms-accept__label input{
  margin-top: 3px;
}
.r2s-terms-accept__label a{
  color: #0B3C8C;
  text-decoration: underline;
}
.r2s-terms-accept__meta{
  font-size: 12px;
  color: rgba(31,41,55,0.75);
  font-style: italic;
}

/* --------------------
   Homepage tweaks
   - keep buttons pill-shaped everywhere
   - make primary CTA a bit thicker
-------------------- */

.r2s-home-actions .r2s-btn,
.r2s-home-actions a.r2s-btn {
  border-radius: 999px !important;
}

.r2s-home-cta {
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

/* =========================================================
   Custom date picker (availability calendar)
========================================================= */

/* R2S override: force date chips colors (theme-proof) */
.r2s-date-picker .r2s-date-btn{
  background: var(--r2s-blue) !important;
  border-color: rgba(11,60,140,.28) !important;
  color: #ffffff !important;
}
.r2s-date-picker .r2s-date-btn .r2s-date-top{
  color: #ffffff !important;
}
.r2s-date-picker .r2s-date-btn .r2s-date-badge{
  background: rgba(255,255,255,.18) !important;
  color: #ffffff !important;
}
.r2s-date-picker .r2s-date-btn.is-selected{
  background: var(--r2s-green) !important;
  border-color: var(--r2s-green) !important;
  box-shadow: 0 0 0 3px rgba(30,201,138,.15) !important;
}
.r2s-date-picker .r2s-date-btn.is-selected .r2s-date-badge{
  background: rgba(255,255,255,.22) !important;
}
.r2s-date-picker .r2s-date-btn.is-disabled{
  background: #e5e7eb !important;
  border-color: #e5e7eb !important;
  color: #6b7280 !important;
}
.r2s-date-picker .r2s-date-btn.is-disabled .r2s-date-top,
.r2s-date-picker .r2s-date-btn.is-disabled .r2s-date-badge{
  color: #6b7280 !important;
  background: rgba(255,255,255,.55) !important;
}

.r2s-date-picker{
  width: 100%;
}
.r2s-date-grid{
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}
@media (max-width: 820px){
  .r2s-date-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 520px){
  .r2s-date-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.r2s-date-btn{
  border: 1px solid #e5e7eb;
  background: #fff;
  border-radius: 14px;
  padding: 10px 10px;
  text-align: left;
  cursor: pointer;
  transition: transform .05s ease, border-color .12s ease, box-shadow .12s ease;
  min-height: 64px;
}
.r2s-date-btn:hover{
  border-color: #cbd5e1;
}
.r2s-date-btn:active{
  transform: scale(0.99);
}
.r2s-date-btn.is-selected{
  border-color: var(--r2s-green);
  box-shadow: 0 0 0 3px rgba(30,201,138,.12);
}
.r2s-date-btn.is-disabled{
  opacity: .55;
  cursor: not-allowed;
}
.r2s-date-top{
  font-weight: 600;
  color: #111827;
  font-size: 13px;
}
.r2s-date-badge{
  margin-top: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 12px;
  background: #F4F6F8;
  color: #111827;
}
.r2s-date-btn.is-disabled .r2s-date-badge{
  background: #f1f5f9;
  color: #6b7280;
}
.r2s-date-btn.is-selected .r2s-date-badge{
  background: rgba(30,201,138,.12);
  color: #065f46;
}

/* =========================================================
   Custom date picker (availability calendar)
========================================================= */
.r2s-date-picker{
  width: 100%;
}
.r2s-date-grid{
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}
@media (max-width: 820px){
  .r2s-date-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 520px){
  .r2s-date-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.r2s-date-btn{
  border: 1px solid #e5e7eb;
  background: #fff;
  border-radius: 14px;
  padding: 10px 10px;
  text-align: left;
  cursor: pointer;
  transition: transform .05s ease, border-color .12s ease, box-shadow .12s ease;
  min-height: 64px;
}
.r2s-date-btn:hover{
  border-color: #cbd5e1;
}
.r2s-date-btn:active{
  transform: scale(0.99);
}
.r2s-date-btn.is-selected{
  border-color: var(--r2s-green);
  box-shadow: 0 0 0 3px rgba(30,201,138,.12);
}
.r2s-date-btn.is-disabled{
  opacity: .55;
  cursor: not-allowed;
}
.r2s-date-top{
  font-weight: 600;
  color: #111827;
  font-size: 13px;
}
.r2s-date-badge{
  margin-top: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 12px;
  background: #F4F6F8;
  color: #111827;
}
.r2s-date-btn.is-disabled .r2s-date-badge{
  background: #f1f5f9;
  color: #6b7280;
}
.r2s-date-btn.is-selected .r2s-date-badge{
  background: rgba(30,201,138,.12);
  color: #065f46;
}

/* =========================================================
   Custom date picker (availability calendar)
========================================================= */
.r2s-date-picker{ width:100%; }
.r2s-date-grid{ display:grid; grid-template-columns:repeat(7,minmax(0,1fr)); gap:10px; }
@media (max-width:820px){ .r2s-date-grid{ grid-template-columns:repeat(4,minmax(0,1fr)); } }
@media (max-width:520px){ .r2s-date-grid{ grid-template-columns:repeat(3,minmax(0,1fr)); } }
.r2s-date-btn{ border:1px solid #e5e7eb; background:#fff; border-radius:14px; padding:10px 10px; text-align:left; cursor:pointer; transition:transform .05s ease,border-color .12s ease,box-shadow .12s ease; min-height:64px; }
.r2s-date-btn:hover{ border-color:#cbd5e1; }
.r2s-date-btn:active{ transform:scale(0.99); }
.r2s-date-btn.is-selected{ border-color:var(--r2s-green); box-shadow:0 0 0 3px rgba(30,201,138,.12); }
.r2s-date-btn.is-disabled{ opacity:.55; cursor:not-allowed; }
.r2s-date-top{ font-weight:600; color:#111827; font-size:13px; }
.r2s-date-badge{ margin-top:6px; display:inline-flex; align-items:center; justify-content:center; padding:3px 8px; border-radius:999px; font-size:12px; background:#F4F6F8; color:#111827; }
.r2s-date-btn.is-disabled .r2s-date-badge{ background:#f1f5f9; color:#6b7280; }
.r2s-date-btn.is-selected .r2s-date-badge{ background:rgba(30,201,138,.12); color:#065f46; }

/* =========================================================
   Custom date picker (availability calendar)
========================================================= */
.r2s-date-picker{width:100%;}
.r2s-date-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;}
@media (max-width:820px){.r2s-date-grid{grid-template-columns:repeat(4,minmax(0,1fr));}}
@media (max-width:520px){.r2s-date-grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
.r2s-date-btn{border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:10px;text-align:left;cursor:pointer;transition:transform .05s ease,border-color .12s ease,box-shadow .12s ease;min-height:64px;}
.r2s-date-btn:hover{border-color:#cbd5e1;}
.r2s-date-btn:active{transform:scale(.99);}
.r2s-date-btn.is-selected{border-color:var(--r2s-green);box-shadow:0 0 0 3px rgba(30,201,138,.12);}
.r2s-date-btn.is-disabled{opacity:.55;cursor:not-allowed;}
.r2s-date-top{font-weight:600;color:#111827;font-size:13px;}
.r2s-date-badge{margin-top:6px;display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:12px;background:#F4F6F8;color:#111827;}
.r2s-date-btn.is-disabled .r2s-date-badge{background:#f1f5f9;color:#6b7280;}
.r2s-date-btn.is-selected .r2s-date-badge{background:rgba(30,201,138,.12);color:#065f46;}

/* =========================================================
   Date chip colors (v255 tweak)
   - Unselected: R2S blauw
   - Selected: R2S groen
   - Disabled/full: lichtgrijs
========================================================= */
.r2s-date-grid .r2s-date-btn{
  background: var(--r2s-brand-blue, #0B3C8C);
  border-color: rgba(11,60,140,.18);
}
.r2s-date-grid .r2s-date-btn .r2s-date-top{ color:#ffffff; }
.r2s-date-grid .r2s-date-btn .r2s-date-badge{
  background: rgba(255,255,255,.18);
  color:#ffffff;
}
.r2s-date-grid .r2s-date-btn.is-selected{
  background: var(--r2s-brand-green, #1EC98A);
  border-color: rgba(30,201,138,.35);
  box-shadow: 0 0 0 3px rgba(30,201,138,.18);
}
.r2s-date-grid .r2s-date-btn.is-selected .r2s-date-badge{
  background: rgba(255,255,255,.20);
  color:#ffffff;
}
.r2s-date-grid .r2s-date-btn.is-disabled{
  background:#eef2f7;
  border-color:#e5e7eb;
}
.r2s-date-grid .r2s-date-btn.is-disabled .r2s-date-top{ color:#6b7280; }
.r2s-date-grid .r2s-date-btn.is-disabled .r2s-date-badge{
  background:#f6f8fc;
  color:#6b7280;
}
.r2s-date-grid .r2s-date-btn.is-disabled .r2s-date-badge{ background:#f1f5f9; color:#6b7280; }

/* Custom date picker */
.r2s-date-picker{width:100%}
.r2s-date-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}
@media(max-width:820px){.r2s-date-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:520px){.r2s-date-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.r2s-date-btn{border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:10px;text-align:left;cursor:pointer;transition:transform .05s,border-color .12s,box-shadow .12s;min-height:64px}
.r2s-date-btn:hover{border-color:#cbd5e1}
.r2s-date-btn:active{transform:scale(.99)}
.r2s-date-btn.is-selected{border-color:var(--r2s-green);box-shadow:0 0 0 3px rgba(30,201,138,.12)}
.r2s-date-btn.is-disabled{opacity:.55;cursor:not-allowed}
.r2s-date-top{font-weight:600;color:#111827;font-size:13px}
.r2s-date-badge{margin-top:6px;display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:12px;background:#F4F6F8;color:#111827}
.r2s-date-btn.is-disabled .r2s-date-badge{background:#f1f5f9;color:#6b7280}
.r2s-date-btn.is-selected .r2s-date-badge{background:rgba(30,201,138,.12);color:#065f46}

/* ================================
   R2S Date chips – kleur & polish
   ================================ */

/* Basis (niet geselecteerd) */
.r2s-date-picker .r2s-date-btn{
  background: #0B3C8C !important; /* R2S-blauw */
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  box-shadow: none !important;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
}

/* Hover (desktop) */
@media (hover:hover){
  .r2s-date-picker .r2s-date-btn:hover{
    background: #0F4DB8 !important; /* iets lichter blauw */
    box-shadow: 0 6px 14px rgba(11,60,140,.25);
    transform: translateY(-1px);
  }
}

/* Geselecteerde dag */
.r2s-date-picker .r2s-date-btn.is-selected{
  background: #1EC98A !important; /* R2S-groen */
  color: #ffffff !important;
  border: 2px solid rgba(255,255,255,.6) !important;
  box-shadow: 0 0 0 3px rgba(30,201,138,.25), 0 8px 18px rgba(30,201,138,.35) !important;
  transform: translateY(0);
}

/* Disabled / VOL */
.r2s-date-picker .r2s-date-btn.is-disabled,
.r2s-date-picker .r2s-date-btn.is-full{
  background: #E5E7EB !important; /* lichtgrijs */
  color: #9CA3AF !important;
  border: 1px solid #E5E7EB !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}

/* Compact op mobiel */
@media (max-width: 480px){
  .r2s-date-picker .r2s-date-btn{
    padding: 8px 12px !important;
    font-size: 13px !important;
  }
}



/* ================================
   R2S Modal (confirm cancel)
   ================================ */
.r2s-modal-overlay{
  display:none;
  position:fixed;
  inset:0;
  background: rgba(15, 23, 42, 0.55);
  z-index: 99999;
  align-items:center;
  justify-content:center;
  padding: 16px;
}
.r2s-modal-overlay.is-open{ display:flex; }

.r2s-modal-card{z-index:9999;
  width: 100%;
  max-width: 460px;
  background: #ffffff;
  border-radius: 22px;
  border: 1px solid rgba(11,60,140,0.15);
  box-shadow: 0 20px 60px rgba(0,0,0,0.18);
  padding: 18px 18px 16px;
}
.r2s-modal-card h3{
  margin: 0 0 8px;
  font-size: 18px;
  color: #0B3C8C;
}
.r2s-modal-card p{
  margin: 0 0 14px;
  color: #1F2937;
  line-height: 1.35;
}

.r2s-modal-actions{
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  flex-wrap: wrap;
}
.r2s-modal-actions .r2s-btn{
  min-width: 120px;
}


/* Cancel modal – no backdrop + R2S button color */
#r2s-cancel-modal{background:transparent !important;}
#r2s-cancel-modal .r2s-btn-secondary{
  background:#0B3C8C !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.15) !important;
}
#r2s-cancel-modal .r2s-btn-secondary:hover{background:#0F4DB8 !important;}



/* ================================
   Cancel modal – NO overlay (force)
   ================================ */
#r2s-cancel-modal.r2s-modal,
#r2s-cancel-modal.r2s-modal.is-open{
  background: transparent !important;
  box-shadow: none !important;
}
#r2s-cancel-modal.r2s-modal::before,
#r2s-cancel-modal.r2s-modal::after{
  display:none !important;
  content:none !important;
}


/* ================================
   Hulp / FAQ
   ================================ */
.r2s-faq{display:flex;flex-direction:column;gap:10px;}
.r2s-faq-item{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:14px;padding:12px 14px;}
.r2s-faq-q{font-weight:700;color:#0f172a;margin:0;}
details.r2s-faq-item{padding:0;}
details.r2s-faq-item > summary{list-style:none;cursor:pointer;padding:12px 14px;border-radius:14px;font-weight:700;color:#0f172a;}
details.r2s-faq-item > summary::-webkit-details-marker{display:none;}
details.r2s-faq-item[open] > summary{border-bottom:1px solid rgba(15,23,42,.08);border-bottom-left-radius:0;border-bottom-right-radius:0;}
details.r2s-faq-item .r2s-faq-a{padding:10px 14px 12px;}
.r2s-faq-a{color:#334155;}
.r2s-faq-a p{margin:0 0 10px;}
.r2s-faq-a p:last-child{margin-bottom:0;}
/* FAQ categories (nested accordion) */
details.r2s-faq-cat{background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:16px;overflow:hidden;}
details.r2s-faq-cat > summary{list-style:none;cursor:pointer;padding:14px 16px;font-weight:800;color:#0f172a;}
details.r2s-faq-cat > summary::-webkit-details-marker{display:none;}
details.r2s-faq-cat[open] > summary{border-bottom:1px solid rgba(15,23,42,.08);}
.r2s-faq-cat-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:10px;}
.r2s-faq-cat-body details.r2s-faq-item{border-radius:14px;border:1px solid rgba(15,23,42,.08);}




/* v280: When logged out on /pakketomgeving/, hide duplicate header CTA buttons (login/register CTAs live in the card) */
body.r2s-loggedout-pakketomgeving header a.wp-block-button__link[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving header a.button[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving header a.btn[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving header a.elementor-button[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving header a[role="button"][href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving .site-header a.wp-block-button__link[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving .site-header a.button[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving .site-header a.btn[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving .site-header a.elementor-button[href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving .site-header a[role="button"][href*="/pakketomgeving"],
body.r2s-loggedout-pakketomgeving header a.wp-block-button__link[href*="/registr"],
body.r2s-loggedout-pakketomgeving header a.button[href*="/registr"],
body.r2s-loggedout-pakketomgeving header a.btn[href*="/registr"],
body.r2s-loggedout-pakketomgeving header a.elementor-button[href*="/registr"],
body.r2s-loggedout-pakketomgeving header a[role="button"][href*="/registr"],
body.r2s-loggedout-pakketomgeving header a.wp-block-button__link[href*="/account-aanmaken"],
body.r2s-loggedout-pakketomgeving header a.button[href*="/account-aanmaken"],
body.r2s-loggedout-pakketomgeving header a.btn[href*="/account-aanmaken"],
body.r2s-loggedout-pakketomgeving header a.elementor-button[href*="/account-aanmaken"],
body.r2s-loggedout-pakketomgeving header a[role="button"][href*="/account-aanmaken"]{
  display:none !important;
}


/* ================================
   Upload progress (label photo)
   ================================ */
.r2s-upload-progress{margin-top:10px;}
.r2s-upload-track{position:relative;height:14px;border-radius:999px;background:#e6eef8;overflow:hidden;border:1px solid rgba(15,23,42,.12);}
.r2s-upload-bar{height:100%;width:0%;background:#1EC98A;transition:width .15s linear;}
.r2s-upload-text{margin-top:6px;font-size:13px;font-weight:600;color:#1F2937;opacity:.85;}
