/* Welverro App — design system
   Warm & scouting: kampvuur-oranje accent, natuurtinten, paper-warm surfaces. */

:root{
  /* brand */
  --accent:#E16F38;          /* kampvuur oranje */
  --accent-700:#C0492F;      /* dieper baksteen */
  --accent-100:#FBE4D6;
  --accent-50:#FDF1E9;
  --forest:#2F4739;          /* bosgroen, donkere ink/nav */
  --forest-600:#3F6B53;
  --leaf:#3F8E5B;
  --sky:#3E6B8A;
  --sand:#E0A93B;
  --plum:#7A5AE0;

  /* neutrals — warm paper */
  --paper:#FBF7F0;           /* app background */
  --surface:#FFFFFF;
  --surface-2:#F5EFE6;       /* subtle warm panel */
  --ink:#2A2520;
  --ink-2:#6B6259;           /* secondary text */
  --ink-3:#9A9087;           /* tertiary / placeholder */
  --line:#E7DFD2;            /* warm hairline */
  --line-2:#D8CEBE;

  /* semantic */
  --ok:#3F8E5B; --ok-bg:#E7F1E9;
  --warn:#C77C1E; --warn-bg:#FBEFD8;
  --bad:#C0492F; --bad-bg:#F8E2DC;
  --info:#3E6B8A; --info-bg:#E4EDF3;

  /* type */
  --font-display:"Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --font-body:"Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, sans-serif;

  /* spacing scale driven by density tweak */
  --gap:18px;
  --pad:18px;
  --row-h:54px;
  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(42,37,32,.06), 0 1px 3px rgba(42,37,32,.05);
  --shadow:0 4px 14px rgba(42,37,32,.08), 0 1px 3px rgba(42,37,32,.06);
  --shadow-lg:0 18px 50px rgba(42,37,32,.18);
  --nav-w:248px;
}
:root[data-density="compact"]{ --gap:12px; --pad:13px; --row-h:44px; --radius:11px; }
:root[data-density="comfy"]{ --gap:24px; --pad:24px; --row-h:64px; }

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  font-size:15px; line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;margin:0;letter-spacing:-.01em;color:var(--ink);}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent-100)}

/* scrollbars */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px;border:3px solid var(--paper)}
*::-webkit-scrollbar-track{background:transparent}

/* ============ App layout ============ */
.app{display:flex;min-height:100vh;background:var(--paper)}

