/* ============================================================
   RIJDOOR TESTRIJDERS — app stylesheet (PWA prototype)
   ============================================================ */
:root{
  --asfalt:#0E0E0E; --asfalt-2:#1A1B17; --asfalt-3:#232419;
  --lime:#E3FC02; --lime-deep:#C7DE00; --wit:#FFFFFF;
  --blauw:#2F6DB0; --oranje:#FF7A33; --groen:#34A06A; --rood:#E0533D;
  --inkt:#16170F; --steen:#6E726A; --steen-licht:#9A9E94;
  --mist:#DCDDD2; --papier:#F4F4EC; --papier-2:#ECECE1;
  --r:18px; --r-sm:12px; --r-lg:26px;
  --shadow:0 1px 2px rgba(20,20,12,.05), 0 8px 26px rgba(20,20,12,.07);
  --shadow-lg:0 22px 60px rgba(20,20,12,.18);
  --fdisp:'Quicksand', system-ui, sans-serif;
  --fbody:'Hanken Grotesk', system-ui, sans-serif;
  --fcode:'JetBrains Mono', ui-monospace, monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--fbody); color:var(--inkt);
  background:#26271f;
  -webkit-font-smoothing:antialiased; font-size:16px; line-height:1.5;
  min-height:100dvh;
}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit}
a{color:inherit}
.disp{font-family:var(--fdisp);font-weight:700;letter-spacing:-.02em;line-height:1.04}
:focus-visible{outline:3px solid var(--lime);outline-offset:2px}
::selection{background:var(--lime);color:var(--asfalt)}

