/* ============================================================
   PayIBAN App — Unified stylesheet
   ============================================================ */

/* -----------------------------
   Design tokens
----------------------------- */
:root{
  /* Brand — warm MagicMonday-inspired palette */
  --pi-primary:#D4654A;
  --pi-primary2:#b8533a;
  --pi-ink:#2D2D2D;
  --pi-muted:#5a5a5a;

  /* Surfaces — clean white like MagicMonday dashboard */
  --bg:#f8f9fb;
  --surface:#f3f5f8;
  --card:#fff;
  --border:#eaedf2;
  --ring:rgba(212,101,74,.2);

  /* Tokens */
  --radius:12px;
  --radius-lg:14px;
  --space:12px;
  --space-lg:18px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.06);
  --shadow-lg:0 8px 24px rgba(0,0,0,.1);
  --easing:cubic-bezier(.2,.7,.2,1);
  --t:.18s var(--easing);

  /* Typografie schaal — consistent over alle pagina's */
  --fs-h1: 1.5rem;       /* Pagina titel */
  --fs-h2: 1.15rem;      /* Sectie titel */
  --fs-h3: 1rem;         /* Subsectie */
  --fs-body: .95rem;     /* Body tekst / tabel rijen */
  --fs-body-sm: .88rem;  /* Compacte body */
  --fs-label: .78rem;    /* Label boven invoerveld */
  --fs-caption: .75rem;  /* Meta info / datums */
  --fs-micro: .68rem;    /* Kleinste — alleen voor badges/pills */
  --fs-stat-value: 2rem; /* Grote KPI getallen */
  --fs-stat-label: .72rem;/* KPI label onder getal */

  --fw-regular: 500;
  --fw-medium: 600;
  --fw-bold: 700;
  --fw-black: 900;

  /* Buttons */
  --btn-primary-gradient: linear-gradient(135deg,#D4654A,#b8533a);

  /* States */
  --ok:#5B8C5A;            --ok-bg:#e8f0e8;
  --err:#b91c1c;           --err-bg:#fee2e2;
  --warn:#92400e;          --warn-bg:#fef3c7;
  --info:#8FAFC4;          --info-bg:#e8f0f6;
}

/* -----------------------------
   Base
----------------------------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--pi-ink);
  font:16px/1.55 'Inter',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif;
  -webkit-text-size-adjust:100%;
  -webkit-tap-highlight-color:transparent;

  /* sticky footer layout */
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
a{color:inherit}
img{max-width:100%;height:auto}

/* A11y */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0
}
.skiplink{
  position:absolute;left:-999px;top:10px;
  background:#fff;border:1px solid var(--border);
  padding:10px 12px;border-radius:10px;box-shadow:var(--shadow-sm);
  z-index:999;
}
.skiplink:focus{left:10px}

/* -----------------------------
   Typography
----------------------------- */
h1{
  font-size:clamp(1.35rem,1.1rem+1.6vw,2.05rem);
  margin:0 0 .4rem;
  letter-spacing:-.02em;
}
h2{font-size:1.05rem;margin:.1rem 0 .4rem}
p.sub{margin:.25rem 0 1.2rem;color:var(--pi-muted)}
.hint{font-size:.86rem;color:var(--pi-muted)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}

/* -----------------------------
   Layout
----------------------------- */
.wrap{width:min(90vw, 1440px);max-width:1440px;margin:0 auto;padding:28px}
.grid{display:grid;gap:var(--space-lg);flex:1}

/* Sections */
.section{padding:46px 0}
.section.compact{padding:32px 0}

.divider{border-top:1px solid var(--border)}

/* Cards */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:16px;
  box-shadow:var(--shadow-sm);
}
.card-title-sm{
  font-size:1rem;
  line-height:1.2;
  margin:0 0 10px;
  font-weight:800;
}
.card-headline{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.onboarding-intro{margin:0}

/* Generic rows */
.row{display:flex;gap:var(--space);align-items:center}
.row>*{flex:1}
@media (max-width:640px){ .row{flex-wrap:wrap} }

/* Two-column grid blocks (Relatiecards, etc.) */
.two-col-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:var(--space-lg);
  align-items:start;
}
@media (max-width:980px){
  .two-col-grid{grid-template-columns:1fr}
}

/* Actions row */
.actions-row{
  display:flex;
  gap:var(--space);
  justify-content:flex-end;
  flex-wrap:wrap;
  margin-top:12px;
}