/* Sidebar (desktop) */
.sidebar{
  width:var(--nav-w);flex:0 0 var(--nav-w);
  background:var(--forest);color:#EDE6DA;
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
}
.sb-brand{display:flex;align-items:center;gap:11px;padding:20px 18px 16px;}
.sb-brand .tent{width:34px;height:34px;color:#EDE6DA;flex:0 0 auto}
.sb-brand .tent svg{display:block;width:100%;height:100%}
.sb-brand b{font-family:var(--font-display);font-size:20px;letter-spacing:-.02em;color:#fff}
.sb-brand small{display:block;font-size:11px;color:#A9BBAE;letter-spacing:.04em;text-transform:uppercase}
.sb-nav{display:flex;flex-direction:column;gap:2px;padding:8px 10px;flex:1;overflow-y:auto}
.sb-sec{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#85A38C;padding:14px 12px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:#D6DED4;font-weight:500;font-size:14.5px;border:none;background:none;width:100%;text-align:left;transition:background .12s;white-space:nowrap}
.nav-item > span:not(.nav-badge){flex:1;overflow:hidden;text-overflow:ellipsis}
.nav-item svg{width:19px;height:19px;flex:0 0 auto;opacity:.85}
.nav-item:hover{background:rgba(255,255,255,.07)}
.nav-item.active{background:var(--accent);color:#fff}
.nav-item.active svg{opacity:1}
.nav-badge{margin-left:auto;background:rgba(255,255,255,.16);border-radius:20px;font-size:11px;padding:1px 8px;font-weight:600}
.nav-item.active .nav-badge{background:rgba(255,255,255,.25)}

/* persona card in sidebar */
.sb-persona{margin:8px 12px 14px;padding:11px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09)}
.sb-persona .row{display:flex;align-items:center;gap:10px}
.avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:14px;flex:0 0 auto;font-family:var(--font-display)}
.sb-persona .nm{font-weight:600;color:#fff;font-size:14px;line-height:1.2}
.sb-persona .rl{font-size:12px;color:#A9BBAE}
.sb-persona .scope{font-size:11.5px;color:#C9D4CB;margin-top:8px;line-height:1.35}
.sb-switch{margin-top:9px;width:100%;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.04);color:#EDE6DA;border-radius:8px;padding:6px;font-size:12.5px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px}
.sb-switch:hover{background:rgba(255,255,255,.12)}

/* main column */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:30;background:rgba(251,247,240,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 26px;height:64px}
.topbar h1{font-size:21px}
.crumb{font-size:12.5px;color:var(--ink-2);font-weight:600;letter-spacing:.02em}
.topbar .spacer{flex:1}
.searchbox{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 12px;width:300px;color:var(--ink-3);font-size:14px}
.searchbox svg{width:16px;height:16px;flex:0 0 auto}
.searchbox input{border:none;background:none;outline:none;flex:1;color:var(--ink);font-size:14px}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--ink-2);position:relative}
.icon-btn:hover{background:var(--surface-2);color:var(--ink)}
.icon-btn svg{width:18px;height:18px}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--accent);border:1.5px solid var(--surface)}

.content{padding:26px;max-width:1280px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head .ttl{font-size:28px}
.page-head .sub{color:var(--ink-2);font-size:14.5px;margin-top:3px}
.page-head .spacer{flex:1}
.head-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.head-actions .new-member{margin-left:auto}

/* ============ Primitives ============ */
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:10px;padding:9px 15px;font-weight:600;font-size:14px;border:1px solid var(--line-2);background:var(--surface);color:var(--ink);transition:.12s;white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn:hover{background:var(--surface-2)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-700);border-color:var(--accent-700)}
.btn.ghost{background:none;border-color:transparent;color:var(--ink-2)}
.btn.ghost:hover{background:var(--surface-2);color:var(--ink)}
.btn.sm{padding:6px 11px;font-size:13px}
.btn.danger{color:var(--bad);border-color:var(--line-2)}
.btn.danger:hover{background:var(--bad-bg)}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-pad{padding:var(--pad)}

.chip{display:inline-flex;align-items:center;gap:6px;border-radius:20px;padding:3px 10px;font-size:12.5px;font-weight:600;background:var(--surface-2);color:var(--ink-2);white-space:nowrap}
.chip .swatch{width:8px;height:8px;border-radius:50%}
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:7px;padding:2px 8px;font-size:12px;font-weight:600}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.bad{background:var(--bad-bg);color:var(--bad)}
.badge.info{background:var(--info-bg);color:var(--info)}
.badge.mut{background:var(--surface-2);color:var(--ink-2)}

.level-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:7px;letter-spacing:.01em}
.lvl-teamleider{background:#FBE4D6;color:#B7431F}
.lvl-leiding{background:#E7F1E9;color:#2E7547}
.lvl-hulpstaf{background:#E4EDF3;color:#345D78}
.lvl-lid{background:#F0ECE3;color:#6B6259}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);font-weight:700;padding:16px 14px 10px;border-bottom:1px solid var(--line)}
.tbl td{padding:0 14px;border-bottom:1px solid var(--line);height:var(--row-h);vertical-align:middle}
.tbl tbody tr{transition:background .1s;cursor:pointer}
.tbl tbody tr:hover{background:var(--accent-50)}
.tbl tbody tr:last-child td{border-bottom:none}

/* avatar small */
.av-sm{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:13px;flex:0 0 auto;font-family:var(--font-display)}
.cell-name{display:flex;align-items:center;gap:11px}
.cell-name .nm{font-weight:600;white-space:nowrap}
.cell-name .meta{font-size:12.5px;color:var(--ink-2)}
.tbl td:first-child{min-width:190px}

/* stat cards */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat .ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.stat .ic svg{width:20px;height:20px}
.stat .v{font-family:var(--font-display);font-size:30px;font-weight:700;line-height:1}
.stat .l{color:var(--ink-2);font-size:13.5px;margin-top:4px}
.stat .delta{font-size:12.5px;font-weight:600;margin-top:8px}

/* segmented control */
.seg{display:inline-flex;background:var(--surface-2);border-radius:10px;padding:3px;gap:2px}
.seg button{border:none;background:none;padding:6px 13px;border-radius:8px;font-size:13.5px;font-weight:600;color:var(--ink-2)}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}

/* field */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-2)}
.field input,.field select,.field textarea{border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;font-size:14px;background:var(--surface);color:var(--ink);outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}
.kv{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line)}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--ink-2);font-size:13.5px}
.kv .v{font-weight:600;text-align:right}