/* ---------- prototype mode switch (chrome) ---------- */
.modebar{
  position:fixed;z-index:200;left:50%;transform:translateX(-50%);bottom:14px;
  display:flex;gap:4px;background:rgba(14,14,14,.92);backdrop-filter:blur(10px);
  border:1px solid #34352b;border-radius:999px;padding:4px;box-shadow:var(--shadow-lg);
}
.modebar button{
  border:none;background:transparent;color:#C9CBC2;font-family:var(--fdisp);font-weight:600;
  font-size:13px;letter-spacing:.01em;padding:8px 16px;border-radius:999px;display:flex;align-items:center;gap:7px;
}
.modebar button.on{background:var(--lime);color:var(--asfalt)}
.modebar button svg{width:15px;height:15px}
.modebar .sep{width:1px;background:#34352b;margin:5px 2px}
.modebar .reset{color:#84877d;font-size:12px;padding:8px 12px}
@media print{.modebar{display:none}}

/* =================================================================
   PHONE / APP SHELL (testrijder)
   ================================================================= */
.phonewrap{
  min-height:100dvh;display:flex;align-items:stretch;justify-content:center;
  padding:0;
}
@media(min-width:560px){
  .phonewrap{padding:26px 16px;align-items:flex-start}
}
.app{
  position:relative;width:100%;max-width:430px;min-height:100dvh;
  background:var(--papier);display:flex;flex-direction:column;overflow:hidden;
}
@media(min-width:560px){
  .app{min-height:auto;height:880px;max-height:calc(100dvh - 52px);border-radius:42px;
    box-shadow:var(--shadow-lg);border:9px solid #0b0b0b;}
}
.appscroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.appscroll::-webkit-scrollbar{width:0}

/* app header bar */
.abar{
  flex:none;background:var(--asfalt);color:var(--wit);
  padding:max(14px,env(safe-area-inset-top)) 18px 14px;
  display:flex;align-items:center;gap:12px;position:relative;z-index:5;
}
.abar .rd{height:22px}
.abar .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.abar .pill{
  font-family:var(--fdisp);font-weight:600;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--asfalt);background:var(--lime);padding:5px 11px;border-radius:999px;
}
.abar . icon,.abar .iconbtn{background:transparent;border:none;color:var(--wit);padding:6px;display:flex}
.abar .iconbtn svg{width:21px;height:21px}

/* ---------- login / onboarding (dark hero) ---------- */
.hero{
  background:var(--asfalt);color:var(--wit);flex:1;display:flex;flex-direction:column;
  padding:max(26px,env(safe-area-inset-top)) 28px 30px;position:relative;overflow-y:auto;min-height:100dvh;
}
@media(min-width:560px){.hero{min-height:0}}
.hero::-webkit-scrollbar{width:0}
.hero .ghost{position:absolute;right:-130px;top:-40px;width:330px;opacity:.07;z-index:0}
.hero .ghost.b{right:auto;left:-150px;top:auto;bottom:-90px;width:300px;opacity:.05}
.hero > *{position:relative;z-index:2}
.hero .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;flex:none}
.hero .top .rd{height:26px}
.hero .eyebrow{
  font-family:var(--fdisp);font-weight:700;font-size:12px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--lime);margin:0 0 16px;
}
.hero h1{font-family:var(--fdisp);font-weight:700;font-size:clamp(33px,9.5vw,42px);line-height:.97;letter-spacing:-.02em;margin:0;color:var(--wit)}
.hero h1 .y{color:var(--lime)}
.hero .lead{color:#C2C4BB;font-size:15.5px;line-height:1.45;margin:14px 0 0;max-width:330px}
.hero .heroblock{margin-top:0;padding-top:4px}

/* code input */
.codefield{margin-top:20px}
.codefield label{display:block;font-family:var(--fdisp);font-weight:600;font-size:13px;color:#9DA096;margin:0 0 9px;letter-spacing:.02em}
.codeinput{
  width:100%;background:var(--asfalt-2);border:1.5px solid #34352b;border-radius:16px;
  color:var(--wit);font-family:var(--fcode);font-weight:700;font-size:26px;letter-spacing:.22em;
  text-align:center;text-transform:uppercase;padding:18px 14px;
}
.codeinput::placeholder{color:#4d4f44;letter-spacing:.22em}
.codeinput:focus{border-color:var(--lime);outline:none}
.codeinput.err{border-color:var(--rood);animation:shake .35s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-7px)}75%{transform:translateX(7px)}}
.codehint{font-size:13px;color:#84877d;margin:12px 2px 0;line-height:1.45}
.codehint b{color:#C2C4BB;font-weight:600}
.errline{color:var(--oranje);font-size:13.5px;font-weight:600;margin:12px 2px 0;min-height:18px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;
  font-family:var(--fdisp);font-weight:700;font-size:16.5px;letter-spacing:.01em;
  border:none;border-radius:15px;padding:16px 22px;transition:transform .08s, background .15s, box-shadow .15s;
}
.btn:active{transform:translateY(1px)}
.btn svg{width:19px;height:19px}
.btn-lime{background:var(--lime);color:var(--asfalt);box-shadow:0 8px 22px rgba(227,252,2,.22)}
.btn-lime:hover{background:var(--lime-deep)}
.btn-dark{background:var(--asfalt);color:var(--lime)}
.btn-dark:hover{background:var(--asfalt-2)}
.btn-ghost{background:transparent;color:var(--inkt);border:1.5px solid var(--mist)}
.btn-ghost:hover{border-color:var(--steen)}
.btn-outline-w{background:transparent;color:var(--wit);border:1.5px solid #3a3c31}
.btn[disabled]{opacity:.45;pointer-events:none}
.btn-sm{width:auto;font-size:14px;padding:11px 17px;border-radius:12px}
.btn-block{width:100%}

/* =================================================================
   CONTENT SCREENS (testrijder light)
   ================================================================= */
.scr{padding:22px 20px 30px}
.scr-hd{margin-bottom:18px}
.scr-hd .eyebrow{font-family:var(--fdisp);font-weight:700;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--steen);margin:0 0 6px}
.scr-hd h2{font-family:var(--fdisp);font-weight:700;font-size:27px;line-height:1.06;letter-spacing:-.02em;margin:0}
.scr-hd p{color:var(--steen);font-size:15px;margin:8px 0 0;line-height:1.5}

/* route card */
.routecard{
  background:var(--asfalt);color:var(--wit);border-radius:var(--r-lg);padding:22px;position:relative;overflow:hidden;
}
.routecard .ghost{position:absolute;right:-50px;bottom:-60px;width:180px;opacity:.10}
.routecard .lbl{font-family:var(--fdisp);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--lime);position:relative;z-index:2}
.routecard h3{font-family:var(--fdisp);font-weight:700;font-size:23px;line-height:1.06;margin:8px 0 0;position:relative;z-index:2}
.routecard .meta{display:flex;gap:18px;margin-top:16px;position:relative;z-index:2}
.routecard .meta div{font-size:12.5px;color:#A9AD9F}
.routecard .meta b{display:block;font-family:var(--fdisp);font-weight:700;color:var(--wit);font-size:15px}

/* steps (onboarding / uitleg) */
.steps{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.step{display:flex;gap:15px;align-items:flex-start;background:var(--wit);border:1px solid var(--mist);border-radius:var(--r);padding:16px 17px}
.step .n{flex:none;width:30px;height:30px;border-radius:50%;background:var(--lime);color:var(--asfalt);font-family:var(--fdisp);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center}
.step .tx h4{font-family:var(--fdisp);font-weight:700;font-size:16px;margin:2px 0 3px}
.step .tx p{margin:0;font-size:14px;color:var(--steen);line-height:1.45}
.step .tx code{font-family:var(--fcode);font-weight:700;font-size:13px;background:var(--papier-2);padding:1px 6px;border-radius:5px;color:var(--inkt)}

/* app-link card with QR */
.applink{display:flex;gap:16px;align-items:center;background:var(--lime);border-radius:var(--r);padding:16px 18px;margin-top:4px;position:relative;overflow:hidden}
.applink .qr{flex:none;width:78px;height:78px;background:var(--wit);border-radius:12px;padding:6px;box-shadow:0 8px 18px rgba(20,20,12,.16)}
.applink .qr img{width:100%;height:100%}
.applink .tx h4{font-family:var(--fdisp);font-weight:700;font-size:16px;margin:0 0 3px;color:var(--asfalt)}
.applink .tx p{margin:0;font-size:13px;color:#2c3000;line-height:1.4}
.applink .tx .codechip{display:inline-block;font-family:var(--fcode);font-weight:700;font-size:14px;letter-spacing:.08em;background:var(--asfalt);color:var(--lime);padding:3px 10px;border-radius:7px;margin-top:8px}

/* notes list */
.sectitle{display:flex;align-items:center;gap:10px;margin:26px 2px 12px;font-family:var(--fdisp);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--steen)}
.sectitle .count{background:var(--asfalt);color:var(--lime);border-radius:999px;font-size:12px;padding:2px 9px;letter-spacing:0}
.sectitle::after{content:"";flex:1;height:1.5px;background:var(--mist)}

.note{background:var(--wit);border:1px solid var(--mist);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);margin-bottom:12px}
.note .ph{width:100%;aspect-ratio:16/10;object-fit:cover;background:var(--papier-2);display:block}
.note .nbody{padding:14px 16px}
.note .nbody p.txt{margin:0;font-size:15px;line-height:1.45;color:var(--inkt)}
.note .nmeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:11px;font-size:12.5px;color:var(--steen)}
.note .nmeta .loc{display:inline-flex;align-items:center;gap:5px;background:var(--papier-2);padding:4px 9px;border-radius:999px;color:var(--inkt);font-weight:500}
.note .nmeta .loc svg{width:13px;height:13px}
.note .nmeta .dot{width:3px;height:3px;border-radius:50%;background:var(--steen-licht)}

/* status chips */
.statuschip{display:inline-flex;align-items:center;gap:6px;font-family:var(--fdisp);font-weight:700;font-size:11px;letter-spacing:.04em;padding:4px 10px;border-radius:999px}
.statuschip .sd{width:7px;height:7px;border-radius:50%}
.st-Nieuw{background:#eef1e6;color:#5b6047}
.st-Nieuw .sd{background:var(--steen)}
.st-Bekeken{background:#e6eef6;color:#234e77}
.st-Bekeken .sd{background:var(--blauw)}
.st-Wordt{background:#fff0e6;color:#b1531f}
.st-Wordt .sd{background:var(--oranje)}
.st-Verwerkt{background:#e4f5ec;color:#1f7a4e}
.st-Verwerkt .sd{background:var(--groen)}
.st-Afgewezen{background:#fbe7e3;color:#a23522}
.st-Afgewezen .sd{background:var(--rood)}

/* empty state */
.empty{text-align:center;padding:34px 24px;color:var(--steen)}
.empty .ic{width:54px;height:54px;margin:0 auto 14px;opacity:.5}
.empty h4{font-family:var(--fdisp);font-weight:700;font-size:17px;color:var(--inkt);margin:0 0 5px}
.empty p{margin:0;font-size:14px;line-height:1.5}

/* sticky bottom action */
.appfoot{
  flex:none;background:rgba(244,244,236,.92);backdrop-filter:blur(10px);border-top:1px solid var(--mist);
  padding:12px 18px max(12px,env(safe-area-inset-bottom));
}

/* =================================================================
   NOTE COMPOSER
   ================================================================= */
.composer{display:flex;flex-direction:column;gap:18px}
.field label{display:block;font-family:var(--fdisp);font-weight:700;font-size:14px;margin:0 0 8px}
.field label .req{color:var(--oranje)}
.field label .opt{color:var(--steen);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-left:6px}
.field .help{font-size:13px;color:var(--steen);margin:8px 2px 0;line-height:1.45}
.ta{
  width:100%;background:var(--wit);border:1.5px solid var(--mist);border-radius:var(--r-sm);
  padding:14px;font-size:16px;line-height:1.5;color:var(--inkt);resize:vertical;min-height:120px;
}
.ta:focus{border-color:var(--asfalt);outline:none}

/* photo dropzone */
.photoadd{
  width:100%;border:2px dashed var(--steen-licht);border-radius:var(--r);background:var(--papier-2);
  padding:26px 18px;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--steen);text-align:center;
}
.photoadd svg{width:34px;height:34px;color:var(--asfalt)}
.photoadd .t{font-family:var(--fdisp);font-weight:700;font-size:15px;color:var(--inkt)}
.photoadd .s{font-size:12.5px}
.photopreview{position:relative;border-radius:var(--r);overflow:hidden;background:var(--asfalt)}
.photopreview img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.photopreview .rm{position:absolute;top:10px;right:10px;background:rgba(14,14,14,.78);color:#fff;border:none;border-radius:999px;width:34px;height:34px;display:flex;align-items:center;justify-content:center}
.photopreview .rm svg{width:17px;height:17px}
.photopreview .edit{position:absolute;bottom:10px;right:10px;background:rgba(244,244,236,.94);color:var(--asfalt);border:none;border-radius:999px;font-family:var(--fdisp);font-weight:700;font-size:12.5px;padding:7px 13px;display:flex;align-items:center;gap:6px}
.photopreview .edit svg{width:14px;height:14px}

/* location field */
.locbox{background:var(--wit);border:1.5px solid var(--mist);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:12px}
.locbox.on{border-color:var(--groen)}
.locstate{display:flex;align-items:center;gap:12px}
.locstate .ic{flex:none;width:40px;height:40px;border-radius:11px;background:var(--papier-2);display:flex;align-items:center;justify-content:center}
.locbox.on .locstate .ic{background:#e4f5ec}
.locstate .ic svg{width:21px;height:21px;color:var(--steen)}
.locbox.on .locstate .ic svg{color:var(--groen)}
.locstate .tx{flex:1;min-width:0}
.locstate .tx .s1{font-family:var(--fdisp);font-weight:700;font-size:14.5px}
.locstate .tx .s2{font-size:12.5px;color:var(--steen);font-variant-numeric:tabular-nums}
.locspin{width:18px;height:18px;border:2.5px solid var(--mist);border-top-color:var(--asfalt);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.lab-input{width:100%;background:var(--papier);border:1.5px solid var(--mist);border-radius:10px;padding:11px 13px;font-size:15px}
.lab-input:focus{border-color:var(--asfalt);outline:none}

/* =================================================================
   PHOTO EDITOR (modal, EXIF + zoom + rotate)
   ================================================================= */
.peditor{position:fixed;inset:0;z-index:300;background:#0b0b0b;display:flex;flex-direction:column;touch-action:none}
.peditor .pe-bar{flex:none;display:flex;align-items:center;justify-content:space-between;padding:max(14px,env(safe-area-inset-top)) 18px 12px;color:#fff}
.peditor .pe-bar .t{font-family:var(--fdisp);font-weight:700;font-size:15px}
.peditor .pe-bar button{background:transparent;border:none;color:#fff;font-family:var(--fdisp);font-weight:700;font-size:15px;padding:6px 4px}
.peditor .pe-bar .done{color:var(--lime)}
.pe-stage{flex:1;position:relative;overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center;margin:0 auto;width:100%}
.pe-frame{position:relative;width:100%;max-width:520px;aspect-ratio:4/3;overflow:hidden;touch-action:none;cursor:grab;background:#000}
.pe-frame:active{cursor:grabbing}
.pe-frame canvas{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}
.pe-frame .gridlines{position:absolute;inset:0;pointer-events:none;background:
  linear-gradient(to right,transparent 33.3%,rgba(255,255,255,.18) 33.3%,rgba(255,255,255,.18) 33.5%,transparent 33.5%,transparent 66.6%,rgba(255,255,255,.18) 66.6%,rgba(255,255,255,.18) 66.8%,transparent 66.8%),
  linear-gradient(to bottom,transparent 33.3%,rgba(255,255,255,.18) 33.3%,rgba(255,255,255,.18) 33.5%,transparent 33.5%,transparent 66.6%,rgba(255,255,255,.18) 66.6%,rgba(255,255,255,.18) 66.8%,transparent 66.8%);}
.pe-controls{flex:none;padding:18px 22px max(20px,env(safe-area-inset-bottom));background:#0b0b0b;display:flex;flex-direction:column;gap:16px}
.pe-row{display:flex;align-items:center;gap:14px}
.pe-row .ico{flex:none;color:#9DA096;display:flex}
.pe-row .ico svg{width:20px;height:20px}
.pe-slider{-webkit-appearance:none;appearance:none;flex:1;height:5px;border-radius:99px;background:#34352b;outline:none;accent-color:var(--lime)}
.pe-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--lime);border:3px solid #0b0b0b;box-shadow:0 2px 6px rgba(0,0,0,.5)}
.pe-slider::-moz-range-thumb{width:24px;height:24px;border:3px solid #0b0b0b;border-radius:50%;background:var(--lime)}
.pe-btnrow{display:flex;gap:10px}
.pe-iconbtn{flex:1;background:#1a1b15;border:1px solid #34352b;color:#fff;border-radius:12px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:5px;font-family:var(--fdisp);font-weight:600;font-size:11.5px}
.pe-iconbtn svg{width:20px;height:20px}
.pe-iconbtn:active{background:#232419}

/* =================================================================
   ADMIN
   ================================================================= */
.admin{min-height:100dvh;background:var(--papier);display:flex;flex-direction:column}
.adminnav{position:sticky;top:0;z-index:40;background:var(--asfalt);color:var(--wit)}
.adminnav .in{max-width:1080px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;gap:16px}
.adminnav .rd{height:23px}
.adminnav .tag{font-family:var(--fdisp);font-weight:600;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--asfalt);background:var(--lime);padding:4px 10px;border-radius:999px}
.adminnav .sp{margin-left:auto}
.adminnav .who{font-size:13px;color:#9DA096;display:flex;align-items:center;gap:8px}
.adminwrap{max-width:1080px;margin:0 auto;width:100%;padding:26px 24px 90px}
@media(max-width:620px){.adminwrap{padding:18px 16px 90px}}

.adminhd{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.adminhd .eyebrow{font-family:var(--fdisp);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--steen);margin:0 0 6px}
.adminhd h1{font-family:var(--fdisp);font-weight:700;font-size:clamp(26px,4vw,36px);letter-spacing:-.02em;margin:0}
.adminhd p{margin:6px 0 0;color:var(--steen);font-size:15px}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
@media(max-width:620px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--wit);border:1px solid var(--mist);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow)}
.stat .v{font-family:var(--fdisp);font-weight:700;font-size:30px;line-height:1;letter-spacing:-.02em}
.stat .l{font-size:13px;color:var(--steen);margin-top:6px}
.stat.accent{background:var(--asfalt);color:var(--wit)}
.stat.accent .v{color:var(--lime)}
.stat.accent .l{color:#A9AD9F}

/* participant table / cards */
.panel{background:var(--wit);border:1px solid var(--mist);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.panel .ph{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--mist);flex-wrap:wrap}
.panel .ph h3{font-family:var(--fdisp);font-weight:700;font-size:17px;margin:0}
.ptable{width:100%;border-collapse:collapse}
.ptable th{text-align:left;font-family:var(--fdisp);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--steen);padding:12px 20px;border-bottom:1px solid var(--mist);background:var(--papier-2)}
.ptable td{padding:14px 20px;border-bottom:1px solid var(--papier-2);font-size:14.5px;vertical-align:middle}
.ptable tr:last-child td{border-bottom:none}
.ptable tr.clk{cursor:pointer;transition:background .12s}
.ptable tr.clk:hover{background:var(--papier)}
.ptable .nm{font-family:var(--fdisp);font-weight:700;font-size:15px}
.ptable .em{color:var(--steen);font-size:13px}
.ptable .codecell{font-family:var(--fcode);font-weight:700;font-size:14px;letter-spacing:.06em}
.ptable .mut{color:var(--steen)}
.miniroute{display:inline-flex;align-items:center;gap:7px}
.miniroute .dotc{width:8px;height:8px;border-radius:50%;flex:none}
@media(max-width:720px){.hide-sm{display:none}}

/* card list (mobile admin) */
.pcards{display:flex;flex-direction:column}
.pcardrow{display:flex;align-items:center;gap:13px;padding:15px 18px;border-bottom:1px solid var(--papier-2);cursor:pointer}
.pcardrow:last-child{border-bottom:none}
.pcardrow:active{background:var(--papier)}
.pcardrow .av{flex:none;width:42px;height:42px;border-radius:12px;background:var(--asfalt);color:var(--lime);font-family:var(--fdisp);font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center}
.pcardrow .gr{flex:1;min-width:0}
.pcardrow .gr .nm{font-family:var(--fdisp);font-weight:700;font-size:15.5px}
.pcardrow .gr .sub{font-size:12.5px;color:var(--steen);display:flex;align-items:center;gap:7px;margin-top:2px}
.pcardrow .gr .sub code{font-family:var(--fcode);font-weight:700;letter-spacing:.05em}
.pcardrow .chev{color:var(--steen-licht);flex:none}

/* generic chips/badges */
.tag-pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--fdisp);font-weight:600;font-size:12px;background:var(--papier-2);color:var(--inkt);padding:4px 10px;border-radius:999px}
.codetag{font-family:var(--fcode);font-weight:700;letter-spacing:.06em;background:var(--asfalt);color:var(--lime);padding:4px 11px;border-radius:8px;font-size:13.5px;display:inline-block}

/* =================================================================
   MODAL / SHEET
   ================================================================= */
.scrim{position:fixed;inset:0;z-index:250;background:rgba(14,14,14,.5);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
@media(min-width:620px){.scrim{align-items:center}}
@keyframes fade{from{opacity:0}}
.sheet{background:var(--papier);width:100%;max-width:520px;max-height:92dvh;overflow-y:auto;border-radius:24px 24px 0 0;animation:rise .25s cubic-bezier(.2,.8,.2,1)}
@media(min-width:620px){.sheet{border-radius:22px;max-height:88dvh}}
@keyframes rise{from{transform:translateY(40px);opacity:.6}}
.sheet-hd{position:sticky;top:0;background:var(--papier);display:flex;align-items:center;justify-content:space-between;padding:20px 22px 14px;z-index:2}
.sheet-hd h3{font-family:var(--fdisp);font-weight:700;font-size:20px;margin:0}
.sheet-hd .x{background:var(--papier-2);border:none;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center}
.sheet-hd .x svg{width:18px;height:18px}
.sheet-bd{padding:4px 22px 24px}
.sheet-bd .field{margin-bottom:16px}
.in{width:100%;background:var(--wit);border:1.5px solid var(--mist);border-radius:12px;padding:13px 14px;font-size:16px;color:var(--inkt)}
.in:focus{border-color:var(--asfalt);outline:none}
.lab{display:block;font-family:var(--fdisp);font-weight:700;font-size:13.5px;margin:0 0 7px}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:fit-content;background:var(--wit);border:1.5px solid var(--mist);border-radius:11px;padding:11px 12px;font-family:var(--fdisp);font-weight:600;font-size:13.5px;color:var(--inkt);display:flex;align-items:center;gap:8px;justify-content:center}
.seg button.sel{border-color:var(--asfalt);background:var(--asfalt);color:var(--wit)}
.seg button .dotc{width:9px;height:9px;border-radius:50%;flex:none}

/* detail (participant) */
.detail-hero{background:var(--asfalt);color:var(--wit);border-radius:var(--r);padding:22px;display:flex;align-items:center;gap:16px;position:relative;overflow:hidden;margin-bottom:18px}
.detail-hero .av{flex:none;width:56px;height:56px;border-radius:15px;background:var(--lime);color:var(--asfalt);font-family:var(--fdisp);font-weight:700;font-size:22px;display:flex;align-items:center;justify-content:center}
.detail-hero .nm{font-family:var(--fdisp);font-weight:700;font-size:21px}
.detail-hero .em{color:#A9AD9F;font-size:14px;margin-top:2px}
.detail-hero .codetag{margin-top:0}
.detail-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;align-items:start}
@media(max-width:760px){.detail-grid{grid-template-columns:1fr}}

/* admin note review item */
.rnote{background:var(--wit);border:1px solid var(--mist);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px}
.rnote .top{display:flex;gap:14px;padding:14px}
.rnote .thumb{flex:none;width:96px;height:96px;border-radius:12px;object-fit:cover;background:var(--papier-2)}
.rnote .thumb.none{display:flex;align-items:center;justify-content:center;color:var(--steen-licht)}
.rnote .thumb.none svg{width:26px;height:26px}
.rnote .meat{flex:1;min-width:0}
.rnote .meat p{margin:0;font-size:14.5px;line-height:1.45}
.rnote .meat .sub{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:9px;font-size:12px;color:var(--steen)}
.rnote .meat .sub .loc{display:inline-flex;align-items:center;gap:5px}
.rnote .meat .sub .loc svg{width:12px;height:12px}
.rnote .act{border-top:1px solid var(--papier-2);padding:12px 14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--papier)}
.rnote .act .lbltxt{font-family:var(--fdisp);font-weight:700;font-size:12px;color:var(--steen);text-transform:uppercase;letter-spacing:.06em}

/* changelog timeline */
.timeline{margin-top:10px;padding-left:4px}
.tl{display:flex;gap:11px;padding-bottom:11px;position:relative}
.tl:not(:last-child)::before{content:"";position:absolute;left:5px;top:16px;bottom:0;width:2px;background:var(--mist)}
.tl .d{flex:none;width:12px;height:12px;border-radius:50%;margin-top:3px;border:2px solid var(--papier);box-shadow:0 0 0 1px var(--mist)}
.tl .c .l{font-family:var(--fdisp);font-weight:700;font-size:13.5px}
.tl .c .t{font-size:12px;color:var(--steen);font-variant-numeric:tabular-nums;margin-top:1px}

/* toast */
.toast{position:fixed;left:50%;bottom:74px;transform:translateX(-50%);z-index:400;background:var(--asfalt);color:var(--wit);
  font-family:var(--fdisp);font-weight:600;font-size:14px;padding:13px 20px;border-radius:999px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:10px;animation:toastin .3s;max-width:90vw}
.toast svg{width:17px;height:17px;color:var(--lime);flex:none}
@keyframes toastin{from{transform:translate(-50%,12px);opacity:0}}

/* mail log row */
.maillog{display:flex;gap:11px;align-items:flex-start;padding:12px 0;border-top:1px solid var(--papier-2)}
.maillog:first-child{border-top:none}
.maillog .mi{flex:none;width:32px;height:32px;border-radius:9px;background:var(--papier-2);display:flex;align-items:center;justify-content:center;color:var(--steen)}
.maillog .mi svg{width:16px;height:16px}
.maillog .mc .s{font-family:var(--fdisp);font-weight:700;font-size:14px}
.maillog .mc .t{font-size:12px;color:var(--steen);margin-top:1px}

/* misc helpers */
.muted{color:var(--steen)}
.row{display:flex;gap:10px}
.row.wrap{flex-wrap:wrap}
.grow{flex:1}
.center{text-align:center}
.spacer{height:14px}
.divid{height:1px;background:var(--mist);margin:18px 0}
.installhint{display:flex;gap:10px;align-items:center;background:var(--asfalt-2);border:1px solid #34352b;border-radius:14px;padding:12px 14px;color:#C2C4BB;font-size:12.5px;line-height:1.4;margin-top:14px}
.installhint svg{width:20px;height:20px;color:var(--lime);flex:none}
.installhint b{color:#fff;font-weight:600}