/* -----------------------------
   Topbar / Header
----------------------------- */
.topbar{
  position:sticky;
  top:0;
  z-index:10;
  background:color-mix(in srgb, var(--surface) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar .wrap{
  padding:10px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.logo{display:flex;align-items:center;gap:10px;white-space:nowrap}
.logo-img{height:28px;width:auto;display:block}

.nav{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  font-weight:750;
  color:var(--pi-muted);
  font-size:.95rem;
}
.nav a{text-decoration:none;opacity:.96}
.nav a:hover{opacity:1;text-decoration:underline}

.top-actions{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  font-weight:750;
  color:var(--pi-muted);
  font-size:.95rem;
  white-space:nowrap;
}

/* Optional emphasis helpers */
.text-strong{font-weight:900}
.text-muted{color:var(--pi-muted)}

/* -----------------------------
   Forms
----------------------------- */
label{
  display:block;
  margin:8px 0 6px;
  color:#0b1220;
  font-size:.92rem;
  font-weight:700;
}
.label-strong{ font-weight:800; }

select,input[type=email],input[type=text],input[type=number],textarea{
  width:100%;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--pi-ink);
  padding:10px 12px;
  outline:none;
  transition:border-color var(--t),box-shadow var(--t),background-color var(--t);
}
select:focus-visible,textarea:focus-visible,input:focus-visible{
  border-color:var(--pi-primary);
  box-shadow:0 0 0 4px var(--ring);
}
::placeholder{color:#9aa3b2}
input[readonly], textarea[readonly]{background:#f4f7fb;color:#475569}
textarea{resize:vertical;min-height:140px}
input,textarea,select{ -webkit-appearance:none; appearance:none }

/* Validation */
.is-invalid{ border-color: var(--err) !important; }
.is-invalid:focus-visible{ box-shadow: 0 0 0 4px color-mix(in srgb, var(--err) 25%, transparent); }
.field-hint--error{ color: var(--err); }

/* -----------------------------
   Buttons
----------------------------- */
.btn{
  appearance:none;
  border:1px solid var(--border);
  background:#fff;
  color:var(--pi-ink);
  padding:10px 14px;
  border-radius:var(--radius);
  cursor:pointer;
  font-weight:700;
  transition:transform .02s, border-color var(--t), box-shadow var(--t), background-color var(--t);
}
.btn:hover:not(.btn-primary){ background:#fff; }
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.6;cursor:not-allowed}
.btn:focus-visible{outline:none;box-shadow:0 0 0 4px var(--ring)}

.btn-primary{
  color:#fff !important;
  border-color:transparent !important;
  background:var(--btn-primary-gradient) !important;
  background-repeat:no-repeat !important;
  background-origin:border-box !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active{
  color:#fff !important;
  border-color:transparent !important;
  background:var(--btn-primary-gradient) !important;
}

.btn-secondary{ background:var(--surface); border-color:var(--border); color:var(--pi-ink) }

.btn-ghost{
  background:transparent;
  border:1px solid var(--border);
  color:var(--pi-muted);
  font-size:.82rem;
  padding:6px 12px;
  border-radius:999px;
}
.btn-ghost:hover{ background:#f3f6fb;color:var(--pi-primary);border-color:var(--pi-primary) }
.btn-ghost:focus-visible{ outline:none;box-shadow:0 0 0 3px var(--ring);border-color:var(--pi-primary) }

.btn-soft{
  background:color-mix(in srgb, var(--pi-primary) 10%, #fff);
  border-color:color-mix(in srgb, var(--pi-primary) 20%, var(--border));
  color:color-mix(in srgb, var(--pi-primary) 70%, #000);
}
.btn-soft:hover{ border-color:color-mix(in srgb, var(--pi-primary) 32%, var(--border)); }

.btn-small{ padding:6px 14px; font-size:.82rem; border-radius:999px; }
a.btn{ text-decoration:none; }
a.btn-small{ font-weight:700; }

/* Busy spinner */
.btn.is-busy{ position:relative; pointer-events:none; opacity:.92; }
.btn.is-busy::after{
  content:"";
  position:absolute;
  right:12px;
  top:50%;
  width:16px;height:16px;
  margin-top:-8px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.6);
  border-top-color:#fff;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* -----------------------------
   Toggle (tabs, email mode, etc.)
----------------------------- */
.toggle{
  display:inline-flex;
  gap:2px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:999px;
  padding:3px;
}
.toggle button,
.toggle a{
  border:0;
  background:transparent;
  color:var(--pi-muted);
  padding:8px 14px;
  border-radius:999px;
  cursor:pointer;
  font-weight:800 !important;
  font-family:inherit;
  font-size:.92rem;
  text-decoration:none;
  display:inline-block;
  box-sizing:border-box;
  min-width:110px;
  text-align:center;
  line-height:1.2;
}
.toggle button.active,
.toggle a.active{
  background:var(--btn-primary-gradient);
  color:#fff;
}
.toggle button:disabled,
.toggle a[aria-disabled="true"]{
  opacity:.45;
  cursor:not-allowed;
  pointer-events:auto;
}

/* -----------------------------
   Type badge in Overzicht (Flow vs Transactie)
----------------------------- */
.ov-type{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ov-type--flow{
  background:#dbeafe;
  color:#1d4ed8;
}
.ov-type--trans{
  background:#f1f5f9;
  color:#64748b;
}

/* -----------------------------
   Combobox / results
----------------------------- */
.combo{position:relative;max-width:560px}
.combo input{width:100%}
.combo .results{
  position:absolute;
  left:0;right:0;
  top:100%;
  margin-top:6px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  max-height:280px;
  overflow:auto;
  z-index:1000;
  display:none;
}
.combo .results.open{display:block}
.combo .results button{
  display:block;
  width:100%;
  text-align:left;
  border:0;
  background:#fff;
  padding:10px 12px;
  cursor:pointer;
}
.combo .results button:hover,
.combo .results button[aria-selected="true"]{background:#f3f6fb}

/* -----------------------------
   Mail layout
   Aan | Referentie | Soort e-mail
----------------------------- */
#mailForm .mail-row3{
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(260px, 1fr) minmax(320px, 1fr);
  gap: var(--space);
  align-items: start;
  width: 100%;
  margin-top: 12px;
}

#mailForm .mail-row3 > *{ min-width: 0; }

/* Zorg dat labels in de rij dezelfde spacing hebben (voorkomt optische "hoogteverschillen") */
#mailForm .mail-row3 label,
#mailForm .mail-row3 .col-toggle .label-strong{
  display: block;
  margin: 0 0 6px;
  line-height: 1.2;
}

/* Toggle: altijd netjes links en volle breedte */
#mailForm .mail-row3 .col-toggle{
  justify-self: stretch;
  align-self: start;
  min-width: 0;
}

#mailForm .mail-row3 .col-toggle .toggle{
  width: 100%;
  display: flex;
  gap: 8px;              /* optioneel: iets rustiger */
}

#mailForm .mail-row3 .col-toggle .toggle button{
  flex: 1 1 0;
  min-width: 0;
  white-space: nowrap;
}

/* ✅ Wanneer ref weg is → exact 2 kolommen (Aan | Soort e-mail) 50/50
   - Werkt voor: hidden attribute, inline display:none, en class-based hiding als je die later toevoegt.
*/
#mailForm .mail-row3:has(#refField[hidden]),
#mailForm .mail-row3:has(#refField[style*="display:none"]),
#mailForm .mail-row3:has(#refField[style*="display: none"]){
  grid-template-columns: 1fr 1fr;
}

/* Alleen in 2-kolom modus: toggle forceren naar kolom 2 */
#mailForm .mail-row3:has(#refField[hidden]) .col-toggle,
#mailForm .mail-row3:has(#refField[style*="display:none"]) .col-toggle,
#mailForm .mail-row3:has(#refField[style*="display: none"]) .col-toggle{
  grid-column: 2;
}

/* Full width blocks under top row */
#mailForm .mail-full{ width: 100%; margin-top: 12px; }
#mailForm .mail-full input,
#mailForm .mail-full select,
#mailForm .mail-full textarea { width: 100%; }

/* Bottom row spacing */
#mailForm .mail-row2{ margin-top: 16px; }

/* Responsive */
@media (max-width: 900px){
  #mailForm .mail-row3{ grid-template-columns: 1fr; }
  #mailForm .mail-row3 .col-toggle{ grid-column: auto; }
}

/* -----------------------------
   Onboarding steps
----------------------------- */
.onboarding-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
.flow-option{
  display:block;
  padding:14px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:color-mix(in srgb, var(--surface) 70%, #fff);
  transition:border-color var(--t), box-shadow var(--t), background-color var(--t);
}
.flow-option:hover{ border-color:color-mix(in srgb, var(--pi-primary) 35%, var(--border)); }
.flow-option:has(.flow-option-toggle input:checked),
.flow-option:has(.flow-order-btn[aria-pressed="true"]){
  border-color:color-mix(in srgb, var(--pi-primary) 52%, var(--border));
  background:color-mix(in srgb, var(--pi-primary) 10%, #fff);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--pi-primary) 10%, transparent);
}
.flow-option-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.flow-option-heading{
  min-width:0;
}
.flow-option-title{
  font-size:.97rem;
  font-weight:900;
  line-height:1.2;
  margin:0 0 6px;
}
.flow-option-meta{
  margin:0 0 6px;
  color:color-mix(in srgb, var(--pi-primary) 68%, var(--pi-ink));
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.flow-option-text{
  color:var(--pi-muted);
  font-size:.9rem;
  line-height:1.45;
  margin:0;
}
.flow-option-upload{
  margin-top:14px;
  padding-top:14px;
  border-top:1px dashed color-mix(in srgb, var(--border) 80%, #fff);
}
.flow-option-upload[hidden]{
  display:none !important;
}
.flow-option-fields{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  margin-top:10px;
}
.field-title-sm{
  display:block;
  margin:0 0 6px;
  font-size:.84rem;
  font-weight:800;
  color:var(--pi-ink);
}
.flow-option-upload input[type="file"]{
  display:block;
  width:100%;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  color:var(--pi-muted);
}
.flow-option-upload input[type="text"],
.flow-option-upload input[type="number"],
.flow-option-upload textarea{
  width:100%;
}
.upload-state{
  margin-top:8px;
}
.upload-state.is-ready{
  color:var(--ok);
  font-weight:700;
}
.flow-option-toggle{
  cursor:pointer;
  flex:0 0 auto;
}
.flow-option-toggle input{
  appearance:auto;
  -webkit-appearance:checkbox;
  width:18px;
  height:18px;
  margin:0 8px 0 0;
  accent-color:var(--pi-primary);
  vertical-align:-3px;
  border:1px solid var(--border);
  border-radius:4px;
  background:#fff;
}
.flow-option-toggle input:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px var(--ring);
}
/* ── Volgorde-knoppen (1/2/3 of —) per flow-dienst ── */
.flow-order-btn{
  flex:0 0 auto;
  width:36px;
  height:36px;
  border-radius:50%;
  border:2px solid var(--border);
  background:#fff;
  color:var(--pi-muted);
  font-size:.95rem;
  font-weight:900;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background var(--t), border-color var(--t), color var(--t), box-shadow var(--t);
  padding:0;
  line-height:1;
}
.flow-order-btn:hover{
  border-color:var(--pi-primary);
  color:var(--pi-primary);
}
.flow-order-btn[aria-pressed="true"]{
  background:var(--pi-primary);
  border-color:var(--pi-primary);
  color:#fff;
  box-shadow:0 2px 8px color-mix(in srgb, var(--pi-primary) 35%, transparent);
}
/* ── Locked / niet beschikbare dienst ── */
.flow-option--locked{
  background:color-mix(in srgb, var(--surface) 70%, #fff);
}
.flow-option--locked:hover{
  border-color:var(--border);
  box-shadow:none;
}
.flow-option--locked .flow-option-title{
  opacity:.45;
}
.flow-option--locked .flow-order-btn{
  visibility:hidden;
  pointer-events:none;
}
.flow-activate-link{
  display:none;
  margin-top:6px;
  font-size:.82rem;
  color:var(--pi-primary);
  font-weight:600;
  cursor:pointer;
  background:none;
  border:none;
  padding:0;
  text-align:left;
}
.flow-activate-link:hover{
  text-decoration:underline;
}
.flow-option--locked .flow-activate-link{
  display:inline-block;
}
.onboarding-summary{
  margin-top:12px;
  padding:12px 14px;
  border-radius:var(--radius);
  background:color-mix(in srgb, var(--surface) 75%, #fff);
  color:var(--pi-muted);
  font-size:.92rem;
}
@media (max-width:900px){
  .onboarding-grid{grid-template-columns:1fr;}
  .card-headline{flex-wrap:wrap;}
  .flow-option-head{flex-wrap:wrap;}
  .flow-option-fields{grid-template-columns:1fr;}
}



/* -----------------------------
   Overview table + pills
----------------------------- */
.overview-toolbar{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  margin:0 0 14px;
}

.overview-actions-cell{
  min-width:86px;
  white-space:nowrap;
}

.overview-page-title{
  margin:0 0 18px;
  font-size:clamp(1.6rem, 2.4vw, 2.2rem);
  line-height:1.1;
  letter-spacing:-.03em;
  color:var(--pi-ink);
}

.tableWrap{
  overflow:auto;
  border:1px solid var(--border);
  border-radius:var(--radius);
}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{
  padding:10px 12px;
  border-bottom:1px solid color-mix(in srgb, var(--border) 70%, transparent);
  text-align:left;
  vertical-align:top;
}
th{
  font-size:.92rem;
  color:var(--pi-muted);
  font-weight:900;
  white-space:nowrap;
  background:color-mix(in srgb, var(--surface) 80%, #fff);
}
tbody tr:hover{ background:color-mix(in srgb, var(--pi-primary) 6%, #fff); }

.overview-row td{
  padding-top:14px;
  padding-bottom:14px;
}
.overview-main{
  font-weight:800;
  color:var(--pi-ink);
}
.overview-main--mono{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-weight:700;
}
.overview-sub{
  margin-top:4px;
  color:var(--pi-muted);
  font-size:.8rem;
}
.overview-empty{
  color:var(--pi-muted);
  font-size:.88rem;
}
.overview-date{
  white-space:nowrap;
  min-width:118px;
}
.overview-ref{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:4px 10px;
  border-radius:10px;
  background:color-mix(in srgb, var(--surface) 84%, #fff);
  border:1px solid color-mix(in srgb, var(--border) 85%, #fff);
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:.84rem;
  font-weight:700;
  color:var(--pi-ink);
}
.overview-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  min-width:0;
}

.overview-status-cell{
  min-width:90px;
  max-width:120px;
  white-space:nowrap;
}

.overview-cell--truncate .overview-main,
.overview-cell--truncate .overview-empty{
  max-width:180px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.overview-cell--merchant .overview-main,
.overview-cell--merchant .overview-empty{
  max-width:320px;
}
.overview-ref{
  display:inline-block;
  max-width:72px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  vertical-align:middle;
}

.pill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:4px 10px;
  border-radius:999px;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--pi-muted);
  font-size:.82rem;
  font-weight:800;
  white-space:nowrap;
}
.pill .dot{
  width:8px;height:8px;border-radius:999px;
  background:#94a3b8;
}
.pill.sent .dot{ background: color-mix(in srgb, var(--warn) 65%, #f59e0b); }
.pill.open .dot{ background: var(--pi-primary); }
.pill.done .dot{ background: var(--ok); }
.pill.err  .dot{ background: var(--err); }

@media (max-width: 1100px){
  .overview-status-cell{min-width:90px; max-width:110px}
  .overview-actions-cell{min-width:90px}
  .overview-cell--truncate .overview-main,
  .overview-cell--truncate .overview-empty{max-width:130px}
  .overview-cell--merchant .overview-main,
  .overview-cell--merchant .overview-empty{max-width:220px}
  .overview-ref{max-width:60px}
}

/* Links */
.link{color:var(--pi-primary);text-decoration:none;font-weight:800}
.link:hover{text-decoration:underline}
.link:focus-visible{outline:none;box-shadow:0 0 0 4px var(--ring);border-radius:8px}

/* -----------------------------
   Toasts
----------------------------- */
.toast{
  position:fixed;
  right:16px;
  bottom:16px;
  display:grid;
  gap:8px;
  z-index:1100;
}
.toast>div{
  background:#fff;
  border:1px solid var(--border);
  padding:10px 12px;
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
}
.toast .ok{border-color:rgba(34,197,94,.35)}
.toast .err{border-color:rgba(239,68,68,.35)}

#appToast{ z-index:2147483647; }
#appToast .link{ color:inherit; text-decoration:underline; }

/* -----------------------------
   Modal
----------------------------- */
.modal{position:fixed;inset:0;z-index:1200}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.35)}
.modal-card{
  position:relative;
  max-width:720px;
  margin:6vh auto;
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  padding:18px 18px 12px;
  border:1px solid var(--border);
}
.modal-header,.modal-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.modal-header h2{margin:0}
.modal-body .field{margin-top:10px}
.icon-btn{
  appearance:none;
  border:1px solid var(--border);
  background:#fff;
  color:var(--pi-ink);
  padding:6px 10px;
  border-radius:10px;
  cursor:pointer;
  font-weight:800;
  transition:background var(--t),border-color var(--t),box-shadow var(--t);
}
.icon-btn:hover{background:#f9fafb;border-color:#cfd5de}
.icon-btn:focus-visible{outline:none;box-shadow:0 0 0 4px var(--ring)}

/* -----------------------------
   Footer
----------------------------- */
.footer-note{
  text-align:center;
  margin:14px 0 22px;
  padding:0 20px;
  color:var(--pi-muted);
  font-size:.92rem;
}

/* -----------------------------
   Sidebar — MagicMonday style
----------------------------- */

/* Sidebar — force visible on desktop */
.app-sidebar{
  background:#1e2a3a !important;
  border-right:1px solid rgba(255,255,255,.06) !important;
  display:flex !important;
  flex-direction:column !important;
  position:fixed !important;
  left:0 !important; top:0 !important; bottom:0 !important;
  width:250px !important;
  z-index:100 !important;
  overflow:hidden !important;
  font-family:'Inter',system-ui,-apple-system,sans-serif !important;
}
.app-sidebar .app-sidebar-menu{
  flex:1 !important;
  overflow-y:auto !important;
  min-height:0 !important;
  padding-bottom:90px !important;
}
/* Push ALL content to the right of the 250px sidebar */
.app-page,
#kt_app_page{
  margin-left:250px !important;
  width:calc(100vw - 250px) !important;
}
/* Hide Metronic header and footer — we use our own topbar */
.app-header,
#kt_app_header{
  display:none !important;
}
.app-footer,
#kt_app_footer{
  display:none !important;
}

/* ── Topbar (user + logout) ── */
.pi-topbar{
  position:fixed; top:0; right:0;
  left:250px; height:36px; z-index:90;
  display:flex; align-items:center; justify-content:flex-end;
  padding:0 20px; gap:12px;
  background:rgba(248,249,251,.85);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
.pi-topbar-user{
  font-size:.78rem; font-weight:600; color:var(--pi-muted);
}
.pi-topbar-logout{
  font-size:.75rem; font-weight:700; color:var(--pi-muted);
  text-decoration:none; padding:3px 12px; border-radius:6px;
  border:1px solid var(--border); background:var(--card);
  transition:all .12s;
}
.pi-topbar-tour{
  font-size:.75rem; font-weight:700; color:var(--pi-muted);
  text-decoration:none; padding:3px 12px; border-radius:6px;
  border:1px solid var(--border); background:var(--card);
  cursor:pointer; transition:all .12s;
  display:inline-flex; align-items:center; gap:4px;
}
.pi-topbar-tour:hover{
  color:#D4654A; border-color:#D4654A;
}
.pi-topbar-logout:hover{
  color:#D4654A; border-color:#D4654A;
}
@media (max-width:991px){
  .pi-topbar{ left:0; }
}
/* Impersonatie-banner — zichtbaar wanneer admin/partner een ander bekijkt */
.pi-impersonate-banner{
  position:fixed; top:0; right:0;
  left:250px; height:36px; z-index:91;
  display:flex; align-items:center; gap:14px;
  padding:0 20px;
  background:linear-gradient(90deg,#fef0ed 0%,#fff3e0 100%);
  border-bottom:1px solid #f5dca8;
  font-size:.78rem; color:#8a3a1f;
}
.pi-impersonate-icon{ font-size:1rem; line-height:1; color:#D4654A; }
.pi-impersonate-text{ flex:1; }
.pi-impersonate-text strong{ color:#5a1f08; font-weight:800; }
.pi-impersonate-meta{ color:#a05a3f; font-weight:500; margin-left:4px; font-size:.72rem; }
.pi-impersonate-stop{
  background:#D4654A; color:#fff; border:0;
  padding:4px 14px; border-radius:6px;
  font-size:.72rem; font-weight:700; cursor:pointer;
  transition:background .12s;
}
.pi-impersonate-stop:hover{ background:#b8553f; }
/* Topbar schuift omlaag wanneer banner aanwezig is, zodat ze elkaar niet overlappen */
.pi-topbar--impersonating{ top:36px !important; }
@media (max-width:991px){
  .pi-impersonate-banner{ left:0; }
}
.app-wrapper,
#kt_app_wrapper{
  padding-left:0 !important;
}
/* Prevent content overflow */
.app-main,
#kt_app_main{
  width:100% !important;
  max-width:100% !important;
  overflow-x:hidden !important;
}
.app-content,
#kt_app_content,
.app-content .container-fluid,
#kt_app_content_container{
  max-width:100% !important;
  overflow-x:hidden !important;
  box-sizing:border-box !important;
}
/* Force all rows/grids inside content to respect boundaries */
.app-main .row,
#kt_app_main .row{
  max-width:100% !important;
  margin-left:0 !important;
  margin-right:0 !important;
}
.app-main [class*="col-"],
#kt_app_main [class*="col-"]{
  min-width:0 !important;
}

/* ── MagicMonday content area styling ── */
/* Force Inter font on entire app (override Metronic) */
body, .app-main, #kt_app_main,
.app-main *, #kt_app_main *{
  font-family:'Inter',system-ui,-apple-system,sans-serif !important;
}
/* Content area: full width, white background */
.app-main{
  background:#f8f9fb !important;
}
#kt_app_content_container{
  padding:2px 28px 24px !important;
}
/* Remove toolbar whitespace when hidden */
#kt_app_toolbar[style*="display: none"],
#kt_app_toolbar[style*="display:none"]{
  height:0 !important; padding:0 !important; margin:0 !important;
  overflow:hidden !important;
}
/* Compact flash messages */
.app-content .alert:empty,
#kt_app_content .alert:empty{ display:none !important; }
/* Hide duplicate user avatar that floats between header and content */
#kt_app_header + .app-wrapper .sidebar-user-avatar,
.app-page > .sidebar-user-avatar{ display:none !important; }
/* Metronic cards: override to MagicMonday clean style */
.app-main .card{
  background:#fff !important;
  border:1px solid #eaedf2 !important;
  border-radius:12px !important;
  box-shadow:0 1px 3px rgba(0,0,0,.04) !important;
}
.app-main .card-header{
  border-bottom:1px solid #f3f5f8 !important;
  background:transparent !important;
  min-height:auto !important;
  padding:16px 22px !important;
}
.app-main .card-body{
  padding:18px 22px !important;
}
.app-main .card-title h3,
.app-main .card-title{
  font-size:.95rem !important;
  font-weight:800 !important;
  color:#1e2a3a !important;
}
/* Text colors */
.app-main .text-gray-900,
.app-main .text-gray-800{
  color:#1e2a3a !important;
}
.app-main .text-gray-600,
.app-main .text-gray-500,
.app-main .text-muted{
  color:#6b7a8d !important;
}
/* Badges */
.app-main .badge{
  font-weight:700 !important;
  border-radius:6px !important;
}
/* Buttons — coral primary */
.app-main .btn-primary,
.app-main .btn-success{
  background:#D4654A !important;
  border-color:#D4654A !important;
  color:#fff !important;
}
.app-main .btn-primary:hover,
.app-main .btn-success:hover{
  background:#b8533a !important;
  border-color:#b8533a !important;
}
.app-main .btn-light-primary{
  background:#fef0ed !important;
  color:#D4654A !important;
  border-color:#fce0d9 !important;
}
/* Page headings — match sidebar menu item size for unified feel */
.app-main h1,
#kt_app_main h1{
  font-size:1.6rem !important;
  font-weight:900 !important;
  letter-spacing:-.02em !important;
  color:#1e2a3a !important;
}
.app-main h2,
#kt_app_main h2{
  font-size:1.1rem !important;
  font-weight:800 !important;
  color:#1e2a3a !important;
}
@media (max-width:991px){
  .app-sidebar{ display:none !important; }
  .app-header, #kt_app_header{ margin-left:0 !important; }
  .app-wrapper, #kt_app_wrapper{ padding-left:0 !important; }
}

/* Brand row + sidebar collapse-toggle */
.app-sidebar-logo,
#kt_app_sidebar_logo{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  padding:14px 18px 10px !important;
  min-height:48px !important;
}

/* Menu section labels (WEBSITE, MARKETING, etc.)
   v1.5.237 — gesynced met klant-sidebar (.ca-sidebar-section) voor visuele
   consistentie tussen admin en klant. Was 16px 16px 6px + .68rem; nu 8px 12px 4px + .62rem. */
.app-sidebar .menu-item > .menu-content,
.app-sidebar .menu-item > .menu-content .menu-section,
.app-sidebar .menu-content{
  font-size:.62rem !important;
  font-weight:800 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  color:rgba(255,255,255,.32) !important;
  padding:8px 12px 4px !important;
  margin:0 !important;
  background:transparent !important;
  border:none !important;
}
/* Override Metronic's default section color */
.app-sidebar .menu-section{
  color:rgba(255,255,255,.32) !important;
  font-size:.62rem !important;
  font-weight:800 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}
/* Extra ruimte boven elke nieuwe section (behalve de eerste), mirror van klant */
.app-sidebar .menu-item:has(> .menu-content .menu-section):not(:first-of-type){
  margin-top:10px !important;
}

/* Menu items — gesynced met klant .ca-sidebar-item (padding 9px 12px, font .88rem) */
.app-sidebar .menu-item > .menu-link{
  border-radius:8px !important;
  margin:1px 4px !important;
  padding:9px 12px !important;
  transition:all .15s !important;
}
.app-sidebar .menu-item > .menu-link .menu-title{
  font-size:.88rem !important;
  font-weight:600 !important;
  color:rgba(255,255,255,.6) !important;
  transition:color .15s !important;
}
.app-sidebar .menu-item > .menu-link .menu-icon{
  color:rgba(255,255,255,.6) !important;
}
.app-sidebar .menu-item > .menu-link .menu-icon i{
  font-size:1rem !important;
}

/* Nav dot (replaces icons where used) */
.nav-dot{
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
  display:inline-block;
}
.nav-dot.coral   { background:#D4654A; }
.nav-dot.green   { background:#5B8C5A; }
.nav-dot.blue    { background:#8FAFC4; }
.nav-dot.orange  { background:#E9A030; }
.nav-dot.gray    { background:rgba(255,255,255,.25); }

/* Hover */
.app-sidebar .menu-item > .menu-link:hover{
  background:rgba(255,255,255,.06) !important;
}
.app-sidebar .menu-item > .menu-link:hover .menu-title{
  color:rgba(255,255,255,.85) !important;
}

/* Active state — coral pill */
.app-sidebar .menu-item > .menu-link.active,
.app-sidebar .menu-item.here > .menu-link{
  background:#D4654A !important;
}
.app-sidebar .menu-item > .menu-link.active .menu-title,
.app-sidebar .menu-item.here > .menu-link .menu-title{
  color:#fff !important;
  font-weight:700 !important;
}
.app-sidebar .menu-item > .menu-link.active .menu-icon,
.app-sidebar .menu-item.here > .menu-link .menu-icon{
  color:#fff !important;
}
.app-sidebar .menu-item > .menu-link.active .nav-dot,
.app-sidebar .menu-item.here > .menu-link .nav-dot{
  background:rgba(255,255,255,.8) !important;
}

/* Badge count in sidebar */
.sidebar-badge{
  margin-left:auto;
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.6);
  font-size:.7rem; font-weight:700;
  padding:2px 7px; border-radius:99px;
}
.menu-link.active .sidebar-badge,
.here > .menu-link .sidebar-badge{
  background:rgba(255,255,255,.25);
  color:#fff;
}

/* Sidebar footer — hidden, version in topbar */
.app-sidebar-footer{
  display:none !important;
}
.sidebar-user{
  display:flex; align-items:center; gap:10px;
  font-size:.8rem; color:rgba(255,255,255,.4);
}
.sidebar-user-avatar{
  width:30px; height:30px; border-radius:50%;
  background:#D4654A; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:.72rem; font-weight:800; flex-shrink:0;
}

/* Sidebar minimize toggle — hide to keep clean look */
#kt_app_sidebar_toggle{ display:none !important; }

/* ── Growth model in sidebar ── */
.sidebar-growth{
  margin:0 12px 12px;
}
.sidebar-growth-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:0 4px; margin-bottom:8px;
}
.sidebar-growth-label{
  font-size:.6rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:rgba(255,255,255,.3);
}
.sidebar-growth-progress{
  font-size:.65rem; font-weight:700; color:#D4654A;
}

/* Phase steps */
.growth-phase{
  display:flex; align-items:flex-start; gap:0;
  position:relative;
  padding:0 0 0 28px;
  margin-bottom:2px;
}
/* Vertical line */
.growth-phase::before{
  content:'';
  position:absolute; left:10px; top:0; bottom:0;
  width:2px; background:rgba(255,255,255,.08);
}
.growth-phase:last-child::before{ display:none; }

/* Step dot */
.growth-dot{
  position:absolute; left:5px; top:8px;
  width:12px; height:12px; border-radius:50%;
  border:2px solid rgba(255,255,255,.15);
  background:#1e2a3a;
  z-index:1;
  flex-shrink:0;
}
.growth-phase.done .growth-dot{
  background:#5B8C5A; border-color:#5B8C5A;
}
.growth-phase.active .growth-dot{
  background:#D4654A; border-color:#D4654A;
  box-shadow:0 0 0 3px rgba(212,101,74,.25);
}

.growth-body{
  padding:4px 0 12px;
  min-width:0;
}
.growth-title{
  font-size:.8rem; font-weight:600;
  color:rgba(255,255,255,.35);
  line-height:1.3;
}
.growth-phase.done .growth-title{ color:rgba(255,255,255,.5); }
.growth-phase.active .growth-title{ color:#D4654A; font-weight:700; }

.growth-period{
  font-size:.65rem; font-weight:600;
  color:rgba(255,255,255,.2);
  margin-top:2px;
}
.growth-phase.active .growth-period{ color:rgba(255,255,255,.4); }

.growth-agents{
  display:flex; flex-wrap:wrap; gap:4px;
  margin-top:4px;
}
.growth-agent-tag{
  font-size:.58rem; font-weight:700;
  padding:1px 6px; border-radius:4px;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.3);
}
.growth-phase.active .growth-agent-tag{
  background:rgba(212,101,74,.12);
  color:rgba(212,101,74,.8);
}

/* ── Site dropdown in sidebar ── */
.site-dropdown{
  margin:18px 12px 12px;
  position:relative;
}
.site-dropdown-btn{
  display:flex; align-items:center; justify-content:space-between;
  width:100%; padding:10px 14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px; cursor:pointer;
  color:#fff; font-size:.88rem; font-weight:700;
  transition:all .15s;
}
.site-dropdown-btn:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.15);
}
.site-dropdown-btn .site-dot{
  width:8px; height:8px; border-radius:50%;
  background:#5B8C5A; flex-shrink:0;
}
.site-dropdown-btn .site-label{ flex:1; margin-left:10px; text-align:left; }
.site-dropdown-btn .site-arrow{
  font-size:.65rem; color:rgba(255,255,255,.4);
  transition:transform .2s;
}
.site-dropdown.open .site-arrow{ transform:rotate(180deg); }

.site-dropdown-menu{
  display:none; position:absolute; left:0; right:0; top:100%;
  margin-top:4px; padding:4px;
  background:#253548; border:1px solid rgba(255,255,255,.1);
  border-radius:10px; z-index:50;
  box-shadow:0 10px 30px rgba(0,0,0,.3);
}
.site-dropdown.open .site-dropdown-menu{ display:block; }

.site-dropdown-item{
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:7px;
  font-size:.85rem; font-weight:600;
  color:rgba(255,255,255,.6); cursor:pointer;
  transition:all .12s; border:none; background:none;
  width:100%; text-align:left;
}
.site-dropdown-item:hover{
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.9);
}
.site-dropdown-item.active{
  background:rgba(212,101,74,.15);
  color:#fff;
}
.site-dropdown-item .site-dot{
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
}

/* -----------------------------
   Preferences
----------------------------- */
@media (prefers-contrast: more){
  :root{ --ring:rgba(99,102,241,.45); }
  .btn-primary{ filter:contrast(1.05); }
}
@media (prefers-reduced-motion:reduce){
  *{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important
  }
}

/* Dark mode — warm dark variant */
@media (prefers-color-scheme:dark){
  :root{
    --bg:#1a1714;
    --surface:#221f1b;
    --card:#2a2520;
    --border:#3d362f;
    --pi-ink:#e8e4df;
    --pi-muted:#a39a90;

    --shadow-sm:0 2px 10px rgba(0,0,0,.35);
    --shadow-md:0 10px 28px rgba(0,0,0,.45);
    --shadow-lg:0 10px 30px rgba(0,0,0,.6);

    --ok-bg:rgba(91,140,90,.15);
    --err-bg:rgba(185,28,28,.15);
    --warn-bg:rgba(146,64,14,.15);
    --info-bg:rgba(143,175,196,.15);
  }

  select,input[type=email],input[type=text],textarea{
    background:#221f1b;
    border-color:#3d362f;
    color:var(--pi-ink);
  }
  input[readonly], textarea[readonly]{
    background:#1a1714;
    color:#c5bfb7;
  }

  .combo .results,
  .toast>div{
    background:#221f1b;
    border-color:#3d362f;
  }

  table{background:#2a2520}
  th{background:#221f1b}
  tbody tr:hover{ background:rgba(212,101,74,.08); }
}