/* section title */
.sect-title{font-family:var(--font-display);font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:12px}
.sect-title .ic{color:var(--accent)}
.sect-title .ic svg{width:17px;height:17px;display:block}

/* mobile bits hidden on desktop */
.mobile-only{display:none}
.tabbar{display:none}
.hamburger{display:none}

/* ============ Responsive: tablet/mobile ============ */
@media (max-width:900px){
  .sidebar{display:none}
  .desktop-only{display:none !important}
  .mobile-only{display:block}
  .hamburger{display:flex}
  .topbar{padding:0 16px;height:58px}
  .searchbox{display:none}
  .content{padding:16px 15px 96px}
  .page-head .ttl{font-size:23px}
  .tabbar{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:rgba(251,247,240,.94);backdrop-filter:blur(14px);
    border-top:1px solid var(--line);padding:7px 6px calc(7px + env(safe-area-inset-bottom));
    justify-content:space-around;
  }
  .tabbar button{flex:1;border:none;background:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink-3);font-size:10.5px;font-weight:600;padding:4px 2px;border-radius:10px}
  .tabbar button svg{width:22px;height:22px}
  .tabbar button.active{color:var(--accent)}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr !important}
  .hide-sm{display:none !important}
  .hide-matrix-mobile{display:none !important}
  .head-actions{width:100%}
}
@media (max-width:560px){
  .stat .v{font-size:25px}
}

/* grids */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.grid-sidebar{display:grid;grid-template-columns:1.7fr 1fr;gap:var(--gap)}
@media (max-width:900px){.grid-sidebar{grid-template-columns:1fr}}

/* PDF-template editor + generate */
.pdf-editor-grid{display:grid;grid-template-columns:190px 1fr 250px;gap:14px;align-items:start}
.pdf-gen-grid{display:grid;grid-template-columns:300px 1fr;gap:18px;align-items:start}
/* Laat de 1fr-kolom écht krimpen onder de intrinsieke 794px-breedte van de A4-iframe.
   Zonder min-width:0 houdt de track ~794px aan -> 100cqi wordt 794 -> scale 1 -> afgeknotte hoek. */
.pdf-gen-grid>*{min-width:0}
.pdf-palette-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;border:1px solid var(--line);background:var(--surface);cursor:grab;font-size:13px;font-weight:600;width:100%;text-align:left}
.pdf-palette-item:hover{border-color:var(--accent)}
.pdf-canvas{width:100%;max-width:794px;aspect-ratio:794/1123;background:#fff;position:relative;box-shadow:var(--shadow-lg);border-radius:2px;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:1.7635% 1.2467%;touch-action:none}
.pdf-fieldbox{position:absolute;border-radius:3px;cursor:move;padding:3px 5px;overflow:hidden;box-sizing:border-box;outline:1px solid transparent}
.pdf-fieldbox.sel{outline:2px solid var(--accent);background:var(--accent-50)}
.pdf-resize{position:absolute;right:-5px;bottom:-5px;width:12px;height:12px;background:var(--accent);border:2px solid #fff;border-radius:3px;cursor:nwse-resize}
.pdf-gen-preview-wrap{width:100%;max-width:794px;aspect-ratio:794/1123;min-height:0;container-type:inline-size;overflow:hidden;background:#fff;box-shadow:var(--shadow-lg);border-radius:2px;cursor:zoom-in}
.pdf-gen-preview{width:794px;height:1123px;border:none;display:block;transform-origin:top left;transform:scale(calc(100cqi / 794px));pointer-events:none}
/* Fallback voor browsers zonder container query-units (oudere mobiele Safari/WebView):
   schaal de A4-iframe weg en laat de wrap scrollen i.p.v. een afgeknotte hoek te tonen. */
@supports not (width: 1cqi){
  .pdf-gen-preview-wrap{aspect-ratio:auto;height:min(80vh,1123px);overflow:auto;-webkit-overflow-scrolling:touch}
  .pdf-gen-preview{transform:none}
}
@media (max-width:1040px){.pdf-gen-grid{grid-template-columns:1fr}}

/* Fullscreen zoom-popup voor de PDF-preview: A4-pagina in een pan/scroll-viewport,
   met zoomknoppen in de balk. De iframe schaalt via transform; de wrapper krijgt de
   geschaalde afmetingen zodat de scrollbalken kloppen. */
.pdf-zoom{display:flex;flex-direction:column;padding:0;z-index:100}
.pdf-zoom-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--forest);color:#fff;flex:0 0 auto}
.pdf-zoom-btn{color:#fff;background:transparent;border-color:transparent}
.pdf-zoom-btn:hover{background:rgba(255,255,255,.14)}
.pdf-zoom-viewport{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;display:flex;padding:16px}
.pdf-zoom-page{flex:0 0 auto;margin:auto;background:#fff;box-shadow:var(--shadow-lg);position:relative}
.pdf-zoom-frame{width:794px;height:1123px;border:none;display:block;transform-origin:top left}

/* drawer for mobile nav */
.scrim{position:fixed;inset:0;background:rgba(42,37,32,.45);z-index:80;opacity:0;pointer-events:none;transition:opacity .2s}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;left:0;bottom:0;width:270px;background:var(--forest);z-index:90;transform:translateX(-100%);transition:transform .24s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;color:#EDE6DA}
.drawer.show{transform:none}

/* empty / helper */
.muted{color:var(--ink-2)}
.tiny{font-size:12px}
.divider{height:1px;background:var(--line);margin:var(--gap) 0}

/* naamkaartje */
.namecard{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:12px 16px;box-shadow:var(--shadow);display:inline-block}

.app-password-row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:11px;
  background:var(--surface-2);
  min-width:0;
}

/* member import */
.import-modal{
  max-width:1040px;
  width:100%;
  padding:0;
  overflow:hidden;
  max-height:90vh;
  display:flex;
  flex-direction:column;
}
.import-modal-head,
.import-modal-foot{
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:1px solid var(--line);
}
.import-modal-foot{
  border-top:1px solid var(--line);
  border-bottom:none;
}
.import-modal-body{
  padding:18px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.import-drop{
  border:1px dashed var(--line-2);
  border-radius:12px;
  background:var(--surface-2);
  padding:16px;
  display:flex;
  align-items:center;
  gap:12px;
  cursor:pointer;
}
.import-drop input{display:none}
.import-drop:hover{border-color:var(--accent);background:var(--accent-50)}
.import-drop strong{display:block}
.import-layout{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(330px,.8fr);
  gap:16px;
  align-items:start;
}
.import-map-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.import-map-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(190px,.7fr);
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:11px;
  background:var(--surface);
}
.import-map-row select{
  width:100%;
  min-width:0;
  border:1px solid var(--line-2);
  border-radius:9px;
  padding:8px 10px;
  background:var(--surface);
  color:var(--ink);
}
.import-preview-table td{
  height:auto;
  padding:11px 12px;
}
@media (max-width:860px){
  .import-modal{
    max-height:94vh;
  }
  .import-layout{
    grid-template-columns:1fr;
  }
  .import-map-row{
    grid-template-columns:1fr;
  }
  .import-modal-foot{
    align-items:stretch;
    flex-wrap:wrap;
  }
  .import-modal-foot .btn{
    flex:1 1 auto;
    justify-content:center;
  }
}

/* calendar create-on-click */
.cal-cell{transition:background .12s, box-shadow .12s}
.cal-cell:hover{box-shadow:inset 0 0 0 1.5px var(--accent)}
.cal-add{opacity:0;color:var(--accent);transition:opacity .12s;display:flex}
.cal-cell:hover .cal-add{opacity:1}
.dynamic-agenda-modal{
  max-width:980px;
  width:100%;
  padding:0;
  overflow:hidden;
  max-height:90vh;
  display:flex;
  flex-direction:column;
}
.dynamic-agenda-head,
.dynamic-agenda-foot{
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:1px solid var(--line);
}
.dynamic-agenda-foot{
  border-top:1px solid var(--line);
  border-bottom:none;
}
.dynamic-agenda-body{
  padding:18px;
  overflow:auto;
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);
  gap:16px;
}
.dynamic-agenda-row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:11px;
  background:var(--surface);
}
.dynamic-role-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin-top:10px;
}
.dynamic-check{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  font-size:13px;
  font-weight:600;
  cursor:pointer;
}
.dynamic-check input{
  accent-color:var(--accent);
}
.dynamic-event-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.dynamic-event-option{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  cursor:pointer;
  min-width:0;
}
.dynamic-event-option input{
  width:16px;
  height:16px;
  flex:0 0 auto;
}
@media (max-width:860px){
  .dynamic-agenda-body{
    grid-template-columns:1fr;
  }
  .dynamic-role-grid{
    grid-template-columns:1fr;
  }
  .dynamic-event-grid{
    grid-template-columns:1fr;
  }
  .dynamic-agenda-row{
    align-items:flex-start;
    flex-wrap:wrap;
  }
  .dynamic-agenda-foot{
    align-items:stretch;
    flex-wrap:wrap;
  }
  .dynamic-agenda-foot .btn{
    flex:1 1 auto;
    justify-content:center;
  }
}
.caldav-modal{
  max-width:680px;
  width:100%;
  padding:0;
  overflow:hidden;
  max-height:90vh;
  display:flex;
  flex-direction:column;
}
.caldav-modal-head,
.caldav-modal-foot{
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:1px solid var(--line);
}
.caldav-modal-foot{
  border-top:1px solid var(--line);
  border-bottom:none;
}
.caldav-modal-body{
  padding:18px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.caldav-info-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.caldav-info-box{
  border:1px solid var(--line);
  border-radius:11px;
  padding:10px 12px;
  background:var(--surface-2);
  min-width:0;
}
.caldav-info-box code{
  display:block;
  margin-top:5px;
  font-size:12.5px;
  white-space:normal;
  overflow-wrap:anywhere;
}
.caldav-password-new{
  margin-top:9px;
  padding:9px;
  border:1px solid var(--accent);
  border-radius:9px;
  background:var(--accent-50);
  display:flex;
  flex-direction:column;
  gap:7px;
}
.caldav-password-actions{
  margin-top:10px;
  display:flex;
  gap:7px;
  flex-wrap:wrap;
}
.caldav-password-actions .btn{
  flex:1 1 auto;
  justify-content:center;
}
.caldav-tabs{
  flex-wrap:wrap;
}
.caldav-tabs button{
  flex:1 1 auto;
}
.caldav-steps{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:9px;
}
.caldav-steps li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:11px 12px;
  border:1px solid var(--line);
  border-radius:11px;
  background:var(--surface);
  line-height:1.45;
}
.caldav-step-n{
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:12px;
  flex:0 0 auto;
}
.caldav-agendas{
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
  background:var(--surface-2);
}
@media (max-width:700px){
  .caldav-info-grid{
    grid-template-columns:1fr;
  }
  .caldav-modal-foot{
    align-items:stretch;
    flex-direction:column;
  }
  .caldav-modal-foot .btn{
    justify-content:center;
  }
}

/* reports */
.reports-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:var(--gap);
}
.report-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.report-field-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.report-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
@media (max-width:900px){
  .reports-grid,
  .report-field-grid,
  .report-form-grid{
    grid-template-columns:1fr;
  }
  .report-card .btn{
    flex:1 1 auto;
    justify-content:center;
  }
}

/* agenda mobile layout */
.agenda-mobile-list{display:none}
@media (max-width:700px){
  .agenda-month-nav{
    display:grid !important;
    grid-template-columns:38px 1fr 38px;
    gap:8px !important;
    align-items:center;
  }
  .agenda-month-nav h2{
    min-width:0 !important;
    font-size:18px !important;
  }
  .agenda-month-nav > .btn{
    grid-column:1 / -1;
    justify-content:center;
  }
  .agenda-month-nav .seg.mobile-only{
    grid-column:1 / -1;
    margin-left:0 !important;
    width:100%;
    display:flex;
  }
  .agenda-month-nav .seg.mobile-only button{flex:1}
  .agenda-filters{
    flex-wrap:nowrap !important;
    overflow-x:auto;
    margin-inline:-15px;
    padding:0 15px 4px;
    scrollbar-width:none;
  }
  .agenda-filters::-webkit-scrollbar{display:none}
  .agenda-filter-chip{
    flex:0 0 auto;
    min-height:36px;
    padding:8px 12px !important;
  }
  .agenda-month-card{
    padding:10px !important;
    border-radius:12px;
  }
  .agenda-month-grid{
    gap:4px !important;
  }
  .agenda-day-cell{
    min-height:48px !important;
    padding:5px 4px !important;
    border-radius:8px !important;
    align-items:center;
    justify-content:flex-start;
  }
  .agenda-day-cell .tiny{
    width:100%;
    justify-content:center;
    margin-bottom:0 !important;
    font-size:12px;
  }
  .agenda-event-pill{
    display:none !important;
  }
  .agenda-day-dots{
    display:flex !important;
    justify-content:center;
    min-height:7px;
  }
  .agenda-day-cell .cal-add{
    display:none !important;
  }
  .agenda-month-card > .tiny.muted{
    display:none;
  }
  .agenda-mobile-list{
    display:flex !important;
  }
}

/* forms mobile layout */
@media (max-width:700px){
  .forms-stats{
    grid-template-columns:repeat(3,1fr) !important;
    gap:8px !important;
  }
  .forms-stats .stat{
    padding:10px 9px;
    min-height:104px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
  }
  .forms-stats .stat .ic{
    width:30px;
    height:30px;
    border-radius:9px;
    margin-bottom:7px;
  }
  .forms-stats .stat .ic svg{
    width:16px;
    height:16px;
  }
  .forms-stats .stat .v{
    font-size:21px;
  }
  .forms-stats .stat .l{
    font-size:11.5px;
    line-height:1.2;
  }
  .forms-shell{
    gap:12px !important;
  }
  .form-card{
    padding:14px !important;
    border-radius:12px;
  }
  .form-card-inner{
    flex-direction:column;
    gap:11px !important;
  }
  .form-card-icon{
    width:36px !important;
    height:36px !important;
    border-radius:10px !important;
  }
  .form-card-body h3{
    font-size:16px !important;
  }
  .form-card-body .chip{
    font-size:11.5px;
    padding:3px 8px;
    max-width:100%;
    white-space:normal;
  }
  .form-card-actions{
    width:100%;
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:8px !important;
  }
  .form-card-actions .btn{
    justify-content:center;
    min-height:38px;
    width:100%;
  }
  .form-card-actions .btn.danger{
    grid-column:auto;
  }
  .forms-filter-card{
    padding:14px !important;
  }
  .forms-filter-row{
    align-items:stretch !important;
    gap:12px !important;
  }
  .forms-filter-select{
    min-width:0 !important;
    width:100%;
  }
  .forms-group-chips{
    flex-wrap:nowrap !important;
    overflow-x:auto;
    margin-inline:-14px;
    padding:0 14px 4px !important;
    scrollbar-width:none;
  }
  .forms-group-chips::-webkit-scrollbar{display:none}
  .forms-group-chips .chip{
    flex:0 0 auto;
    min-height:34px;
  }
  .forms-submission-card{
    padding:14px !important;
  }
  .forms-submission-values{
    grid-template-columns:1fr !important;
  }
  .forms-editor-grid{
    grid-template-columns:1fr !important;
  }
  .forms-editor-settings,
  .forms-fields-card,
  .forms-fill-card{
    padding:14px !important;
    border-radius:12px;
  }
  .forms-fields-head{
    align-items:stretch !important;
    gap:10px;
    flex-direction:column;
  }
  .forms-fields-head select{
    width:100%;
    min-height:40px;
  }
  .forms-field-row{
    grid-template-columns:1fr !important;
    gap:10px !important;
    padding:12px !important;
  }
  .forms-field-row > .btn{
    width:100%;
    justify-content:center;
    min-height:38px;
  }
  .forms-field-row label[style*="grid-column"]{
    grid-column:auto !important;
  }
  .forms-fill-card{
    max-width:none !important;
  }
  .forms-fill-card .field input,
  .forms-fill-card .field select,
.forms-fill-card .field textarea{
    min-height:42px;
  }
}

/* RBAC roles tab: prevent mobile overflow and keep sticky bars clear */
.rbac-roles-tab,
.rbac-role-list,
.rbac-role-detail,
.rbac-groups-tab,
.rbac-group-list,
.rbac-group-detail{
  min-width:0;
  max-width:100%;
}
.rbac-role-card,
.rbac-group-card{
  width:100%;
  min-width:0;
}
.rbac-role-title{
  min-width:0;
  flex-wrap:wrap;
}
.rbac-perm-row{
  min-width:0;
}
.rbac-perm-row > span{
  min-width:0;
}
.rbac-search-bar{
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.rbac-search-input{
  flex:1 1 280px;
  min-width:180px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border:1px solid var(--line-2);
  border-radius:10px;
  background:var(--surface-2);
  color:var(--ink-3);
}
.rbac-search-input input{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  color:var(--ink);
  font:inherit;
  font-size:13.5px;
}
.rbac-search-input input::placeholder{
  color:var(--ink-3);
}
@media (max-width:900px){
  .rbac-roles-tab{
    display:flex !important;
    flex-direction:column;
    width:100%;
    max-width:100%;
    overflow-x:hidden;
    padding-bottom:calc(82px + env(safe-area-inset-bottom));
  }
  .rbac-groups-tab{
    display:flex !important;
    flex-direction:column;
    width:100%;
    max-width:100%;
    overflow-x:hidden;
    padding-bottom:calc(82px + env(safe-area-inset-bottom));
  }
  .rbac-groups-tab .rbac-group-detail{
    display:none !important;
  }
  .rbac-role-card,
  .rbac-group-card{
    padding:12px 13px !important;
    gap:10px !important;
  }
  .rbac-role-card > span:last-child,
  .rbac-group-card > span:last-child{
    align-self:flex-start;
  }
  .rbac-role-detail-head{
    align-items:flex-start !important;
    flex-wrap:wrap;
  }
  .rbac-role-detail-head > div{
    min-width:0;
    flex:1 1 180px !important;
  }
  .rbac-role-detail-head .btn{
    flex:1 1 auto;
    justify-content:center;
  }
  .rbac-perm-row{
    flex-wrap:wrap;
    align-items:flex-start !important;
    gap:8px !important;
  }
  .rbac-perm-row > span:not(.chip){
    flex:1 1 calc(100% - 32px) !important;
  }
  .rbac-perm-row code{
    max-width:100%;
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .rbac-perm-row .chip{
    white-space:normal;
  }
  .rbac-perm-row .btn{
    margin-left:28px;
  }
  .rbac-group-modal-level{
    grid-template-columns:1fr !important;
    gap:7px !important;
  }
  .rbac-group-modal-level select{
    width:100%;
    max-width:none !important;
  }
  .rbac-search-bar{
    align-items:stretch;
  }
  .rbac-search-input{
    flex-basis:100%;
  }
  .rbac-search-bar .btn{
    justify-content:center;
  }
}

/* topbar dropdowns (search results + notifications) */
.tb-pop{position:absolute;top:54px;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);z-index:50;overflow:hidden;animation:popIn .14s ease}
@keyframes popIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.tb-pop .hd{display:flex;align-items:center;gap:8px;padding:12px 15px;border-bottom:1px solid var(--line)}
.pop-item{display:flex;align-items:center;gap:11px;padding:10px 14px;width:100%;border:none;background:none;text-align:left;cursor:pointer;border-bottom:1px solid var(--line)}
.pop-item:last-child{border-bottom:none}
.pop-item:hover{background:var(--accent-50)}
.pop-sec{font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);font-weight:700;padding:9px 14px 5px;background:var(--surface-2)}

/* search box anchored relative */
.searchwrap{position:relative}

/* hover tooltip (allergie) */
.tip-pop{background:var(--ink);color:#fff;border-radius:9px;padding:9px 12px;font-size:12.5px;line-height:1.4;box-shadow:var(--shadow-lg);max-width:240px;pointer-events:none}
.tip-pop b{color:#fff}

/* Blazor foutmelding-UI (verborgen tot er een fout is) */
#blazor-error-ui {
    color-scheme: light only;
    background: #ffe8e6;
    border-top: 1px solid #f5c2bd;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, .1);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.9rem 1.4rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}
#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

/* Auth-pagina's (login/registratie e.d.) — niet in design-prototype, app-stijl aangehouden */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--paper);padding:24px}
.auth-card{width:100%;max-width:404px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px 28px}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.auth-brand .tent{width:38px;height:38px;color:var(--forest);flex:0 0 auto}
.auth-brand .tent svg{display:block;width:100%;height:100%}
.auth-brand b{font-family:var(--font-display);font-size:22px;letter-spacing:-.02em;color:var(--ink);display:block}
.auth-brand small{display:block;font-size:11px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}
.auth-card h1{font-size:21px;margin-bottom:2px}
.auth-form{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.auth-form .btn{justify-content:center;width:100%;padding:11px 15px}
.auth-check{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-2);font-weight:500}
.auth-check input{width:16px;height:16px;accent-color:var(--accent)}
.field-error{color:var(--bad);font-size:12.5px}
.auth-alt{margin-top:6px;padding-top:16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:9px;font-size:13.5px}
.auth-alt a{color:var(--accent);font-weight:600}
.auth-alt a:hover{color:var(--accent-700);text-decoration:underline}
.auth-alt form{margin:0}
.linklike{background:none;border:none;padding:0;color:var(--accent);font-weight:600;font-size:inherit;cursor:pointer;font-family:inherit}
.linklike:hover{color:var(--accent-700);text-decoration:underline}

/* Tweestapsverificatie instellen + herstelcodes */
.setup-steps{margin:18px 0 0;padding:0 0 0 18px;display:flex;flex-direction:column;gap:14px;font-size:13.5px;color:var(--ink-2)}
.setup-steps li{padding-left:4px}
.setup-steps p{margin:0 0 8px}
.setup-steps kbd{display:inline-block;background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:3px 7px;font-family:var(--font-mono,monospace);font-size:13px;letter-spacing:.04em;color:var(--ink)}
.qr-box{display:flex;justify-content:center;padding:14px;background:#fff;border:1px solid var(--line);border-radius:10px;margin:4px 0 2px}
.qr-box svg{width:190px;height:190px;display:block}
.recovery-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:16px}
.recovery-code{background:var(--surface-2);border:1px solid var(--line);border-radius:7px;padding:8px 10px;font-family:var(--font-mono,monospace);font-size:14px;text-align:center;letter-spacing:.06em;color:var(--ink)}
