@import url("https://fonts.googleapis.com/css2?family=Orbitron:wght@500;600;700;800&display=swap");
:root{
  --bg:#06101f;--panel:rgba(8,18,35,.82);--panel2:rgba(10,24,45,.78);
  --line:rgba(108,161,255,.24);--line2:rgba(108,161,255,.42);
  --blue:#6aa1ff;--cyan:#22d3ff;--green:#42d392;--gold:#ffd166;--orange:#f2a62a;
  --text:#eef4ff;--muted:#9fafca;--dark:#030916;
}
*{box-sizing:border-box}html,body{margin:0;width:100%;min-height:100%;overflow-x:hidden;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif}body:before{content:"";position:fixed;inset:0;background:linear-gradient(90deg,rgba(3,9,20,.90),rgba(6,16,31,.74) 48%,rgba(6,16,31,.92)),url("assets/logo_porstech.png") center/cover no-repeat;z-index:-3}body:after{content:"";position:fixed;inset:0;background:radial-gradient(circle at 72% 12%,rgba(66,211,146,.13),transparent 28%),radial-gradient(circle at 20% 0%,rgba(106,161,255,.17),transparent 25%),linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.016) 1px,transparent 1px);background-size:auto,auto,22px 22px,22px 22px;z-index:-2;pointer-events:none}.machine-shell{width:100%;min-height:100vh;overflow-x:hidden}.machine-header{position:sticky;top:0;z-index:30;display:grid;grid-template-columns:minmax(280px,370px) minmax(520px,1fr) minmax(290px,410px);align-items:center;gap:16px;min-height:108px;padding:14px 24px;border-bottom:1px solid var(--line);background:linear-gradient(90deg,rgba(4,10,20,.96),rgba(8,18,35,.70),rgba(4,10,20,.96)),url("assets/logo_porstech.png") center/cover no-repeat;box-shadow:0 18px 55px rgba(0,0,0,.32)}.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--text);min-width:0}.brand img{height:78px;width:78px;object-fit:cover;border-radius:4px;filter:drop-shadow(0 10px 22px rgba(0,0,0,.55))}.brand-text{display:grid;line-height:1}.brand-text strong{font-size:31px;letter-spacing:-1.3px}.brand-text small{font-size:18px;color:#d8e3f8;font-weight:800}.brand-text em{margin-top:4px;color:var(--gold);font-size:11px;font-style:normal;font-weight:900;letter-spacing:.11em}.doc-tabs{display:flex;justify-content:center;border:1px solid var(--line2);border-radius:14px;overflow:hidden;min-width:0}.doc-tabs button{flex:1;min-width:180px;border:0;border-right:1px solid var(--line2);background:rgba(5,15,32,.74);color:var(--text);font-weight:900;font-size:17px;padding:16px 22px;cursor:pointer}.doc-tabs button:last-child{border-right:0}.doc-tabs button.active{background:linear-gradient(180deg,rgba(38,103,206,.45),rgba(20,61,130,.48));box-shadow:inset 0 0 0 1px rgba(112,170,255,.30)}.head-actions{display:flex;align-items:center;justify-content:flex-end;gap:9px;flex-wrap:wrap}.head-actions a,.head-actions span{font-size:12px;color:var(--muted);text-decoration:none;white-space:nowrap}.usage,.account{border:1px solid rgba(66,211,146,.24);background:rgba(66,211,146,.08);border-radius:999px;padding:6px 9px}.lang{display:inline-flex!important;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.12);font-weight:900;color:#c8d5ef!important}.lang.active{border-color:rgba(255,209,102,.50);background:rgba(255,209,102,.12);color:var(--gold)!important}.workgrid{width:100%;max-width:100vw;margin:0 auto;padding:12px 16px 18px;display:grid;grid-template-columns:minmax(560px,1.55fr) minmax(240px,.55fr) minmax(270px,.62fr) minmax(270px,.62fr);grid-template-areas:"viewer upload project preview" "profiles profiles profiles profiles" "bar bar bar bar" "rules rules rules rules";gap:12px;align-items:start;overflow:hidden}.panel{min-width:0;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel),rgba(6,15,30,.76));border-radius:15px;box-shadow:0 18px 46px rgba(0,0,0,.26);backdrop-filter:blur(12px)}.viewer-panel{grid-area:viewer;position:relative;height:480px;display:grid;grid-template-rows:48px 1fr;overflow:hidden}.upload-panel{grid-area:upload}.project-panel{grid-area:project}.preview-panel{grid-area:preview}.compact{padding:14px}.compact h2,.profiles-panel h2{margin:0 0 12px;color:#8fc3ff;font-size:21px;line-height:1.1}.viewer-bar{display:flex;align-items:center;gap:8px;padding:8px 9px;border-bottom:1px solid rgba(255,255,255,.07);overflow:hidden;white-space:nowrap}.toggle{display:flex}.toggle button{border:1px solid var(--line2);border-right:0;background:rgba(3,10,22,.72);color:var(--text);padding:9px 15px;font-weight:900;cursor:pointer}.toggle button:first-child{border-radius:10px 0 0 10px}.toggle button:last-child{border-right:1px solid var(--line2);border-radius:0 10px 10px 0}.toggle button.active{background:#1567d9;color:white}.viewer-bar span,.viewer-bar>button{height:34px;border:1px solid var(--line);border-radius:9px;background:rgba(4,12,26,.78);color:var(--text);padding:7px 13px;font-weight:800;min-width:0}.viewer-bar>button{cursor:pointer}.viewer-map{position:relative;width:100%;height:100%;min-height:400px;background:#07101f;z-index:1;overflow:hidden}.leaflet-container{font-family:inherit;background:#07101f}.leaflet-control-attribution{display:none}.map-controls{position:absolute;z-index:520;right:12px;top:70px;display:grid;gap:8px}.map-controls button{width:42px;height:42px;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:rgba(5,12,24,.80);color:#fff;font-weight:950;cursor:pointer}.map-controls button.active{outline:2px solid var(--gold);background:rgba(255,209,102,.18)}.viewer-note{position:absolute;z-index:500;left:12px;right:12px;bottom:12px;padding:10px 12px;border:1px solid rgba(255,209,102,.35);background:rgba(0,0,0,.60);border-radius:12px;color:var(--gold);font-size:14px;font-weight:800}.viewer-panel.is3d .leaflet-map-pane{transform:perspective(900px) rotateX(17deg) scale(.98);transform-origin:center center;transition:.25s}.filebox{display:block;border:1px solid rgba(106,161,255,.35);background:rgba(3,10,22,.58);border-radius:11px;padding:14px;margin-bottom:10px;cursor:pointer}.filebox span{display:block;font-weight:900;color:#f2f7ff;margin-bottom:8px}.filebox input{width:100%;font-size:12px;color:var(--muted)}.small{font-size:12px;color:var(--muted);margin:0 0 12px}.small.ok,.ok{color:#2cff9b}.client-logo{margin-top:10px;border:1px solid rgba(255,255,255,.10);border-radius:12px;background:rgba(6,18,38,.72);padding:12px;overflow:hidden}.client-logo strong{display:block;margin-bottom:8px}.client-logo small{color:var(--muted)}.client-logo img{display:block;width:100%;height:86px;object-fit:cover;border-radius:8px;margin-bottom:6px}.client-logo span{font-size:12px;color:#27ffa5}.fields{display:grid;gap:10px}.fields label{font-size:12px;color:#9bb7de;font-weight:900}.fields input{width:100%;margin-top:4px;border:1px solid rgba(106,161,255,.29);border-radius:9px;background:rgba(3,10,22,.70);color:#fff;padding:10px 11px;font-weight:800;min-width:0}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.doc-choice,.asbuilt-choice{font-weight:900;color:var(--gold);font-size:13px;margin:0 0 10px}.asbuilt-choice{color:#c7d2e8;margin-top:6px}.preview-cards{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:10px}.preview-cards div{min-height:78px;border:1px solid rgba(106,161,255,.28);border-radius:11px;background:rgba(7,18,36,.86);padding:10px;display:grid;align-content:space-between}.preview-cards b{color:var(--gold);font-size:22px}.preview-cards span{font-size:13px;font-weight:900;color:#d9e7ff}.actions{display:grid;gap:9px;margin-top:12px}.actions button,.bottom-actions button,#profileHelp{border:1px solid var(--line);border-radius:12px;background:rgba(8,20,42,.86);color:var(--text);font-weight:950;padding:12px 14px;cursor:pointer}.actions .gold,.bottom-actions .gold{border:1px solid rgba(255,209,102,.55);background:linear-gradient(180deg,#ffd166,#d89420);color:#06101f}.profiles-panel{grid-area:profiles;padding:14px;max-height:none;overflow:visible}.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.section-head h2{display:inline;margin-right:12px;color:#fff}.section-head span{color:var(--muted);font-size:13px}.profile-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.profile-controls label{font-size:12px;color:var(--muted);font-weight:900}.profile-controls select{margin-left:6px;background:rgba(3,10,22,.70);color:#fff;border:1px solid var(--line);border-radius:8px;padding:9px 12px}.profiles-empty{border:1px dashed rgba(106,161,255,.36);border-radius:12px;padding:25px;text-align:center;color:var(--muted);font-size:18px}.profiles-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.profile-card{min-width:0;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(210px,.75fr);gap:12px;border:1px solid rgba(106,161,255,.30);border-radius:13px;background:rgba(3,10,22,.62);padding:12px}.profile-card h3{margin:0;color:#fff;font-size:22px}.profile-meta{margin:3px 0 8px;color:#bcd0ed;font-size:12px}.profile-chart{height:165px;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(5,12,24,.65);overflow:hidden}.profile-chart svg{width:100%;height:100%}.profile-chart text{font-family:Inter,Segoe UI,Arial,sans-serif;fill:#cfe0fb}.profile-table{width:100%;border-collapse:collapse;font-size:13px;align-self:start}.profile-table td{border-bottom:1px solid rgba(255,255,255,.08);padding:7px;color:#d7e6ff}.profile-table td:nth-child(2),.profile-table td:nth-child(3){text-align:right}.bottom-bar{grid-area:bar;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 12px}.status-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:var(--muted)}.status-left strong{color:#51ffae}.dot{display:inline-block;width:12px;height:12px;border-radius:50%;background:#2dff91;box-shadow:0 0 18px #2dff91}.bottom-actions{display:flex;gap:10px;flex-wrap:wrap}.bottom-actions button{min-width:160px}.rules{grid-area:rules;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;padding:0;border:0;background:transparent;box-shadow:none}.rules article{border:1px solid rgba(66,211,146,.24);border-radius:13px;background:rgba(7,30,33,.58);padding:13px 15px}.rules b{display:block;color:#fff;margin-bottom:7px}.rules b:before{content:"✓";display:inline-grid;place-items:center;margin-right:8px;width:24px;height:24px;border:2px solid #2dff91;border-radius:50%;color:#2dff91}.rules span{font-size:12px;color:var(--muted)}dialog#pdfDialog{width:min(1320px,94vw);height:min(880px,88vh);border:1px solid var(--line2);border-radius:18px;background:#07101f;color:var(--text);padding:0;box-shadow:0 30px 90px rgba(0,0,0,.58)}dialog::backdrop{background:rgba(0,0,0,.55);backdrop-filter:blur(4px)}.dialog-head{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid var(--line);background:rgba(8,18,35,.95)}.dialog-head button{border:1px solid var(--line);background:rgba(255,255,255,.06);color:#fff;border-radius:10px;padding:10px 16px;font-weight:900}.pdf-preview{height:calc(100% - 60px);overflow:auto;padding:18px;background:#2a2a2a}.pdf-page{width:1120px;min-height:790px;background:white;color:#0a1830;margin:0 auto 20px;padding:34px;border:1px solid #111}.pdf-box{border:2px solid #111;min-height:450px;margin:24px 0;padding:30px;display:grid;place-items:center;text-align:center}.pdf-meta{font-size:12px;color:#344}.pdf-profiles{display:grid;gap:18px}.pdf-profile{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}.pdf-profile svg{width:100%;height:170px;border:1px solid #222}.pdf-profile table{width:100%;border-collapse:collapse}.pdf-profile td{border:1px solid #333;padding:4px;font-size:11px}
@media(max-width:1450px){.machine-header{grid-template-columns:300px 1fr 300px}.brand img{height:62px;width:62px}.brand-text strong{font-size:26px}.doc-tabs button{min-width:150px;font-size:15px;padding:13px 15px}.workgrid{grid-template-columns:minmax(520px,1.15fr) minmax(220px,.48fr) minmax(245px,.55fr) minmax(245px,.55fr);padding:10px;gap:10px}.viewer-panel{height:430px}.rules{grid-template-columns:repeat(5,1fr)}.profile-card{grid-template-columns:1fr}.profile-table{font-size:12px}.profile-chart{height:145px}}
@media(max-width:1200px){.machine-header{position:relative;grid-template-columns:1fr}.doc-tabs{order:3}.head-actions{justify-content:flex-start}.workgrid{grid-template-columns:1fr 1fr;grid-template-areas:"viewer viewer" "upload project" "preview preview" "profiles profiles" "bar bar" "rules rules"}.viewer-panel{height:420px}.profiles-grid{grid-template-columns:1fr}.rules{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.workgrid{grid-template-columns:1fr;grid-template-areas:"viewer" "upload" "project" "preview" "profiles" "bar" "rules"}.viewer-panel{height:360px}.bottom-bar{display:grid}.rules{grid-template-columns:1fr}.doc-tabs{display:grid}.doc-tabs button{border-right:0;border-bottom:1px solid var(--line2)}}


/* v25 Leaflet hard-fix: prevents OpenStreetMap tiles from splitting/stacking when CDN CSS is blocked or cached wrong */
.leaflet-container{position:relative!important;overflow:hidden!important;width:100%!important;height:100%!important;background:#07101f!important;outline:0!important;touch-action:pan-x pan-y;font-family:Inter,Segoe UI,Arial,sans-serif!important;}
.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute!important;left:0;top:0;}
.leaflet-tile{width:256px!important;height:256px!important;max-width:none!important;max-height:none!important;user-select:none;-webkit-user-drag:none;}
.leaflet-tile-pane{z-index:200!important;}
.leaflet-overlay-pane{z-index:400!important;}
.leaflet-marker-pane{z-index:600!important;}
.leaflet-tooltip-pane{z-index:650!important;}
.leaflet-popup-pane{z-index:700!important;}
.leaflet-control{position:relative;z-index:800;pointer-events:auto;}
.viewer-map,.leaflet-container,.leaflet-map-pane,.leaflet-tile-pane{transform:none;transform-origin:50% 50%;}
.viewer-panel.is3d .leaflet-map-pane{transform:perspective(900px) rotateX(16deg) scale(.98)!important;transform-origin:center center;transition:.25s;}
.pt-label,.profile-label{background:rgba(3,10,22,.86)!important;border:1px solid rgba(106,161,255,.45)!important;color:#e8f4ff!important;border-radius:6px!important;box-shadow:0 6px 16px rgba(0,0,0,.35)!important;font-weight:800!important;}

/* v26: DXF-lagen, cache en Q1-profielherstel */
.layer-panel{margin:10px 0 12px;border:1px solid rgba(106,161,255,.26);border-radius:12px;background:rgba(3,10,22,.50);overflow:hidden;max-height:230px}
.layers-head{display:flex;align-items:center;gap:8px;padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.07)}
.layers-head strong{color:#8fc3ff;margin-right:auto}.layers-head button{border:1px solid rgba(106,161,255,.35);background:rgba(8,20,42,.80);color:#fff;border-radius:8px;padding:5px 8px;font-size:11px;font-weight:900;cursor:pointer}.layers-empty{padding:12px;color:#9fafca;font-size:12px}.layers-list{max-height:180px;overflow:auto;padding:7px;display:grid;gap:5px}.layer-row{display:grid;grid-template-columns:22px minmax(0,1fr) 46px;align-items:center;gap:7px;border:1px solid rgba(66,211,146,.16);background:rgba(66,211,146,.06);border-radius:9px;padding:6px 8px;font-size:12px}.layer-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#d9e7ff}.layer-row b{text-align:right;color:#62f6ad}.layer-row input{accent-color:#42d392}
.pt-label,.profile-label{background:rgba(5,12,24,.86)!important;color:#ecf7ff!important;border:1px solid rgba(66,211,146,.35)!important;border-radius:6px!important;font-weight:800!important}.leaflet-tooltip-top:before{border-top-color:rgba(66,211,146,.35)!important}.dxf-only{background:#06101f!important;background-image:linear-gradient(rgba(106,161,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(106,161,255,.06) 1px,transparent 1px)!important;background-size:32px 32px!important}.dxf-only .leaflet-tile-pane{display:none!important}
.q1-head{display:grid;grid-template-columns:150px 1fr;gap:22px;align-items:center;border-bottom:2px solid #1f4e79;padding-bottom:14px;margin-bottom:20px}.q1-head img{width:130px;height:58px;object-fit:cover}.q1-head h1{margin:0;color:#00533f;font-size:24px;letter-spacing:.02em}.q1-head p{margin:5px 0 0;color:#344;font-size:11px}.q1-page .pdf-meta{display:grid;grid-template-columns:1fr 1fr;gap:7px 70px;margin-bottom:18px;font-size:10px;color:#1b344e}.q1-page footer{border:1px solid #1b344e;margin-top:16px;padding:9px 12px;font-size:10px;color:#1b344e}.q1-page .big{min-height:480px}.pdf-sub{font-size:11px;color:#334;margin:0 0 14px}.pdf-profile{grid-template-columns:minmax(0,1fr) 280px}.pdf-profile table th,.pdf-profile table td{border:1px solid #333;padding:3px;font-size:9px}.pdf-profile p{font-size:10px;margin:6px 0}.pdf-profile b{font-size:11px}.pdf-profile svg text{fill:#111!important}.pdf-profile svg .grid line{stroke:#ddd!important}

/* v28 - Q1 blad 1/2 hersteld: viewerbeeld + RD-overzicht zoals referentie, geen placeholders */
.q1-head{grid-template-columns:150px 1fr 90px!important;align-items:center!important;}
.q1-head .bladnr{justify-self:end;align-self:start;font-size:10px;font-weight:800;color:#1b344e;}
.pdf-map-frame{position:relative;border:2px solid #222;height:505px;margin:18px 0 12px;background:#f7f7f2;overflow:hidden;}
.pdf-map-live{width:100%;height:100%;background:#e9edf0;}
.pdf-map-live .leaflet-tile{filter:none!important;}
.pdf-north{position:absolute;right:22px;top:22px;width:44px;height:62px;border:1.5px solid #111;background:#fff;text-align:center;font-weight:800;font-size:10px;line-height:14px;padding-top:5px;z-index:800;}
.pdf-north span{display:block;font-size:36px;line-height:36px;font-weight:400;margin-top:2px;}
.pdf-rd-frame{border:0;margin:18px auto 12px;display:grid;place-items:center;}
.rd-overview-svg{width:100%;height:505px;display:block;background:#fff;}
.q1-page footer{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;align-items:center;min-height:44px;}
.q1-page .pdf-sub{font-size:11px;color:#25374d;margin:4px 0 10px;}
.pdf-profile svg{height:155px!important;}
.pdf-profile{page-break-inside:avoid;}
@media print{
  .pdf-preview{background:#fff!important;padding:0!important;}
  .pdf-page{margin:0 auto!important;page-break-after:always;}
  .pdf-map-frame,.rd-overview-svg{break-inside:avoid;}
}

/* v30 - small safe fixes only: viewer snapshot on page 1, readable profile labels, reset visible */
.viewer-snapshot{width:100%;height:100%;object-fit:contain;display:block;background:#eef2f0;}
#resetTopBtn{border-color:rgba(255,209,102,.34)!important;color:#ffd166!important;}
#resetBottomBtn{border-color:rgba(255,209,102,.34)!important;color:#ffd166!important;}
.pdf-profile svg .pt-name{font-size:7px!important;font-weight:700!important;fill:#111!important;stroke:none!important;}
.pdf-profile svg .axis-tick{font-size:7.5px!important;fill:#111!important;stroke:none!important;}
.pdf-profile svg circle{r:2.2!important;}
.pdf-profile svg path{stroke-width:2!important;}
.pdf-profile{grid-template-columns:minmax(0,1fr) 270px!important;gap:18px!important;margin-bottom:10px!important;}
.pdf-profile svg{height:142px!important;}
.pdf-profile table th,.pdf-profile table td{font-size:8.5px!important;padding:2.5px!important;line-height:1.15!important;}
.pdf-profile p{font-size:9px!important;line-height:1.25!important;}
.pdf-profile b{font-size:10px!important;}
.pdf-profiles{gap:12px!important;}
.q1-page footer{margin-top:12px!important;}


/* v31 - Q1 live profiel, moderne typografie, tabellen niet uitrekken */
html,body,input,button,select,textarea,table,svg text{
  font-family:"Inter","Segoe UI Variable","Segoe UI",Roboto,Arial,sans-serif!important;
  font-weight:500;
  letter-spacing:-.01em;
}
.brand-text strong,.doc-tabs button,.card h2,.section-head h2,.preview-panel h2,.project-panel h2,.upload-panel h2{
  font-weight:780!important;
  letter-spacing:-.025em!important;
}
button,.actions button,.bottom-actions button{font-weight:750!important;}
.profile-card h3{font-weight:760!important;letter-spacing:-.02em;}
.q1-live-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;align-items:start;}
.q1-live-profile{
  display:grid!important;
  grid-template-columns:minmax(0,1.55fr) minmax(230px,.85fr)!important;
  gap:14px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(245,248,252,.98))!important;
  color:#111827!important;
  border:1px solid rgba(170,188,215,.55)!important;
  box-shadow:0 12px 34px rgba(0,0,0,.22)!important;
}
.q1-live-profile h3{color:#111827!important;font-size:15px!important;margin:0 0 3px!important;}
.q1-live-profile .profile-meta{color:#415066!important;font-size:10.5px!important;margin:0 0 7px!important;}
.q1-live-profile .profile-chart{height:155px!important;background:#fff!important;border:1px solid #1f2937!important;border-radius:0!important;}
.q1-live-profile .profile-chart svg text{fill:#111!important;font-weight:500!important;}
.q1-live-profile .profile-chart svg .grid line{stroke:#d7dce3!important;}
.q1-live-profile .profile-chart svg path.profile-line{stroke:var(--h-color,#d92535)!important;stroke-width:2!important;}
.q1-live-profile .profile-chart svg circle{fill:#ffd400!important;stroke:#d92535!important;}
.q1-live-values{align-self:start;min-width:0;max-height:205px;overflow:auto;background:#fff;border:1px solid #333;padding:8px;}
.q1-live-values strong{display:block;color:#111827;font-size:11px;font-weight:760;margin-bottom:4px;line-height:1.25;}
.q1-live-values span{display:block;color:#384456;font-size:9.5px;margin-bottom:6px;}
.profile-table{table-layout:fixed!important;width:100%!important;border-collapse:collapse!important;background:#fff!important;color:#111827!important;font-size:10.5px!important;line-height:1.15!important;}
.profile-table th,.profile-table td{border:1px solid #48515c!important;padding:3px 4px!important;color:#111827!important;white-space:nowrap!important;}
.profile-table th{font-weight:760!important;background:#f5f7fa!important;}
.profile-table td:nth-child(2),.profile-table td:nth-child(3),.profile-table th:nth-child(2),.profile-table th:nth-child(3){text-align:right!important;}
.profiles-empty b{color:#fff;font-weight:760}.profiles-empty span{display:block;margin-top:6px;color:#aebbd0;font-size:13px;line-height:1.35;}
.pdf-page,.pdf-page *{font-family:"Inter","Segoe UI Variable","Segoe UI",Roboto,Arial,sans-serif!important;font-weight:500;letter-spacing:-.005em;}
.q1-head h1{font-weight:760!important;font-size:22px!important;letter-spacing:-.015em!important;}
.pdf-profile{grid-template-columns:minmax(0,1fr) 250px!important;gap:20px!important;align-items:start!important;margin-bottom:12px!important;}
.pdf-profile svg{height:146px!important;width:100%!important;}
.pdf-profile svg .pt-name{font-size:6.5px!important;font-weight:600!important;fill:#111!important;}
.pdf-profile svg .axis-tick{font-size:7px!important;font-weight:500!important;fill:#111!important;}
.pdf-profile-values{align-self:start!important;max-height:none!important;overflow:visible!important;}
.pdf-profile-values b{display:block;font-size:10px!important;font-weight:760!important;line-height:1.2!important;margin-bottom:5px!important;}
.pdf-profile-values p{font-size:8.7px!important;line-height:1.22!important;margin:0 0 6px!important;}
.pdf-profile-values table{width:100%!important;table-layout:fixed!important;border-collapse:collapse!important;height:auto!important;}
.pdf-profile-values table th,.pdf-profile-values table td{font-size:8.2px!important;padding:2px 3px!important;line-height:1.1!important;height:auto!important;white-space:nowrap!important;border:1px solid #333!important;}
.pdf-profile-values table th{font-weight:760!important;background:#f8f9fb!important;}
.pdf-profile-values table th:nth-child(2),.pdf-profile-values table th:nth-child(3),.pdf-profile-values table td:nth-child(2),.pdf-profile-values table td:nth-child(3){text-align:right!important;}
@media(max-width:1250px){.q1-live-grid{grid-template-columns:1fr!important}.q1-live-profile{grid-template-columns:1fr!important}.q1-live-values{max-height:170px}}


/* v32 - betere eerste viewerstand: projectfit, sterkere lijnen en duidelijkere data */
.machine-header .brand-text em::after{content:" / v36 meetproces + H-kleuren";}
.viewer-panel{box-shadow:0 0 0 1px rgba(106,161,255,.22),0 18px 60px rgba(0,0,0,.34)!important;}
.viewer-map{background:#071323!important;}
.viewer-map.dxf-only{background:#06111f!important;background-image:linear-gradient(rgba(106,161,255,.10) 1px,transparent 1px),linear-gradient(90deg,rgba(106,161,255,.10) 1px,transparent 1px)!important;background-size:28px 28px!important;}
.leaflet-overlay-pane svg path{filter:drop-shadow(0 0 3px rgba(0,230,255,.45));}
.leaflet-marker-pane,.leaflet-overlay-pane{mix-blend-mode:normal!important;}
.viewer-note{font-weight:760!important;color:#61fbb9!important;background:linear-gradient(90deg,rgba(0,0,0,.74),rgba(3,12,26,.68))!important;border-top:1px solid rgba(66,211,146,.22)!important;}
.toggle button.active{background:linear-gradient(180deg,#1976ff,#0a4fb7)!important;color:#fff!important;box-shadow:0 0 0 1px rgba(106,161,255,.65),0 0 24px rgba(25,118,255,.28)!important;}
#fitBtn{border-color:rgba(66,211,146,.45)!important;color:#8cffc7!important;}
#fitBtn::after{content:" project";font-size:.85em;color:#9afbd0;}
.pt-label,.profile-label{font-size:11px!important;color:#ffffff!important;background:rgba(2,7,17,.92)!important;border:1px solid rgba(0,245,159,.55)!important;text-shadow:0 1px 2px #000!important;}
.layer-row{background:rgba(0,245,159,.08)!important;border-color:rgba(0,245,159,.25)!important;}


/* v35 - rollback naar v33 basis: verbindingslijnen + Q1 PDF hersteld, geen v34 werkmachine achtergrond override */
html,body,input,button,select,textarea,table,svg text{
  font-family:"Segoe UI Variable","Segoe UI",Arial,Helvetica,sans-serif!important;
  font-weight:440!important;
  letter-spacing:-.015em!important;
}
.brand-text strong{font-weight:720!important;letter-spacing:-.045em!important;}
.doc-tabs button,.compact h2,.profiles-panel h2,.preview-panel h2,.project-panel h2,.upload-panel h2{font-weight:700!important;letter-spacing:-.025em!important;}
.fields label,.filebox span,.preview-cards span,.actions button,.bottom-actions button{font-weight:650!important;}
.viewer-bar span,.viewer-bar>button,.toggle button{font-weight:650!important;}
.viewer-note{font-size:13px!important;line-height:1.25!important;letter-spacing:-.01em!important;}
.rules{gap:8px!important;}
.rules article{padding:10px 12px!important;background:rgba(6,22,30,.72)!important;}
.rules b{font-weight:650!important;font-size:14px!important;line-height:1.2!important;}
.rules span{font-size:12.5px!important;line-height:1.25!important;color:#c3d2ea!important;}
.layer-panel{max-height:360px!important;border-color:rgba(66,211,146,.34)!important;background:rgba(1,11,22,.72)!important;}
.layers-head{padding:9px 9px!important;position:sticky;top:0;z-index:2;background:rgba(4,14,28,.96)!important;}
.layers-head strong{font-size:16px!important;color:#d9f6ff!important;}
.layers-list{max-height:295px!important;gap:4px!important;padding:7px!important;}
.layer-row{grid-template-columns:24px minmax(0,1fr) 54px!important;padding:7px 9px!important;font-size:13px!important;border-color:rgba(66,211,146,.28)!important;background:rgba(0,245,159,.105)!important;}
.layer-row span{font-weight:540!important;color:#edf7ff!important;}
.layer-row b{font-weight:700!important;color:#70ffc0!important;}
.layer-row input{width:15px;height:15px;}
.viewer-map.dxf-only{background:#040d1b!important;background-image:linear-gradient(rgba(85,156,255,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(85,156,255,.16) 1px,transparent 1px)!important;background-size:30px 30px!important;}
.leaflet-overlay-pane svg path{filter:drop-shadow(0 0 4px rgba(0,245,255,.60)) drop-shadow(0 0 1px rgba(0,0,0,.95))!important;}
.pt-label,.profile-label{font-size:12px!important;font-weight:650!important;background:rgba(0,8,18,.94)!important;border-color:rgba(0,245,159,.70)!important;color:#fff!important;}
.profile-card h3{font-weight:690!important;}
.profile-table th,.profile-table td{font-weight:480!important;}
/* maak de upload/laagkolom bruikbaarer zonder de site breder te maken */
@media(min-width:1350px){
  .workgrid{grid-template-columns:minmax(590px,1.45fr) minmax(285px,.62fr) minmax(270px,.58fr) minmax(270px,.58fr)!important;}
}


/* v36 - meetproceslijn-knop en H-profielkleuren terug */
#measureProcessBtn{border-color:rgba(255,79,163,.42)!important;color:#ffd6ef!important;min-width:136px!important;}
#measureProcessBtn.active{background:linear-gradient(180deg,rgba(255,79,163,.26),rgba(90,20,80,.42))!important;color:#fff!important;box-shadow:0 0 0 1px rgba(255,79,163,.55),0 0 22px rgba(255,79,163,.20)!important;}
.h-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:7px;vertical-align:middle;box-shadow:0 0 10px currentColor;}
.q1-live-profile{border-left:4px solid var(--h-color,#6aa1ff)!important;}
.q1-live-profile .profile-chart svg path.profile-line{stroke:var(--h-color,#d92535)!important;}
.q1-live-profile .profile-chart svg circle{fill:#ffd166!important;stroke:var(--h-color,#d92535)!important;}
.layer-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}


/* v37 - leesbaar lettertype over hele werkmachine */
:root{
  --font-main: Aptos, "Segoe UI Variable", "Segoe UI", Arial, sans-serif;
  --font-mono: "Cascadia Mono", "Consolas", monospace;
}
html,body,input,button,select,textarea,table,svg text{
  font-family:var(--font-main)!important;
  font-weight:400!important;
  letter-spacing:-0.006em!important;
  text-rendering:geometricPrecision;
  -webkit-font-smoothing:antialiased;
  font-synthesis-weight:none;
}
.brand-text strong{font-weight:650!important;letter-spacing:-.035em!important;}
.brand-text small{font-weight:520!important;letter-spacing:-.015em!important;}
.brand-text em{font-weight:650!important;letter-spacing:.055em!important;}
.machine-header .brand-text em::after{content:" / v37 leesbaar font"!important;}
.doc-tabs button{font-weight:620!important;font-size:15.5px!important;letter-spacing:-.012em!important;}
.compact h2,.profiles-panel h2,.preview-panel h2,.project-panel h2,.upload-panel h2{font-weight:620!important;letter-spacing:-.018em!important;}
.viewer-bar{gap:6px!important;padding:7px 8px!important;}
.viewer-bar span,.viewer-bar>button,.toggle button{
  font-weight:520!important;
  font-size:12.5px!important;
  padding:7px 10px!important;
  letter-spacing:0!important;
}
#measureProcessBtn{min-width:104px!important;}
#measureProcessBtn::before{content:"";}
.fields label,.filebox span,.preview-cards span,.rules b,.layer-row span,.layer-row b{font-weight:520!important;}
.fields input{font-weight:440!important;font-size:14px!important;}
.filebox,.fields input,.actions button,.bottom-actions button{font-weight:520!important;}
.viewer-note{font-size:13px!important;font-weight:500!important;line-height:1.28!important;}
.layer-row{font-size:12.8px!important;line-height:1.18!important;}
.layer-row b{font-weight:600!important;}
.profile-card h3,.q1-live-profile h3{font-weight:620!important;}
.profile-table,.profile-table th,.profile-table td{font-weight:400!important;font-size:10px!important;}
.q1-live-values strong{font-weight:600!important;}
.q1-live-values span{font-weight:400!important;}
.profile-chart text,.pdf-page svg text{font-weight:400!important;}
.pdf-page,.pdf-page *{font-family:var(--font-main)!important;font-weight:400!important;letter-spacing:0!important;}
.q1-head h1{font-weight:650!important;}
.pdf-profile-values b,.pdf-profile-values table th{font-weight:600!important;}
.pdf-profile-values table td{font-weight:400!important;}
.rules article{font-weight:400!important;}
.rules span{font-weight:400!important;}
@media(max-width:1500px){
  .doc-tabs button{font-size:14.5px!important;padding:14px 16px!important;min-width:160px!important;}
  .viewer-bar span,.viewer-bar>button,.toggle button{font-size:12px!important;padding:7px 8px!important;}
}


/* v38 - Suissnord-ready technische typografie
   Exacte Suissnord fontbestanden zijn niet meegeleverd.
   Plaats een gelicentieerd fontbestand als:
   app/survey-control/assets/fonts/suissnord.woff2
*/
@font-face{
  font-family:"SuissnordLocal";
  src:url("assets/fonts/suissnord.woff2") format("woff2");
  font-weight:400 800;
  font-style:normal;
  font-display:swap;
}
:root{
  --font-tech:"SuissnordLocal","Suissnord","Eurostile Extended","Bank Gothic","Rajdhani","Segoe UI Variable","Segoe UI",Arial,sans-serif;
  --font-main:"Rajdhani","Segoe UI Variable","Segoe UI",Arial,sans-serif;
}
html,body,input,button,select,textarea,table,svg text{
  font-family:var(--font-main)!important;
  font-weight:500!important;
  letter-spacing:.003em!important;
}
.brand-text strong,.brand-text small,.brand-text em,.doc-tabs button,.compact h2,.profiles-panel h2,.preview-panel h2,.project-panel h2,.upload-panel h2,.viewer-bar span,.viewer-bar>button,.toggle button,.actions button,.bottom-actions button,.layer-panel strong,.q1-live-profile h3,.profile-card h3{
  font-family:var(--font-tech)!important;
  font-weight:650!important;
  letter-spacing:.006em!important;
}
.machine-header .brand-text em::after{content:" / v38 Suissnord-ready"!important;}
.doc-tabs button{font-size:15px!important;line-height:1.1!important;}
.viewer-bar span,.viewer-bar>button,.toggle button{font-size:12px!important;font-weight:620!important;}
.fields label,.filebox span,.preview-cards span,.rules b,.layer-row span,.layer-row b{
  font-family:var(--font-main)!important;
  font-weight:560!important;
}
.fields input{font-family:var(--font-main)!important;font-weight:500!important;}
.q1-live-values strong,.pdf-profile-values b,.pdf-profile-values table th{font-family:var(--font-tech)!important;font-weight:650!important;}
.profile-table,.profile-table th,.profile-table td,.pdf-profile-values table td{font-family:var(--font-main)!important;font-weight:500!important;}
/* minder rommelig boven de viewer */
.viewer-bar{gap:5px!important;flex-wrap:wrap!important;align-content:flex-start!important;}
.viewer-bar .toggle{flex-wrap:nowrap!important;}

/* v39 betaalgate + profielkaarten netter */
.pdf-gate-note{
  width:1120px; margin:0 auto 14px; padding:12px 16px; border:1px solid rgba(255,209,102,.75);
  border-radius:10px; background:#fff7dd; color:#4d3300; font-weight:600; font-family:var(--font-main, Segoe UI, Arial, sans-serif);
}
.q1-live-profile{align-items:stretch!important; min-height:245px!important; overflow:hidden!important;}
.q1-live-profile .profile-chart{min-height:160px!important; height:160px!important; overflow:hidden!important;}
.q1-live-profile .q1-live-values{max-height:205px!important; overflow:auto!important; border-left:1px solid rgba(31,78,121,.28); padding-left:12px;}
.q1-live-profile .profile-table{table-layout:fixed!important; width:100%!important; font-size:12px!important;}
.q1-live-profile .profile-table th,.q1-live-profile .profile-table td{padding:4px 6px!important; line-height:1.15!important;}
.q1-live-profile .profile-table th:nth-child(1),.q1-live-profile .profile-table td:nth-child(1){width:30%;}
.q1-live-profile .profile-table th:nth-child(2),.q1-live-profile .profile-table td:nth-child(2){width:34%;}
.q1-live-profile .profile-table th:nth-child(3),.q1-live-profile .profile-table td:nth-child(3){width:36%;}
.preview-panel .actions .gold::after,.bottom-actions .gold::after{content:' na controle'; font-size:.72em; opacity:.75; font-weight:500;}
.preview-panel:after{content:'Preview is gratis. Definitieve PDF gebruikt 1 tegoed of vraagt betaling.';display:block;margin-top:10px;color:#ffd166;font-size:12px;line-height:1.25;}

/* v40 - Starfleet / Star Trek-achtige typografie voor werkmachine
   Geen fontbestanden meegeleverd. Plaats jouw eigen gelicentieerde font als:
   app/survey-control/assets/fonts/startrek.woff2 of startrek.ttf
*/
@font-face{
  font-family:"StarfleetLocal";
  src:url("assets/fonts/startrek.woff2") format("woff2"), url("assets/fonts/startrek.ttf") format("truetype");
  font-weight:400 900;
  font-style:normal;
  font-display:swap;
}
:root{
  --font-starfleet:"StarfleetLocal","Orbitron","Eurostile Extended","Bank Gothic","Rajdhani","Segoe UI Variable","Segoe UI",Arial,sans-serif;
  --font-readable:"Rajdhani","Segoe UI Variable","Segoe UI",Arial,sans-serif;
}
html,body,input,button,select,textarea,a,p,li,td,th,label,small,span,strong,
.machine-header,.machine-header *,.panel,.panel *,.viewer-panel,.viewer-panel *,.profile-card,.profile-card *,.bottom-bar,.bottom-bar *,.rules,.rules *{
  font-family:var(--font-starfleet)!important;
  letter-spacing:.014em!important;
  font-weight:500!important;
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}
h1,h2,h3,h4,.brand-text,.brand-text *,.doc-tab,.actions button,.bottom-actions button,.viewer-bar button,.viewer-bar span{
  font-family:var(--font-starfleet)!important;
  letter-spacing:.028em!important;
  font-weight:700!important;
}
.machine-header .brand-text em::after{content:" / v40 Starfleet font"!important;}
.fields input,.profile-table,.profile-table th,.profile-table td,.q1-live-values,.pdf-profile-values,.pdf-profile-values *{
  font-family:var(--font-starfleet)!important;
  font-weight:500!important;
  letter-spacing:.008em!important;
}
.profile-chart text{font-family:var(--font-starfleet)!important;letter-spacing:.004em!important;}
/* Einde v40 */

/* v41 - gebruik balk.png in de zwarte ruimte van de werkmachine.
   Alleen visueel: geen viewer/PDF/H-profiel/betaal-logica gewijzigd. */
html,body{
  background:#050c18!important;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-4;
  background:
    linear-gradient(90deg,rgba(3,9,20,.76),rgba(3,9,20,.48) 50%,rgba(3,9,20,.78)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
  filter:saturate(1.12) contrast(1.08)!important;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background:
    radial-gradient(circle at 16% 8%,rgba(106,161,255,.11),transparent 25%),
    radial-gradient(circle at 82% 6%,rgba(66,211,146,.10),transparent 24%),
    linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.010) 1px,transparent 1px)!important;
  background-size:auto,auto,26px 26px,26px 26px!important;
}
.machine-shell{
  background:transparent!important;
}
.machine-header{
  background:
    linear-gradient(90deg,rgba(4,10,20,.86),rgba(8,18,35,.50),rgba(4,10,20,.88)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
}
.workgrid{
  background:
    linear-gradient(180deg,rgba(3,9,20,.24),rgba(3,9,20,.44)),
    url("assets/logo_porstech.png") center center/cover fixed no-repeat!important;
}
.panel,.bottom-bar,.rules article{
  background:linear-gradient(180deg,rgba(7,18,36,.74),rgba(3,10,22,.66))!important;
  backdrop-filter:blur(10px)!important;
}
.upload-panel,.project-panel,.preview-panel,.profiles-panel{
  background:linear-gradient(180deg,rgba(8,21,41,.76),rgba(3,10,22,.68))!important;
}
.viewer-panel{
  background:linear-gradient(180deg,rgba(7,18,36,.74),rgba(3,10,22,.64))!important;
}
.client-logo{
  background:
    linear-gradient(180deg,rgba(4,12,26,.72),rgba(4,12,26,.50)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
}
.machine-header .brand-text em::after{content:" / v41 balk in zwart"!important;}

/* v42 - zwarte vlakken vervangen door logo_porstech.png.
   Alleen visueel: geen viewer/PDF/H-profiel/betaal-logica gewijzigd. */
html,body{background:#020813!important;}
body::before{
  content:"";position:fixed;inset:0;z-index:-4;
  background:
    linear-gradient(90deg,rgba(2,8,18,.78),rgba(2,8,18,.36) 48%,rgba(2,8,18,.78)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
  filter:saturate(1.08) contrast(1.04)!important;
}
body::after{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(circle at 16% 8%,rgba(106,161,255,.12),transparent 24%),
    radial-gradient(circle at 84% 8%,rgba(66,211,146,.10),transparent 24%),
    linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.010) 1px,transparent 1px)!important;
  background-size:auto,auto,26px 26px,26px 26px!important;
}
.machine-shell{background:transparent!important;}
.machine-header{
  background:
    linear-gradient(90deg,rgba(4,10,20,.88),rgba(4,10,20,.50),rgba(4,10,20,.88)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
}
.workgrid{
  background:
    linear-gradient(180deg,rgba(3,9,20,.22),rgba(3,9,20,.48)),
    url("assets/logo_porstech.png") center center/cover fixed no-repeat!important;
}
.panel,.bottom-bar,.rules article,.upload-panel,.project-panel,.preview-panel,.profiles-panel,.viewer-panel{
  background:linear-gradient(180deg,rgba(7,18,36,.76),rgba(3,10,22,.68))!important;
  backdrop-filter:blur(10px)!important;
}
.client-logo{
  background:
    linear-gradient(180deg,rgba(4,12,26,.70),rgba(4,12,26,.46)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
}
.machine-header .brand-text em::after{content:" / v42 logo achtergrond"!important;}


/* v43 - meetproceslijn zichtbaar + kleurcode consequent */
.machine-header .brand-text em::after{content:""!important;}
.machine-header .brand-text em{color:#ffd166!important;}
#measureProcessBtn{border-color:rgba(255,79,163,.68)!important;background:rgba(110,21,86,.42)!important;color:#ffe4f4!important;}
#measureProcessBtn.active{background:linear-gradient(180deg,rgba(255,79,163,.38),rgba(72,8,56,.62))!important;box-shadow:0 0 0 1px rgba(255,79,163,.72),0 0 24px rgba(255,79,163,.34)!important;color:#fff!important;}
.q1-live-profile{border-left:7px solid var(--h-color,#6aa1ff)!important;background:linear-gradient(90deg,color-mix(in srgb, var(--h-color,#6aa1ff) 14%, #ffffff),#fff 18%,#fff)!important;}
.q1-live-profile h3 .h-dot{width:12px!important;height:12px!important;border-radius:50%;display:inline-block;margin-right:7px;box-shadow:0 0 16px var(--h-color,#6aa1ff)!important;}
.q1-live-profile .profile-chart svg path.profile-line{stroke:var(--h-color,#d92535)!important;stroke-width:2.2!important;}
.q1-live-profile .profile-chart svg circle{fill:#fff6a6!important;stroke:var(--h-color,#d92535)!important;stroke-width:1.4!important;}
.q1-live-values{border-left:4px solid var(--h-color,#6aa1ff)!important;}
.q1-live-values strong{color:#0b1320!important;}
.profile-table th{background:color-mix(in srgb, var(--h-color,#6aa1ff) 16%, #eef4ff)!important;color:#0b1320!important;}
.viewer-note{font-weight:650!important;}
/* Houd homepage en andere pagina's onaangeroerd; dit blok geldt alleen voor de werkmachine. */


/* v44 - Alleen wijziging: balk-achtergrond vervangen door logo_porstech.png. Geen viewer/PDF/H-profiel/betaal-logica gewijzigd. */

/* v46 - overzichtelijke werkmachine, rustig lettertype, geen reken/PDF-logica aangepast */
:root{
  --font-v46: "Aptos Display", Aptos, "Segoe UI Variable", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Arial, sans-serif;
  --font-v46-mono: "Cascadia Mono", "Segoe UI Mono", Consolas, monospace;
}
html,body,input,button,select,textarea,a,p,li,td,th,label,small,span,strong,h1,h2,h3,h4,
.machine-header,.machine-header *,.panel,.panel *,.viewer-panel,.viewer-panel *,.profile-card,.profile-card *,.q1-live-profile,.q1-live-profile *,.bottom-bar,.bottom-bar *,.rules,.rules *{
  font-family:var(--font-v46)!important;
  letter-spacing:-0.01em!important;
  font-weight:450!important;
  -webkit-font-smoothing:antialiased!important;
  text-rendering:optimizeLegibility!important;
}
.brand-text strong,.doc-tabs button,.compact h2,.profiles-panel h2,.preview-panel h2,.project-panel h2,.upload-panel h2,.actions button,.bottom-actions button{
  font-weight:680!important;
  letter-spacing:-0.025em!important;
}
.machine-header .brand-text em::after{content:" / v48 beste tool"!important;}
.machine-header .brand-text em{font-size:10px!important;line-height:1.1!important;color:#ffd166!important;letter-spacing:.055em!important;font-weight:700!important;}
.brand img{height:74px!important;width:104px!important;object-fit:cover!important;border-radius:6px!important;}
.brand-text strong{font-size:28px!important;line-height:.94!important;}
.brand-text small{font-size:15px!important;font-weight:560!important;color:#dce8fa!important;}
.machine-header{
  grid-template-columns:minmax(285px,360px) minmax(460px,1fr) minmax(300px,430px)!important;
  min-height:104px!important;
  padding:12px 22px!important;
  gap:14px!important;
}
.doc-tabs{max-width:780px;margin:0 auto!important;}
.doc-tabs button{min-width:150px!important;font-size:15px!important;padding:13px 16px!important;line-height:1.18!important;}
.head-actions{gap:7px!important;}
.head-actions a,.head-actions span{font-size:12px!important;font-weight:500!important;}
.lang{width:34px!important;height:34px!important;font-weight:650!important;}

@media(min-width:1280px){
  .workgrid{
    max-width:1760px!important;
    margin:0 auto!important;
    padding:14px!important;
    gap:14px!important;
    grid-template-columns:minmax(680px,1.58fr) minmax(300px,.66fr) minmax(330px,.74fr)!important;
    grid-template-areas:
      "viewer upload project"
      "viewer upload preview"
      "profiles profiles profiles"
      "bar bar bar"
      "rules rules rules"!important;
    align-items:start!important;
    overflow:visible!important;
  }
  .viewer-panel{height:clamp(520px,56vh,650px)!important;}
  .upload-panel{max-height:clamp(520px,56vh,650px)!important;overflow:auto!important;scrollbar-width:thin!important;}
  .project-panel,.preview-panel{height:auto!important;}
}
@media(min-width:1600px){
  .workgrid{grid-template-columns:minmax(760px,1.62fr) minmax(330px,.62fr) minmax(360px,.68fr)!important;}
  .viewer-panel{height:620px!important;}
}
@media(max-width:1279px){
  .workgrid{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-areas:"viewer" "upload" "project" "preview" "profiles" "bar" "rules"!important;
    overflow:visible!important;
  }
  .viewer-panel{height:520px!important;}
}
.panel{border-radius:16px!important;border-color:rgba(106,161,255,.30)!important;box-shadow:0 14px 38px rgba(0,0,0,.28)!important;}
.viewer-panel{grid-template-rows:auto 1fr!important;border-color:rgba(106,161,255,.44)!important;}
.viewer-bar{
  display:flex!important;
  align-items:center!important;
  gap:7px!important;
  padding:8px 10px!important;
  min-height:48px!important;
  white-space:normal!important;
  overflow:visible!important;
  flex-wrap:wrap!important;
}
.toggle button,.viewer-bar span,.viewer-bar>button{
  height:32px!important;
  padding:6px 10px!important;
  font-size:12.5px!important;
  line-height:1!important;
  font-weight:620!important;
  border-radius:9px!important;
}
.toggle{flex:0 0 auto!important;}
.toggle button{min-width:70px!important;}
#rdChip,#zChip{font-family:var(--font-v46-mono)!important;font-size:11.5px!important;letter-spacing:-.035em!important;max-width:190px!important;overflow:hidden!important;text-overflow:ellipsis!important;}
#measureProcessBtn{min-width:124px!important;max-width:150px!important;}
.viewer-note{font-family:var(--font-v46)!important;font-weight:600!important;font-size:13px!important;line-height:1.25!important;}
.map-controls button{font-family:var(--font-v46)!important;font-weight:650!important;}
.compact{padding:14px!important;}
.compact h2,.profiles-panel h2{font-size:20px!important;margin-bottom:12px!important;color:#8cc1ff!important;}
.filebox{padding:12px!important;margin-bottom:10px!important;border-radius:12px!important;}
.filebox span{font-size:15px!important;font-weight:650!important;line-height:1.15!important;}
.filebox input{font-size:12px!important;}
.small{font-size:12.5px!important;line-height:1.3!important;}
.fields{gap:9px!important;}
.fields label{font-size:12.5px!important;font-weight:620!important;color:#9fb9dc!important;}
.fields input{padding:9px 10px!important;font-size:14px!important;font-weight:520!important;border-radius:9px!important;}
.field-row{gap:8px!important;}
.preview-cards{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;}
.preview-cards div{min-height:70px!important;padding:9px!important;}
.preview-cards b{font-size:22px!important;font-weight:700!important;}
.preview-cards span{font-size:12.5px!important;font-weight:620!important;}
.actions button,.bottom-actions button,#profileHelp{font-size:13.5px!important;font-weight:650!important;padding:11px 13px!important;min-height:42px!important;}
.layer-panel{max-height:330px!important;overflow:auto!important;scrollbar-width:thin!important;}
.layers-head{padding:8px!important;}
.layers-head strong{font-size:15px!important;font-weight:680!important;}
.layers-list{max-height:none!important;}
.layer-row{padding:7px 8px!important;grid-template-columns:22px minmax(0,1fr) 44px!important;font-size:12.5px!important;}
.layer-row span{font-weight:520!important;}
.layer-row b{font-weight:650!important;}
.client-logo{padding:10px!important;}
.client-logo img{height:78px!important;object-fit:cover!important;}

.profiles-panel{padding:14px!important;overflow:visible!important;}
.section-head{align-items:flex-end!important;margin-bottom:12px!important;}
.section-head h2{font-size:20px!important;font-weight:680!important;}
.section-head span{font-size:13px!important;}
.profile-controls select{height:38px!important;font-size:13px!important;}
.profiles-grid,.q1-live-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
}
.profile-card,.q1-live-profile{
  min-height:230px!important;
  border-radius:15px!important;
  grid-template-columns:minmax(0,1.35fr) minmax(220px,.68fr)!important;
  gap:14px!important;
  padding:14px!important;
  overflow:hidden!important;
}
.q1-live-profile h3,.profile-card h3{font-size:18px!important;font-weight:680!important;line-height:1.1!important;margin-bottom:3px!important;}
.profile-meta{font-size:12px!important;line-height:1.25!important;}
.q1-live-profile .profile-chart,.profile-chart{height:168px!important;min-height:168px!important;}
.q1-live-profile .q1-live-values{max-height:190px!important;overflow:auto!important;padding-left:12px!important;}
.profile-table,.q1-live-profile .profile-table{font-size:11px!important;line-height:1.14!important;table-layout:fixed!important;}
.profile-table th,.profile-table td,.q1-live-profile .profile-table th,.q1-live-profile .profile-table td{padding:3.5px 5px!important;font-weight:470!important;}
.profile-table th,.q1-live-profile .profile-table th{font-weight:650!important;}
@media(max-width:1160px){
  .profiles-grid,.q1-live-grid{grid-template-columns:1fr!important;}
  .profile-card,.q1-live-profile{grid-template-columns:1fr!important;}
}
.bottom-bar{
  position:static!important;
  padding:11px 14px!important;
  gap:12px!important;
  flex-wrap:wrap!important;
}
.status-left{font-size:14px!important;gap:10px!important;}
.bottom-actions{margin-left:auto!important;}
.bottom-actions button{min-width:145px!important;}
.rules{grid-template-columns:repeat(5,minmax(0,1fr))!important;gap:10px!important;}
.rules article{padding:12px!important;min-height:74px!important;}
.rules b{font-size:14px!important;font-weight:650!important;margin-bottom:6px!important;}
.rules span{font-size:12.5px!important;line-height:1.25!important;}
@media(max-width:1250px){.rules{grid-template-columns:repeat(2,minmax(0,1fr))!important;}}
@media(max-width:720px){.rules{grid-template-columns:1fr!important;}.machine-header{grid-template-columns:1fr!important;position:relative!important}.doc-tabs{width:100%!important}.head-actions{justify-content:flex-start!important}}

/* Homepage font rustig houden */
body:not(:has(.machine-shell)){
  font-family:var(--font-v46)!important;
}
/* Einde v46 */


/* v48 - beste tool concept: overzicht, meetproces en viewerkwaliteit, zonder rekenlogica te wijzigen */
.machine-header .brand-text em::after{content:" / v48 beste tool"!important;}
.viewer-panel{box-shadow:0 0 0 1px rgba(34,211,255,.20),0 28px 80px rgba(0,0,0,.36)!important;}
.viewer-map{background:radial-gradient(circle at 50% 50%,rgba(18,45,80,.52),#050b17 72%)!important;}
.viewer-bar{border-bottom-color:rgba(34,211,255,.22)!important;background:linear-gradient(90deg,rgba(4,12,28,.86),rgba(10,25,48,.62))!important;}
#measureProcessBtn.active{background:linear-gradient(180deg,rgba(255,59,213,.32),rgba(255,59,213,.15))!important;border-color:rgba(255,59,213,.70)!important;color:#fff!important;box-shadow:0 0 0 1px rgba(255,59,213,.18),0 0 22px rgba(255,59,213,.24)!important;}
.layer-row input{accent-color:#42d392!important;}
.layers-head{position:sticky;top:0;background:rgba(6,15,30,.94)!important;z-index:2;border-bottom:1px solid rgba(106,161,255,.22)!important;}
.profile-card,.q1-live-profile{background:linear-gradient(180deg,rgba(6,18,36,.74),rgba(3,10,22,.80))!important;}
.q1-live-profile{box-shadow:inset 4px 0 0 var(--h-color,#6aa1ff),0 16px 38px rgba(0,0,0,.22)!important;}
.profile-table tbody tr:nth-child(odd){background:rgba(255,255,255,.025)!important;}
.profile-table td,.profile-table th{white-space:nowrap!important;}
.viewer-note{background:rgba(0,0,0,.72)!important;border-color:rgba(255,59,213,.38)!important;color:#f5f7ff!important;}
.rules article{background:linear-gradient(180deg,rgba(8,20,42,.74),rgba(3,10,22,.62))!important;}
/* einde v48 */

/* v51 - sitebrede uitstraling gelijkgetrokken met startpagina/werkmachine.
   GEEN wijziging in berekening, PDF-logica, viewer-data of H-profielen. */
.machine-header .brand-text em::after{content:" / v51 site gelijk"!important;}
.machine-header{background:linear-gradient(90deg,rgba(4,10,20,.96),rgba(8,18,35,.70),rgba(4,10,20,.96)),url("assets/logo_porstech.png") center/cover no-repeat!important;}
.panel{background:linear-gradient(180deg,rgba(8,18,35,.80),rgba(6,15,30,.76))!important;}
.viewer-panel,.upload-panel,.project-panel,.preview-panel,.profiles-panel,.bottom-bar{border-color:rgba(106,161,255,.30)!important;}
html,body,input,button,select,textarea,table,svg text{font-family:"Aptos","Segoe UI Variable","Segoe UI",Arial,sans-serif!important;letter-spacing:-.012em!important;}

/* v53 - developer print en betaalde PDF-bescherming
   Let op: een browser-screenshot is technisch nooit 100% te blokkeren.
   Daarom krijgt gratis preview een duidelijk watermerk en is printen/PDF opslaan geblokkeerd tot betaling of PorsTech developer-login. */
.dialog-actions{display:flex;align-items:center;gap:10px}
.print-pdf{border:1px solid rgba(255,209,102,.55)!important;background:linear-gradient(180deg,#ffd166,#d89420)!important;color:#06101f!important;border-radius:10px;padding:10px 16px;font-weight:950;cursor:pointer}
.print-pdf:disabled{display:none!important;opacity:.35;cursor:not-allowed}
.pdf-access-note{width:1120px;max-width:100%;margin:0 auto 14px;padding:13px 16px;border-radius:10px;font-weight:900;line-height:1.3}
.pdf-access-note.ok{background:#fff3cd;color:#3b2700;border:1px solid #ffd166}
.pdf-access-note.locked{background:#2a1720;color:#ffd8e4;border:1px solid rgba(255,79,195,.55)}
.locked-preview .pdf-page{position:relative;filter:saturate(.75) contrast(.92)}
.locked-preview .pdf-page:before{content:'VOORBEELD - BETALING NODIG - NIET GELDIG';position:absolute;inset:0;z-index:50;display:grid;place-items:center;pointer-events:none;color:rgba(220,0,85,.18);font-size:62px;font-weight:950;letter-spacing:.06em;transform:rotate(-18deg);text-align:center;line-height:1.1;padding:80px}
.locked-preview .pdf-page:after{content:'Preview is gratis. Definitieve PDF en print pas na betaling of PorsTech developer-login.';position:absolute;left:34px;right:34px;bottom:34px;z-index:51;padding:10px 14px;border:1px solid rgba(220,0,85,.38);background:rgba(255,255,255,.86);color:#7a0030;font-size:13px;font-weight:900;text-align:center;pointer-events:none}
.unlocked-preview .pdf-page:before,.unlocked-preview .pdf-page:after{content:none!important}
.internal-preview .pdf-page{outline:3px solid rgba(66,211,146,.20);outline-offset:-3px}
@media print{
  body *{visibility:hidden!important}
  #pdfDialog,#pdfDialog *{visibility:visible!important}
  #pdfDialog{position:absolute!important;left:0!important;top:0!important;width:100%!important;height:auto!important;max-height:none!important;overflow:visible!important;border:0!important;border-radius:0!important;background:#fff!important;box-shadow:none!important;padding:0!important}
  .dialog-head,.pdf-access-note,.pdf-gate-note{display:none!important}
  #pdfPreview{position:absolute!important;left:0!important;top:0!important;width:100%!important;height:auto!important;overflow:visible!important;background:#fff!important;padding:0!important}
  #pdfPreview.locked-preview{display:none!important}
  .pdf-page{margin:0 auto!important;box-shadow:none!important;page-break-after:always!important;break-after:page!important}
}

/* v55 - alleen fit, documenttaal en privacy/cache isolatie */
.machine-header .brand-text em::after{content:" / v55 fit taal privacy"!important;}
.head-actions button.lang{
  appearance:none;
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:34px!important;
  height:34px!important;
  border-radius:999px!important;
  border:1px solid rgba(255,255,255,.15)!important;
  background:rgba(5,15,32,.76)!important;
  color:#c8d5ef!important;
  font:650 12px/1 var(--font-main,Aptos,"Segoe UI",Arial,sans-serif)!important;
  cursor:pointer;
  padding:0!important;
}
.head-actions button.lang.active{
  border-color:rgba(255,209,102,.62)!important;
  background:rgba(255,209,102,.14)!important;
  color:var(--gold,#ffd166)!important;
  box-shadow:0 0 18px rgba(255,209,102,.14)!important;
}
#fitBtn,#centerBtn,#viewerRefresh{border-color:rgba(66,211,146,.55)!important;color:#9cffd0!important;}
#fitBtn::after{content:""!important;}
.privacy-note{font-size:12px;color:#aebbd0;line-height:1.35;}

/* v56 documenttaal duidelijk zichtbaar */
.doc-lang-box{display:flex;align-items:center;gap:8px;margin:6px 0 12px;padding:8px 10px;border:1px solid rgba(106,161,255,.28);border-radius:14px;background:rgba(3,12,27,.55);color:#dfe9ff;font-size:14px}
.doc-lang-box strong{margin-right:auto;color:#9fc7ff}
.doc-lang{border:1px solid rgba(106,161,255,.35);background:#071324;color:#dfe9ff;border-radius:999px;padding:6px 10px;font-weight:700;cursor:pointer}
.doc-lang.active{background:#143e76;border-color:#ffd166;color:#fff;box-shadow:0 0 0 1px rgba(255,209,102,.35)}

/* v57 - lege projectvelden, echte fullscreen viewer en H-detectie uit TXT/DXF-puntcodes */
.machine-header .brand-text em::after{content:" / v57 leeg + fullscreen + H-detectie"!important;}
.fields input::placeholder{color:#667b9b!important;font-weight:440!important;}
.fields input{font-weight:520!important;}
body.viewer-fullscreen-open{overflow:hidden!important;}
.viewer-panel.viewer-fullscreen{
  position:fixed!important;
  inset:10px!important;
  z-index:9999!important;
  width:auto!important;
  height:auto!important;
  min-height:0!important;
  display:grid!important;
  grid-template-rows:54px 1fr!important;
  border-radius:18px!important;
  background:linear-gradient(180deg,rgba(4,12,26,.98),rgba(2,7,16,.98))!important;
  box-shadow:0 0 0 9999px rgba(0,0,0,.72),0 0 90px rgba(34,211,255,.26)!important;
}
.viewer-panel.viewer-fullscreen .viewer-map{height:calc(100vh - 84px)!important;min-height:0!important;}
.viewer-panel.viewer-fullscreen .map-controls{top:74px!important;right:18px!important;}
.viewer-panel.viewer-fullscreen #fullBtn{background:rgba(255,209,102,.20)!important;border-color:rgba(255,209,102,.75)!important;color:#ffd166!important;font-size:20px!important;}
.viewer-panel.viewer-fullscreen .viewer-note{font-size:15px!important;left:18px!important;right:18px!important;bottom:18px!important;}
.pdf-rd-and-profiles{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:12px;align-items:stretch;height:560px;}
.pdf-rd-and-profiles .pdf-rd-frame{height:100%!important;min-height:0!important;}
.pdf-profile-side{border:1px solid #111;background:#fff;color:#111;padding:10px 10px 8px;overflow:hidden;font-family:Arial,sans-serif;}
.pdf-profile-side h3{margin:0 0 6px;font-size:15px;font-weight:700;color:#111;}
.pdf-profile-side p{margin:0 0 8px;font-size:9.5px;color:#333;line-height:1.25;}
.pdf-profile-side table{width:100%;border-collapse:collapse;font-size:9.4px;}
.pdf-profile-side th,.pdf-profile-side td{border-bottom:1px solid #d5d5d5;padding:4px 3px;text-align:left;white-space:nowrap;}
.pdf-profile-side th:nth-child(2),.pdf-profile-side th:nth-child(3),.pdf-profile-side td:nth-child(2),.pdf-profile-side td:nth-child(3){text-align:right;}
@media(max-width:900px){.viewer-panel.viewer-fullscreen{inset:4px!important;border-radius:12px!important}.viewer-panel.viewer-fullscreen .viewer-map{height:calc(100vh - 70px)!important}.pdf-rd-and-profiles{grid-template-columns:1fr;height:auto}.pdf-profile-side{min-height:180px}}

/* v58 - leesbare profielen en extra viewer-hulpmiddelen */
.machine-header .brand-text em::after{content:" / v59 bladnummers + H-labels"!important;}
.viewer-bar{gap:6px!important;align-items:center!important;}
.viewer-bar>button.tool-active,.viewer-bar>button.active,#dxfLineBtn.active,#pointToggleBtn.active,#gridToggleBtn.active,#profileLabelBtn.active{border-color:rgba(66,211,146,.58)!important;background:rgba(28,106,83,.44)!important;color:#c9ffe5!important;}
.viewer-bar>button{font-size:12px!important;font-weight:650!important;min-width:auto!important;}
#fullBtn.fullscreen-main{background:linear-gradient(180deg,#ffd166,#d89420)!important;color:#07101f!important;border-color:rgba(255,209,102,.75)!important;font-weight:800!important;min-width:94px!important;}
#fullSideBtn{background:rgba(255,209,102,.22)!important;border-color:rgba(255,209,102,.70)!important;color:#ffd166!important;font-size:18px!important;}
#map.no-grid{background:#07101f!important;}
#map.no-grid:before{display:none!important;}
.viewer-map.dxf-only:not(.no-grid):before,#map:not(.no-grid):before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(106,161,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(106,161,255,.08) 1px,transparent 1px);background-size:36px 36px;z-index:0;pointer-events:none;}
.viewer-map .leaflet-pane{z-index:1;}

.profiles-panel{padding:16px!important;}
.profiles-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(min(860px,100%),1fr))!important;gap:16px!important;align-items:start!important;}
.profile-card.q1-live-profile{display:grid!important;grid-template-columns:minmax(0,1.65fr) minmax(250px,.72fr)!important;gap:14px!important;background:linear-gradient(180deg,#f8fafc,#eef3fb)!important;color:#172033!important;border-left:5px solid var(--h-color)!important;border-color:rgba(106,161,255,.36)!important;padding:14px!important;min-height:260px!important;}
.profile-card.q1-live-profile h3{font-family:Inter,Aptos,"Segoe UI",Arial,sans-serif!important;color:#172033!important;font-size:19px!important;font-weight:740!important;line-height:1.1!important;margin-bottom:3px!important;}
.profile-card.q1-live-profile .profile-meta{color:#33425b!important;font-size:12.5px!important;font-weight:600!important;margin-bottom:8px!important;}
.q1-live-chart{min-width:0!important;}
.profile-chart{height:205px!important;background:#f8fafc!important;border:1px solid #cfd8e6!important;border-radius:8px!important;}
.profile-chart svg{display:block!important;overflow:visible!important;}
.profile-chart .pt-name{font-size:8px!important;paint-order:stroke!important;stroke:#f8fafc!important;stroke-width:2.6px!important;stroke-linejoin:round!important;fill:#1f2937!important;font-weight:650!important;}
.q1-live-values{min-width:0!important;max-height:236px!important;overflow:auto!important;background:rgba(255,255,255,.55)!important;border:1px solid #d5deea!important;border-radius:8px!important;padding:8px!important;color:#172033!important;scrollbar-width:thin!important;}
.q1-live-values strong{display:block!important;color:#172033!important;font-size:13px!important;line-height:1.2!important;margin-bottom:3px!important;}
.q1-live-values span{display:block!important;color:#526176!important;font-size:11px!important;margin-bottom:6px!important;}
.profile-table{font-size:11.5px!important;line-height:1.15!important;color:#172033!important;}
.profile-table th{position:sticky!important;top:0!important;background:#eaf0f8!important;color:#172033!important;border-bottom:1px solid #aab7c8!important;padding:5px 6px!important;z-index:1!important;}
.profile-table td{color:#172033!important;border-bottom:1px solid #d7dfeb!important;padding:4px 6px!important;white-space:nowrap!important;}
.profile-table td:first-child{max-width:120px!important;overflow:hidden!important;text-overflow:ellipsis!important;}

@media(max-width:1150px){
  .profile-card.q1-live-profile{grid-template-columns:1fr!important;}
  .q1-live-values{max-height:210px!important;}
}

/* v59 - PDF-bladnummer en H-label duidelijk gescheiden */
.blad-chip{display:inline-block;margin-left:8px;padding:3px 8px;border-radius:999px;background:rgba(255,209,102,.15);border:1px solid rgba(255,209,102,.45);color:#705400;font-size:11px;font-weight:800;vertical-align:middle}.profile-label{font-weight:900!important}.pdf-profile-side table th:first-child,.pdf-profile-side table td:first-child{text-align:center;width:42px}

/* v60 - meetpunten leesbaar op kaart, H-labels niet meer als zwarte blokken */
.viewer-bar{overflow-x:auto!important;scrollbar-width:thin!important;align-items:center!important;}
.viewer-bar>button#pointFocusBtn.active{border-color:rgba(255,209,102,.68)!important;background:linear-gradient(180deg,rgba(255,209,102,.26),rgba(255,209,102,.12))!important;color:#ffe9a7!important;}
.h-map-badge{background:transparent!important;border:0!important;box-shadow:none!important;pointer-events:none!important;}
.h-map-badge span{display:inline-flex;align-items:center;gap:5px;transform:translate(-50%,-50%);padding:3px 7px;border-radius:999px;background:rgba(3,10,22,.54)!important;border:1px solid var(--h,rgba(255,209,102,.85))!important;color:#fff!important;text-shadow:0 1px 2px #000;font-size:11px!important;font-weight:800!important;box-shadow:0 0 0 1px rgba(255,255,255,.08),0 4px 14px rgba(0,0,0,.25);}
.h-map-badge small{font-size:9px;color:#cbd8ef;font-weight:700;opacity:.72;}
.profile-label{background:rgba(2,7,17,.70)!important;border:1px solid rgba(255,255,255,.20)!important;color:#fff!important;font-size:10px!important;font-weight:700!important;padding:3px 6px!important;border-radius:999px!important;box-shadow:none!important;}
.pt-label{font-size:10px!important;font-weight:650!important;background:rgba(2,7,17,.76)!important;border:1px solid rgba(0,234,255,.45)!important;color:#fff!important;border-radius:8px!important;box-shadow:none!important;}
.leaflet-marker-pane{z-index:650!important;}
.leaflet-tooltip-pane{z-index:660!important;}
.leaflet-overlay-pane svg circle{filter:drop-shadow(0 0 3px rgba(255,255,255,.65));}
.viewer-note{font-size:13px!important;line-height:1.25!important;}
.profile-chart svg .pt-name{font-size:7px!important;font-weight:600!important;paint-order:stroke;stroke:#fff;stroke-width:2px;stroke-linejoin:round;}
.pdf-page svg .pt-name{font-size:6px!important;font-weight:500!important;paint-order:stroke;stroke:#fff;stroke-width:1.4px;stroke-linejoin:round;}
@media(max-width:1200px){.viewer-bar>button,.viewer-bar span{padding-left:9px!important;padding-right:9px!important;font-size:12px!important}.h-map-badge span{font-size:10px!important}}


/* v62 - fullscreen printscreen naar PDF, maximaal 4 A3-pagina's direct na blad 1 */
.machine-header .brand-text em::after{content:" / v62 printscreen naar PDF"!important;}
#shotBtn.active{border-color:rgba(255,209,102,.75)!important;background:linear-gradient(180deg,rgba(255,209,102,.28),rgba(255,209,102,.12))!important;color:#ffe7a0!important;}
#shotClearBtn:disabled{opacity:.55;cursor:not-allowed;}
.viewer-panel.viewer-fullscreen #shotBtn{background:rgba(34,211,255,.18)!important;border-color:rgba(34,211,255,.60)!important;color:#dff8ff!important;font-size:16px!important;}
.viewer-panel.viewer-fullscreen #shotBtn.active{background:rgba(255,209,102,.24)!important;border-color:rgba(255,209,102,.80)!important;color:#ffe9aa!important;}
.pdf-screen-frame{height:570px;border:2px solid #111;background:#f4f7fb;display:flex;align-items:center;justify-content:center;overflow:hidden;margin:14px 0 10px;}
.pdf-screen-frame img{width:100%;height:100%;object-fit:contain;display:block;background:#07101f;}
.pdf-screen-page .pdf-sub{margin-bottom:8px!important;}
@media print{.pdf-screen-frame{height:570px!important;break-inside:avoid!important}.pdf-screen-frame img{max-width:100%!important;max-height:100%!important}}

/* v63 - as-built modus + printscreenknop ook in fullscreen zijbalk */
.machine-header .brand-text em::after{content:" / v66 leerset + automatische herkenning"!important;}
#shotSideBtn{
  background:rgba(34,211,255,.18)!important;
  border-color:rgba(34,211,255,.58)!important;
  color:#dff8ff!important;
  font-size:13px!important;
  font-weight:800!important;
}
#shotSideBtn.active{background:rgba(255,209,102,.22)!important;border-color:rgba(255,209,102,.75)!important;color:#ffe7a0!important;}
.viewer-panel.viewer-fullscreen #shotSideBtn{
  display:flex!important;
  width:76px!important;
  min-width:76px!important;
  height:46px!important;
  font-size:15px!important;
  border-radius:14px!important;
  background:linear-gradient(180deg,rgba(34,211,255,.26),rgba(10,39,76,.84))!important;
  box-shadow:0 0 24px rgba(34,211,255,.22)!important;
}
body.doc-asbuilt .profiles-panel .section-head h2,
body.doc-asbuilt .preview-panel h2{color:#9cffd0!important;}
body.doc-asbuilt .doc-choice{color:#9cffd0!important;}
.asbuilt-series-grid .profile-card.q1-live-profile.asbuilt-card{border-left-color:var(--h-color)!important;background:linear-gradient(180deg,#f8fbff,#edf6ff)!important;}
.profile-chart.asbuilt-plan{height:205px!important;background:#f8fafc!important;}
.profile-chart.asbuilt-plan svg text{font-family:Inter,Aptos,"Segoe UI",Arial,sans-serif!important;font-weight:650!important;paint-order:stroke;stroke:#fff;stroke-width:2px;stroke-linejoin:round;}
.asbuilt-table{font-size:10.4px!important;}
.asbuilt-table th,.asbuilt-table td{padding:4px 5px!important;}
.asbuilt-table td:nth-child(1){max-width:90px!important;}
.asbuilt-pdf-profiles .pdf-profile{grid-template-columns:minmax(0,1.2fr) minmax(240px,.8fr)!important;}
.asbuilt-pdf-profile table{font-size:8.2px!important;}
.asbuilt-pdf-profile td,.asbuilt-pdf-profile th{padding:2px 3px!important;}
.pdf-profile-side h3{color:#0d513d!important;}
@media(max-width:900px){#shotSideBtn{display:flex!important;}}


/* v65 - leerset / ZIP-herkenning en automatische tabel/documentkeuze */
.machine-header .brand-text em::after{content:" / v65 leerset + automatische herkenning"!important;}
.learning-panel-mini{margin-top:12px;border:1px solid rgba(34,211,255,.22);background:rgba(3,14,31,.52);border-radius:14px;padding:10px 11px;color:#dfefff;}
.learning-panel-mini>strong{display:block;font-size:13px;margin-bottom:7px;color:#ffffff;letter-spacing:.02em;}
.learning-report{font-size:12px;line-height:1.35;color:#c9d8ef;}
.learn-verdict{display:inline-block;padding:4px 9px;border-radius:999px;font-weight:900;font-size:12px;margin-bottom:7px;}
.learn-verdict.ok{background:rgba(66,211,146,.18);border:1px solid rgba(66,211,146,.55);color:#b9ffe0;}
.learn-verdict.warn{background:rgba(255,209,102,.17);border:1px solid rgba(255,209,102,.55);color:#ffe6a0;}
.learn-verdict.bad{background:rgba(255,88,88,.17);border:1px solid rgba(255,88,88,.55);color:#ffc2c2;}
.learn-row{margin:5px 0;color:#d9e8ff;}
.learn-row b{color:#fff;}
.learn-row.muted{font-size:11px;color:#8fa5c1;}
.learn-tags{display:flex;flex-wrap:wrap;gap:5px;margin:7px 0;}
.learn-tags span{border:1px solid rgba(106,161,255,.28);background:rgba(106,161,255,.10);border-radius:999px;padding:3px 7px;color:#d8e8ff;font-size:11px;font-weight:700;}
.learn-table{width:100%;border-collapse:collapse;margin-top:7px;font-size:11px;}
.learn-table th,.learn-table td{border-bottom:1px solid rgba(255,255,255,.09);padding:4px 3px;text-align:left;}
.learn-table th{color:#9db8d8;font-weight:800;}
.learn-table td:nth-child(2),.learn-table td:nth-child(3){text-align:right;}
.doc-tabs button.active[data-doc="auto"]{border-color:rgba(255,209,102,.65)!important;background:rgba(255,209,102,.14)!important;color:#ffe6a0!important;}

/* v68 - Survey Control exportknoppen */
.actions .blue,.bottom-actions .blue,.dialog-head button.blue{border:1px solid rgba(34,211,255,.58)!important;background:linear-gradient(180deg,#22d3ff,#1667c8)!important;color:#06101f!important;font-weight:900!important;}
.dialog-head button.gold{border:1px solid rgba(255,209,102,.65)!important;background:linear-gradient(180deg,#ffd166,#d89420)!important;color:#06101f!important;font-weight:900!important;}
.dialog-actions button[disabled]{opacity:.45!important;cursor:not-allowed!important;}
.v68-export-note{font-size:12px;color:#b8c4d9;margin-top:8px;}


/* v69 - Survey Control zakelijke typografie + logo-achtergrond behouden op elke machinepagina */
:root{
  --font-main:"Segoe UI Variable","Segoe UI",Aptos,Arial,sans-serif!important;
  --font-head:"Segoe UI Variable","Segoe UI",Aptos,Arial,sans-serif!important;
}
html,body,input,button,select,textarea,table,td,th,a,p,li,span,label,small,strong,em,svg text{
  font-family:var(--font-main)!important;
  letter-spacing:-.01em!important;
  -webkit-font-smoothing:antialiased!important;
  text-rendering:geometricPrecision!important;
}
h1,h2,h3,h4,.brand-text strong,.machine-title,.panel h2,.section-head h2,.doc-tabs button,.btn,button,.nav a{
  font-family:var(--font-head)!important;
  font-weight:750!important;
  letter-spacing:-.025em!important;
  text-transform:none!important;
}
.machine-body,body{
  background:#061021!important;
  position:relative!important;
}
.machine-body:before,body:before{
  content:""!important;
  position:fixed!important;
  inset:0!important;
  z-index:-4!important;
  pointer-events:none!important;
  background:
    linear-gradient(90deg,rgba(4,10,20,.94),rgba(4,10,20,.58) 46%,rgba(4,10,20,.94)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
}
.machine-body:after,body:after{
  content:""!important;
  position:fixed!important;
  inset:0!important;
  z-index:-3!important;
  pointer-events:none!important;
  background-image:
    radial-gradient(circle at 18% 14%,rgba(34,211,255,.18),transparent 27%),
    radial-gradient(circle at 80% 6%,rgba(66,211,146,.13),transparent 30%),
    linear-gradient(rgba(255,255,255,.030) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.026) 1px,transparent 1px)!important;
  background-size:auto,auto,28px 28px,28px 28px!important;
}
.machine-header{
  background:
    linear-gradient(90deg,rgba(4,10,20,.97),rgba(7,19,38,.78),rgba(4,10,20,.97)),
    url("assets/logo_porstech.png") center center/cover no-repeat!important;
  backdrop-filter:blur(16px)!important;
}
.machine-main,.workspace,.panel,.viewer-panel,.preview-panel,.profiles-panel{
  position:relative!important;
}
.machine-main:before,.workspace:before{
  content:""!important;
  position:absolute!important;
  inset:10px!important;
  z-index:-1!important;
  pointer-events:none!important;
  background:url("assets/logo_porstech.png") center center/contain no-repeat!important;
  opacity:.075!important;
  filter:drop-shadow(0 0 34px rgba(34,211,255,.20))!important;
}
.panel,.viewer-panel,.preview-panel,.profiles-panel,.upload-card,.control-card{
  background:linear-gradient(180deg,rgba(8,20,42,.86),rgba(3,10,22,.78))!important;
  border-color:rgba(106,161,255,.25)!important;
  box-shadow:0 24px 80px rgba(0,0,0,.34)!important;
}
.machine-header .brand-text em::after{content:" / v70 voorbeelden kaart + satelliet"!important;}

/* v70 - voorbeeldpagina uitgebreid met fictieve kaart- en satellietweergave. */


/* =========================================================
   v71 - Survey Control werkmachine afgestemd op commerciële stijl
   ========================================================= */
*{font-family:Inter,"Segoe UI",Arial,sans-serif}
body:before{background:linear-gradient(90deg,rgba(3,9,20,.94),rgba(6,16,31,.76) 46%,rgba(6,16,31,.94)),url("assets/balk.png") center/cover no-repeat fixed!important}
body:after{background:radial-gradient(circle at 72% 12%,rgba(66,211,146,.13),transparent 28%),radial-gradient(circle at 20% 0%,rgba(106,161,255,.17),transparent 25%),url("assets/logo_porstech.png") right -15vw top 110px / 34vw auto no-repeat,linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.016) 1px,transparent 1px)!important;background-size:auto,auto,34vw auto,22px 22px,22px 22px!important;opacity:.28!important}
.machine-header{background:linear-gradient(90deg,rgba(4,10,20,.96),rgba(8,18,35,.80),rgba(4,10,20,.96)),url("assets/balk.png") center/cover no-repeat!important;border-bottom:1px solid rgba(106,161,255,.28)!important}
.brand img{border-radius:6px!important;box-shadow:0 0 26px rgba(34,211,255,.18)!important}
.brand-text strong{font-size:32px!important;letter-spacing:-.05em!important;font-weight:760!important}
.brand-text small{font-family:"Orbitron","Segoe UI Variable","Segoe UI",Arial,sans-serif!important;text-transform:uppercase!important;letter-spacing:.22em!important;color:#eef4ff!important;font-weight:780!important}
.brand-text em{letter-spacing:.12em!important;color:#42d392!important}
.viewer-panel,.upload-panel,.project-panel,.preview-panel,.profiles-panel{box-shadow:0 24px 62px rgba(0,0,0,.32)!important}
.preview-panel .actions button:nth-child(2){background:linear-gradient(135deg,#0d55a8,#102548)!important;border-color:rgba(34,211,255,.42)!important;color:#fff!important}
.preview-panel .actions button.gold,.bottom-actions .gold{background:linear-gradient(135deg,#ffd166,#f2a62a)!important;color:#06101f!important}


/* v73 - puntcode labels + Z-hoogte in viewer */
.machine-header .brand-text em::after{content:" / v73 puntcode labels + Z"!important}
.pt-code-label{background:rgba(2,8,18,.94)!important;border:1px solid rgba(66,211,146,.58)!important;border-radius:9px!important;color:#fff!important;padding:4px 6px!important;box-shadow:0 6px 18px rgba(0,0,0,.45)!important;font-weight:740!important;line-height:1.05!important}
.pt-code-label small{display:block;color:#ffd166;font-size:10px;font-weight:760;margin-top:2px}
.pt-code-label em{display:block;color:#9fb1c9;font-size:9px;font-style:normal;font-weight:520;margin-top:2px}
.asbuilt-plan svg text{font-size:7.2px!important;font-weight:760!important;paint-order:stroke;stroke:#fff;stroke-width:2px;fill:#111827!important}


/* =========================================================
   v74 - Space font alleen op de site, NIET in PDF-output
   ========================================================= */
.pdf-page,
.pdf-page *,
.pdf-page svg,
.pdf-page svg *,
.pdf-profile-values,
.pdf-profile-values *,
.pdf-profile-side,
.pdf-profile-side *,
.q1-page,
.q1-page *{
  font-family: Arial, "Segoe UI", Helvetica, sans-serif!important;
  letter-spacing:0!important;
  text-rendering:auto!important;
}
.pdf-page h1,.pdf-page h2,.pdf-page h3,.pdf-page b,.pdf-page strong{
  font-family: Arial, "Segoe UI", Helvetica, sans-serif!important;
  font-weight:700!important;
}
.pdf-profile svg text,.profile-chart svg text{
  font-family: Arial, "Segoe UI", Helvetica, sans-serif!important;
  letter-spacing:0!important;
}
.machine-header .brand-text small,.v50-brand small,.space-wordmark{
  font-family:"Orbitron","Segoe UI Variable","Segoe UI",Arial,sans-serif!important;
}
/* einde v74 */


/* =========================================================
   v75 - x-as leesbaar + space font alleen buiten PDF
   ========================================================= */
/* Website/werkmachine UI mag space font hebben */
.machine-header .brand-text strong,
.machine-header .brand-text small,
.machine-header .brand-text em,
.doc-tabs button,
.preview-panel h2,
.upload-panel h2,
.project-panel h2,
.profiles-panel h2,
.section-head h2,
.actions button,
.bottom-actions button{
  font-family:"Orbitron","Segoe UI Variable","Segoe UI",Arial,sans-serif!important;
  letter-spacing:.035em!important;
  font-weight:800!important;
}
/* Meetdata, tabellen en assen blijven leesbaar */
.profile-chart svg text,
.q1-live-profile .profile-chart svg text,
.profile-table,
.profile-table *,
.q1-live-values,
.q1-live-values *,
.pdf-profile-values,
.pdf-profile-values *{
  font-family:Arial,"Segoe UI",Helvetica,sans-serif!important;
  letter-spacing:0!important;
  text-rendering:auto!important;
}
.profile-chart svg .axis-x,
.pdf-profile svg .axis-x{
  font-size:8.8px!important;
  font-weight:700!important;
}
.profile-chart svg .axis-tick,
.pdf-profile svg .axis-tick{
  font-family:Arial,"Segoe UI",Helvetica,sans-serif!important;
  letter-spacing:0!important;
}
/* PDF hard terug naar zakelijke technische fonts, geen Orbitron/Starfleet/Suissnord */
#pdfPreview,
#pdfPreview *,
.pdf-page,
.pdf-page *,
.pdf-page svg,
.pdf-page svg *,
.q1-page,
.q1-page *,
.pdf-profile,
.pdf-profile *,
.pdf-profile-side,
.pdf-profile-side *,
.pdf-profile-values,
.pdf-profile-values *{
  font-family:Arial,"Segoe UI",Helvetica,sans-serif!important;
  letter-spacing:0!important;
  text-rendering:auto!important;
}
#pdfPreview h1,#pdfPreview h2,#pdfPreview h3,#pdfPreview b,#pdfPreview strong,
.pdf-page h1,.pdf-page h2,.pdf-page h3,.pdf-page b,.pdf-page strong{
  font-family:Arial,"Segoe UI",Helvetica,sans-serif!important;
  font-weight:700!important;
  letter-spacing:0!important;
}
.machine-header .brand-text em::after{content:" / v75 x-as leesbaar + PDF normaal font"!important;}


/* v78 - BGTviewer.nl extern, DXF/RD als interne fallback */
.machine-header .brand-text em::after{content:" / v78 BGTviewer extern"!important;}
#bgtViewerBtn{border-color:rgba(255,209,102,.55)!important;background:linear-gradient(135deg,rgba(255,209,102,.20),rgba(7,18,36,.85))!important;color:#fff3c4!important;}
.viewer-note::before{content:"Kaartbron: ";font-weight:950;color:#fff;}


/* =========================================================
   v80 - OpenStreet terug + meer balk/logo in browser, nooit in PDF
   ========================================================= */
.machine-header .brand-text em::after{content:" / v80 OSM + install betaling"!important;}
#bgtViewerBtn{display:none!important;}
.viewer-note::before{content:"Kaartbron: ";font-weight:950;color:#fff;}
#map:not(.dxf-only) .leaflet-tile-pane{opacity:1!important;filter:none!important;}
#map:not(.dxf-only)::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(3,9,20,.18),rgba(3,9,20,.08));z-index:430;}
body::before{
  background:linear-gradient(90deg,rgba(3,9,20,.92),rgba(3,9,20,.58) 46%,rgba(3,9,20,.88)),url("assets/balk.png") center/cover no-repeat fixed!important;
}
body::after{
  background:url("assets/logo_porstech.png") right -10vw top 94px/34vw auto no-repeat,radial-gradient(circle at 22% 9%,rgba(106,161,255,.18),transparent 30%),radial-gradient(circle at 80% 12%,rgba(66,211,146,.13),transparent 30%),linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.016) 1px,transparent 1px)!important;
  background-size:34vw auto,auto,auto,24px 24px,24px 24px!important;
  opacity:.34!important;
}
#pdfPreview,#pdfPreview *,.pdf-page,.pdf-page *{
  background-image:none!important;
  text-shadow:none!important;
}


/* =========================================================
   v82 - werkmachine gelijk met site. PDF/profieldata blijft leesbaar.
   ========================================================= */
:root{
  --survey-ui-font:"Orbitron","Segoe UI Variable","Segoe UI",Aptos,Arial,sans-serif;
  --survey-data-font:Arial,"Segoe UI",Helvetica,sans-serif;
}
body,.machine-body,
.machine-header,.machine-header *,
.machine-main,.machine-main *,
.workspace,.workspace *,
.panel,.panel *,
.viewer-bar,.viewer-bar *,
.doc-tabs,.doc-tabs *,
.actions,.actions *,
.bottom-actions,.bottom-actions *,
button,input,select,textarea,label{
  font-family:var(--survey-ui-font)!important;
  letter-spacing:.012em!important;
  text-transform:none!important;
}
.machine-header .brand-text strong,
.machine-header .brand-text small,
.machine-header .brand-text em,
.compact h2,.profiles-panel h2,.preview-panel h2,.project-panel h2,.upload-panel h2,.section-head h2{
  font-family:var(--survey-ui-font)!important;
  font-weight:800!important;
  letter-spacing:.012em!important;
}
.machine-header .brand-text em::after{content:" / v82 huisstijl + prijzen"!important;}
body::before,.machine-body::before{
  background:linear-gradient(90deg,rgba(3,9,20,.92),rgba(3,9,20,.55) 46%,rgba(3,9,20,.88)),url("assets/balk.png") center/cover no-repeat fixed!important;
}
body::after,.machine-body::after{
  background:url("assets/logo_porstech.png") right -8vw top 86px/32vw auto no-repeat,url("assets/logo_porstech.png") left -13vw bottom -8vw/34vw auto no-repeat,radial-gradient(circle at 22% 9%,rgba(106,161,255,.20),transparent 30%),radial-gradient(circle at 80% 12%,rgba(66,211,146,.15),transparent 30%),linear-gradient(rgba(255,255,255,.020) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px)!important;
  background-size:32vw auto,34vw auto,auto,auto,24px 24px,24px 24px!important;
  opacity:.40!important;
}
/* technische data, grafiekassen en PDF krijgen normale fonts */
.profile-chart,.profile-chart *,
.profile-table,.profile-table *,
.q1-live-values,.q1-live-values *,
.asbuilt-plan,.asbuilt-plan *,
.pdf-profile-values,.pdf-profile-values *,
#pdfPreview,#pdfPreview *,
.pdf-page,.pdf-page *,
.pdf-page svg,.pdf-page svg *,
.q1-page,.q1-page *,
.pdf-profile,.pdf-profile *,
.pdf-profile-side,.pdf-profile-side *{
  font-family:var(--survey-data-font)!important;
  letter-spacing:0!important;
  text-transform:none!important;
  text-rendering:auto!important;
}
.profile-chart svg text,.pdf-profile svg text{font-family:var(--survey-data-font)!important;letter-spacing:0!important;}
#pdfPreview h1,#pdfPreview h2,#pdfPreview h3,.pdf-page h1,.pdf-page h2,.pdf-page h3{font-family:var(--survey-data-font)!important;font-weight:700!important;}


/* Survey Control live AI-assistent */
.sc-ai-open{position:fixed;right:22px;bottom:22px;z-index:9000;border:1px solid rgba(246,198,74,.65);background:linear-gradient(180deg,#ffd768,#f0b42d);color:#111827;border-radius:999px;padding:14px 18px;font-weight:900;box-shadow:0 16px 44px rgba(0,0,0,.38);cursor:pointer}
.sc-ai-panel{position:fixed;right:22px;bottom:82px;width:min(420px,calc(100vw - 32px));height:min(620px,calc(100vh - 120px));z-index:9001;border:1px solid rgba(106,161,255,.35);border-radius:22px;background:linear-gradient(180deg,rgba(12,20,36,.98),rgba(5,10,20,.98));box-shadow:0 22px 70px rgba(0,0,0,.55);display:none;overflow:hidden;color:#eaf0ff}
body.sc-ai-open .sc-ai-panel{display:flex;flex-direction:column}.sc-ai-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid rgba(106,161,255,.22)}.sc-ai-head strong{font-size:18px;color:#fff}.sc-ai-head button{background:transparent;border:1px solid rgba(255,255,255,.18);color:#fff;border-radius:999px;width:34px;height:34px;font-size:22px;cursor:pointer}.sc-ai-sub{padding:12px 18px;color:#aebbd4;font-size:13px;border-bottom:1px solid rgba(106,161,255,.14)}.sc-ai-messages{flex:1;overflow:auto;padding:14px;display:flex;flex-direction:column;gap:10px}.sc-ai-msg{white-space:pre-wrap;border-radius:16px;padding:11px 13px;line-height:1.45;font-size:14px}.sc-ai-msg.bot{background:rgba(106,161,255,.12);border:1px solid rgba(106,161,255,.20);align-self:flex-start}.sc-ai-msg.user{background:rgba(246,198,74,.14);border:1px solid rgba(246,198,74,.25);align-self:flex-end;max-width:88%}.sc-ai-input{display:grid;grid-template-columns:1fr auto;gap:10px;padding:14px;border-top:1px solid rgba(106,161,255,.18)}.sc-ai-input textarea{resize:none;border:1px solid rgba(106,161,255,.25);border-radius:14px;background:#07111f;color:#eaf0ff;padding:10px;font:inherit}.sc-ai-input button{border:0;border-radius:14px;background:#ffd166;color:#111827;font-weight:900;padding:0 16px;cursor:pointer}.sc-ai-input button:disabled{opacity:.55;cursor:wait}@media(max-width:640px){.sc-ai-open{right:16px;bottom:16px}.sc-ai-panel{right:16px;bottom:72px}}

/* HERSTELSET V88 - viewer waas uit */
#map:not(.dxf-only) .leaflet-tile-pane,
.leaflet-tile-pane,
.leaflet-tile,
.leaflet-layer,
.leaflet-layer img,
.leaflet-container img,
img.leaflet-tile {
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}
.leaflet-container,
.viewer-map,
#map,
.mapboxgl-map,
canvas,
.mapboxgl-canvas {
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}
.map-overlay,
.viewer-overlay,
.sc-map-overlay,
.sc-viewer-overlay,
.map-dim,
.viewer-dim,
.sc-map-dim,
.sc-viewer-dim,
.loading-overlay,
.busy-overlay {
  display: none !important;
  opacity: 0 !important;
  background: transparent !important;
  pointer-events: none !important;
}

/* HOOGTEDOCUMENT NL14 PRO V1 */
/* Alleen PDF/preview-documentstijl. Geen viewer/upload-motor wijziging. */
.pdf-page.q1-page{
  background:#ffffff!important;
  color:#172033!important;
  border:1px solid #d7dee9!important;
  box-shadow:0 16px 50px rgba(0,0,0,.22)!important;
  padding:30px!important;
}
.q1-head{
  grid-template-columns:128px 1fr!important;
  gap:20px!important;
  border-bottom:3px solid #1f4e79!important;
  padding-bottom:12px!important;
  margin-bottom:16px!important;
}
.q1-head img{
  width:112px!important;
  height:56px!important;
  object-fit:contain!important;
  border-radius:0!important;
}
.q1-head h1{
  color:#17365d!important;
  font-size:24px!important;
  font-weight:800!important;
  letter-spacing:-.015em!important;
}
.q1-head p{
  color:#40536f!important;
  font-size:10.5px!important;
  line-height:1.35!important;
}
.q1-page .pdf-meta{
  border:1px solid #cbd5e1!important;
  border-radius:8px!important;
  padding:9px 11px!important;
  background:#f8fafc!important;
  color:#1e293b!important;
}
.pdf-map-frame,.pdf-rd-frame,.pdf-profile svg{
  border:1.6px solid #1f4e79!important;
  background:#f8fafc!important;
}
.pdf-rd-and-profiles{
  gap:14px!important;
}
.pdf-profile-side{
  border:1px solid #cbd5e1!important;
  border-radius:8px!important;
  background:#f8fafc!important;
  padding:10px!important;
}
.pdf-profile-side h3{
  color:#17365d!important;
  margin-top:0!important;
}
.pdf-profile table,.pdf-profile-side table{
  border-collapse:collapse!important;
  background:#fff!important;
}
.pdf-profile th,.pdf-profile td,.pdf-profile-side th,.pdf-profile-side td{
  border:1px solid #cbd5e1!important;
  padding:4px 5px!important;
  color:#172033!important;
}
.pdf-profile th,.pdf-profile-side th{
  background:#eaf2fb!important;
  color:#17365d!important;
  font-weight:800!important;
}
.pdf-profile svg{
  height:185px!important;
}
.pdf-profile svg .grid line{
  stroke:#d7dee9!important;
}
.pdf-profile svg text{
  fill:#172033!important;
}
.q1-page footer{
  border:1px solid #cbd5e1!important;
  background:#f8fafc!important;
  color:#34465f!important;
  border-radius:7px!important;
}
.pdf-screen-page .screen-img{
  border:1.6px solid #1f4e79!important;
  background:#f8fafc!important;
}
#previewCards div span{
  line-height:1.25!important;
}
/* END HOOGTEDOCUMENT NL14 PRO V1 */

/* HOOGTEMETINGDOCUMENT PROFESSIONAL LAYOUT V1 */
.hdoc-sheet{
  width:100%;
  min-height:720px;
  color:#111827;
  background:#fff;
  font-family:Arial,Helvetica,sans-serif!important;
}
.hdoc-titlebar{
  position:relative;
  display:grid;
  grid-template-columns:300px 1fr 320px;
  align-items:center;
  gap:20px;
  min-height:78px;
  border-bottom:3px solid #17365d;
  padding:0 0 12px;
  margin-bottom:20px;
}
.hdoc-brand{display:flex;align-items:center;gap:13px;color:#17365d}
.hdoc-brand img{width:74px!important;height:54px!important;object-fit:contain!important;border-radius:0!important}
.hdoc-brand b{display:block;font-size:22px;font-weight:800;color:#111827}
.hdoc-brand span{display:block;font-size:13px;color:#17365d}
.hdoc-titlebar h1{margin:0;text-align:center;color:#0b2a5b;font-size:36px!important;line-height:1.05;font-weight:800!important;letter-spacing:-.02em}
.hdoc-subbrand{text-align:right;color:#17365d;font-size:13px}
.hdoc-stamp{justify-self:end;border:1.5px solid #d40000;color:#d40000;padding:9px 14px;font-size:13px;font-weight:800;text-align:center;white-space:nowrap}
.hdoc-layout{display:grid;grid-template-columns:330px 1fr;gap:30px;min-height:565px}
.hdoc-left{display:grid;grid-template-rows:auto auto 1fr;gap:18px}
.hdoc-block h2,.hdoc-textblock h2,.hdoc-maparea h2{margin:0 0 8px;color:#17365d;font-size:13px!important;font-weight:800!important;letter-spacing:.02em}
.hdoc-block h2{background:#17365d;color:#fff;padding:8px 9px;margin:0}
.hdoc-info,.hdoc-meetstaat table{width:100%;border-collapse:collapse;border:1px solid #9fb3cc}
.hdoc-info th,.hdoc-info td{font-size:10px!important;padding:6px 8px;border:0;text-align:left;color:#111827;line-height:1.2}
.hdoc-info th{width:118px;font-weight:800}
.hdoc-textblock p{font-size:10px!important;line-height:1.35;color:#111827;margin:0;text-align:left}
.hdoc-meetstaat table th{background:#17365d;color:#fff;font-weight:800}
.hdoc-meetstaat table td,.hdoc-meetstaat table th{border:1px solid #9fb3cc;padding:4px 5px;font-size:9px!important;color:#111827;text-align:center}
.hdoc-meetstaat table td:first-child{text-align:left}
.hdoc-note{font-size:8px!important;color:#374151;font-style:italic;margin:7px 0 0}
.hdoc-maparea{position:relative;min-width:0}
.hdoc-rd-map{position:relative;height:470px;border:1.5px solid #7488a5;background:#f8fafc;overflow:hidden}
.hdoc-rd-map .rd-overview-svg{width:100%!important;height:100%!important;border:0!important;background:#fbfdff!important}
.hdoc-rd-map svg{width:100%!important;height:100%!important}
.hdoc-rd-map .pt-name{font-size:8px!important}
.hdoc-north{position:absolute;right:18px;top:12px;text-align:center;font-weight:800;color:#111827;font-size:13px;line-height:1}
.hdoc-north span{font-size:30px}
.hdoc-scale{margin-top:10px;width:250px;border-bottom:9px solid #111;border-left:1px solid #111;border-right:1px solid #111;color:#111827;font-size:9px;padding-bottom:5px;text-align:center}
.hdoc-legend{position:absolute;right:0;top:205px;width:140px;border:1.5px solid #8aa0bd;background:#fff;padding:10px 12px}
.hdoc-legend h3,.hdoc-remarks h3{margin:0 0 8px;color:#17365d;font-size:10px!important;font-weight:800!important}
.hdoc-legend div{font-size:8.5px!important;margin:8px 0;color:#111827}
.hdoc-legend i{display:inline-block;vertical-align:middle;margin-right:8px}
.hdoc-legend .pt{width:7px;height:7px;border-radius:50%;background:#00803c;border:1px solid #005c2b}
.hdoc-legend .hline{width:20px;height:0;border-top:2px dashed #d28b35}
.hdoc-legend .dxf{width:20px;height:0;border-top:1.5px solid #6b7280}
.hdoc-legend .grid{width:14px;height:10px;border:1px solid #9fb3cc;background:#eaf2fb}
.hdoc-remarks{position:absolute;right:0;bottom:0;width:250px;border:1.5px solid #8aa0bd;background:#fff;padding:10px 12px}
.hdoc-remarks ul{margin:0;padding-left:15px}
.hdoc-remarks li{font-size:8.5px!important;line-height:1.25;color:#111827;margin:2px 0}
.hdoc-footer{display:grid;grid-template-columns:1fr 1fr 180px;gap:12px;align-items:end;border-top:3px solid #17365d;margin-top:20px;padding-top:12px;color:#111827;font-size:9px!important}
.hdoc-footer div:last-child{text-align:right;font-size:11px}
@media print{
  .hdoc-sheet{min-height:720px}
}
/* END HOOGTEMETINGDOCUMENT PROFESSIONAL LAYOUT V1 */

/* SURVEY CONTROL DOCUMENT OUTPUT STYLE V2 */
#pdfPreview .pdf-page.q1-page{
  width:1123px!important;
  min-height:794px!important;
  background:#fff!important;
  color:#111827!important;
  padding:24px 26px!important;
  overflow:hidden!important;
}
.hdoc-titlebar{
  grid-template-columns:300px 1fr 315px!important;
  min-height:70px!important;
  border-bottom:3px solid #17365d!important;
  margin-bottom:16px!important;
}
.hdoc-titlebar h1{
  font-size:37px!important;
  color:#0b2a5b!important;
}
.hdoc-stamp{
  border:1.5px solid #d40000!important;
  color:#d40000!important;
  background:#fff!important;
}
.hdoc-layout{
  grid-template-columns:330px 1fr!important;
  gap:28px!important;
}
.hdoc-rd-map{
  height:455px!important;
  background:#fbfdff!important;
}
.hdoc-info th,.hdoc-info td{font-size:9.5px!important;}
.hdoc-textblock p{font-size:9.5px!important;line-height:1.35!important;}
.hdoc-meetstaat table td,.hdoc-meetstaat table th{font-size:8.6px!important;}
.hdoc-profile-sheet .hdoc-titlebar h1{font-size:38px!important;}
.hdoc-prof-layout{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:22px;
  min-height:575px;
}
.hdoc-prof-side{
  display:grid;
  grid-template-rows:auto 1fr auto;
  gap:16px;
}
.hdoc-prof-main{
  display:grid;
  gap:10px;
  align-content:start;
}
.hdoc-prof-row{
  display:grid;
  grid-template-columns:52px minmax(0,1fr) 220px;
  gap:12px;
  align-items:stretch;
  border:1px solid #9fb3cc;
  padding:8px;
  background:#fff;
  min-height:158px;
}
.hdoc-prof-label{
  background:#0b2a5b;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  font-weight:900;
  height:42px;
}
.hdoc-prof-chart h3,.hdoc-prof-table h3{
  margin:0 0 5px;
  color:#17365d;
  font-size:11px!important;
  font-weight:800!important;
}
.hdoc-prof-chart svg{
  width:100%!important;
  height:120px!important;
  border:0!important;
  background:#fff!important;
}
.hdoc-prof-chart svg text{
  fill:#111827!important;
  font-size:8px!important;
}
.hdoc-prof-table table{
  width:100%;
  border-collapse:collapse;
  font-size:8px!important;
}
.hdoc-prof-table th{
  background:#17365d!important;
  color:#fff!important;
  font-size:8px!important;
  padding:4px!important;
}
.hdoc-prof-table td{
  border:1px solid #9fb3cc!important;
  color:#111827!important;
  padding:3px 4px!important;
  font-size:8px!important;
  text-align:center!important;
}
.hdoc-prof-remarks{
  border:1px solid #9fb3cc;
  padding:10px 12px;
  background:#fff;
}
.hdoc-prof-remarks h2{
  color:#17365d!important;
  margin:0 0 6px!important;
  font-size:10px!important;
}
.hdoc-prof-remarks ul{
  margin:0;
  padding-left:14px;
}
.hdoc-prof-remarks li{
  color:#111827;
  font-size:8.5px!important;
  line-height:1.25;
}
.hdoc-asbuilt-row svg{
  width:100%!important;
  height:160px!important;
  background:#fbfdff!important;
  border:1px solid #9fb3cc!important;
}
@media print{
  .hdoc-prof-row{break-inside:avoid!important;}
}
/* END SURVEY CONTROL DOCUMENT OUTPUT STYLE V2 */

/* FINAL PDF STYLE 1OP1 V1 */
.client-logo .client-logo-preview{min-height:62px;border:1px solid rgba(106,161,255,.25);border-radius:12px;display:flex;align-items:center;gap:10px;padding:8px;background:rgba(255,255,255,.04);margin:8px 0}
.client-logo .client-logo-preview img{max-width:110px;max-height:48px;object-fit:contain;display:none;background:#fff;border-radius:4px;padding:4px}.client-logo input{width:100%;margin-top:8px;background:#07101f;color:#e8ecf8;border:1px solid rgba(106,161,255,.3);border-radius:10px;padding:9px}
#pdfPreview .pdf-page.q1-page{width:1123px!important;min-height:794px!important;padding:0!important;background:#fff!important;color:#111827!important;border:1px solid #d8dee8!important;overflow:hidden!important;font-family:Arial,Helvetica,sans-serif!important;box-shadow:0 18px 50px rgba(0,0,0,.22)!important}
.hdoc-sheet{width:100%;height:794px;box-sizing:border-box;background:#fff;color:#111827;padding:22px 22px 20px;font-family:Arial,Helvetica,sans-serif!important;position:relative}.hdoc-titlebar{display:grid!important;grid-template-columns:300px 1fr 330px!important;align-items:start!important;gap:18px!important;height:76px!important;min-height:76px!important;border-bottom:2px solid #0b2a5b!important;padding:0 0 9px!important;margin:0 0 16px!important}.hdoc-brand{display:flex;align-items:center;gap:12px;color:#111827}.hdoc-logo-placeholder{width:58px;height:58px;position:relative;flex:0 0 58px}.hdoc-logo-placeholder:before{content:'';position:absolute;inset:8px;border:3px solid #9aa3ad;border-radius:50%}.hdoc-logo-placeholder:after{content:'';position:absolute;left:28px;top:0;width:3px;height:58px;background:#9aa3ad;box-shadow:-28px 28px 0 -1px #9aa3ad,28px 28px 0 -1px #9aa3ad}.hdoc-logo-placeholder span{position:absolute;left:0;right:0;top:28px;height:3px;background:#9aa3ad}.hdoc-client-logo-img{width:78px!important;height:58px!important;object-fit:contain!important;border:0!important;border-radius:0!important;background:#fff!important}.hdoc-brand-name{font-size:20px!important;line-height:1.08!important;font-weight:800!important;color:#111827!important;white-space:pre-line}.hdoc-titlebar h1{margin:2px 0 0!important;text-align:center!important;color:#0b2a5b!important;font-size:39px!important;line-height:1!important;font-weight:800!important;letter-spacing:-.02em!important}.hdoc-right-head{display:flex;flex-direction:column;align-items:flex-end;gap:14px}.hdoc-stamp{border:1.5px solid #ff1616!important;color:#ff1616!important;background:#fff!important;padding:10px 16px!important;font-size:13px!important;font-weight:800!important;white-space:nowrap}.hdoc-subbrand{font-size:11px!important;color:#0b2a5b!important;text-align:right!important}.hdoc-page1-layout{display:grid;grid-template-columns:330px 1fr;gap:36px;height:615px}.hdoc-leftcol{display:grid;grid-template-rows:auto auto 1fr;gap:18px}.hdoc-block{border:1px solid #8fa8c8;background:#fff}.hdoc-block h2{margin:0!important;background:#0b2a5b!important;color:#fff!important;font-size:12px!important;line-height:1!important;font-weight:800!important;padding:8px 9px!important;letter-spacing:.02em}.hdoc-info{width:100%;border-collapse:collapse}.hdoc-info th,.hdoc-info td{font-size:9.5px!important;line-height:1.25!important;padding:5.1px 8px!important;border:0!important;color:#111827!important;text-align:left}.hdoc-info th{width:118px!important;font-weight:800!important}.hdoc-textblock h2,.hdoc-mainmap h2{margin:0 0 10px!important;color:#0b2a5b!important;font-size:13px!important;font-weight:800!important}.hdoc-textblock p{margin:0;color:#111827!important;font-size:9.7px!important;line-height:1.43!important}.hdoc-meetstaat table{width:100%;border-collapse:collapse}.hdoc-meetstaat table th{background:#0b2a5b!important;color:#fff!important;font-size:8.4px!important;font-weight:800!important;padding:4px 5px!important;border:1px solid #8fa8c8!important}.hdoc-meetstaat table td{font-size:8.4px!important;padding:3.8px 5px!important;border:1px solid #a9b9cf!important;color:#111827!important;text-align:center!important}.hdoc-note{margin:7px 0 0!important;font-size:7.6px!important;color:#374151!important;font-style:italic!important}.hdoc-mainmap{position:relative;min-width:0}.hdoc-map-shell{width:100%;height:505px;position:relative}.hdoc-map-svg{width:100%;height:100%;display:block}.hdoc-map-svg .coord-label{font-size:10px;fill:#111827}.hdoc-map-svg .gridline{stroke:#dce3eb;stroke-width:.9;stroke-dasharray:2 2}.hdoc-map-svg .survey-point{fill:#00803c;stroke:#005c2b;stroke-width:.9}.hdoc-map-svg .point-label{font-size:9px;fill:#111827;font-weight:700}.hdoc-map-svg .height-label{font-size:8px;fill:#f07a24}.hdoc-map-svg .north text{font-size:13px;font-weight:800;fill:#111827}.hdoc-map-svg .scale text{font-size:9px;fill:#111827}.hdoc-legend{position:absolute;right:0;top:205px;width:137px;border:1px solid #8fa8c8;background:#fff;padding:10px 12px;box-sizing:border-box}.hdoc-legend h3,.hdoc-remarks h3{margin:0 0 8px!important;color:#0b2a5b!important;font-size:10px!important;font-weight:800!important}.hdoc-legend div{font-size:8px!important;color:#111827;margin:8px 0;display:flex;align-items:center;gap:8px}.hdoc-legend i{display:inline-block;flex:0 0 auto}.hdoc-legend .pt{width:7px;height:7px;border-radius:50%;background:#00803c}.hdoc-legend .hline{width:19px;border-top:2px dashed #f07a24}.hdoc-legend .dxf{width:19px;border-top:1.5px solid #6b7280}.hdoc-legend .boundary{width:19px;border-top:1.5px dashed #111827}.hdoc-legend .box{width:14px;height:10px;background:#e5e7eb;border:1px solid #9ca3af}.hdoc-legend .water{width:14px;height:10px;background:#dcefff;border:1px solid #9ecae8}.hdoc-remarks{position:absolute;right:0;bottom:0;width:250px;border:1px solid #8fa8c8;background:#fff;padding:10px 12px;box-sizing:border-box}.hdoc-remarks ul{margin:0;padding-left:13px}.hdoc-remarks li{font-size:8px!important;line-height:1.28;color:#111827!important;margin:2px 0}.hdoc-footer{position:absolute;left:22px;right:22px;bottom:18px;border-top:2px solid #0b2a5b!important;padding-top:10px;display:grid!important;grid-template-columns:1fr 1.2fr 150px!important;gap:14px;align-items:end;color:#111827!important;font-size:8.7px!important}.hdoc-footer div:first-child b{color:#0b2a5b}.hdoc-footer div:last-child{text-align:right;font-size:11px!important}.hdoc-footer b{font-weight:800}.hdoc-profile-sheet{height:794px}.hdoc-prof-layout{display:grid!important;grid-template-columns:285px 1fr!important;gap:18px!important;height:615px}.hdoc-prof-side{display:grid;grid-template-rows:auto 1fr auto;gap:18px}.hdoc-prof-main{display:grid;grid-template-rows:1fr 1fr 1fr;gap:11px}.hdoc-prof-row{display:grid!important;grid-template-columns:54px minmax(0,1fr) 220px!important;gap:10px!important;align-items:start!important;border:1px solid #8fa8c8!important;background:#fff!important;padding:8px!important;min-height:0!important}.hdoc-prof-label{background:#0b2a5b!important;color:#fff!important;font-size:25px!important;font-weight:900!important;width:42px!important;height:38px!important;display:flex!important;align-items:center!important;justify-content:center!important}.hdoc-prof-chart h3,.hdoc-prof-table h3{margin:0 0 5px!important;color:#0b2a5b!important;font-size:10.5px!important;font-weight:800!important}.hdoc-profile-svg{width:100%!important;height:128px!important}.hdoc-profile-svg .prof-grid{stroke:#d4dbe5;stroke-width:.8;stroke-dasharray:2 2}.hdoc-profile-svg text{fill:#111827;font-size:8px}.hdoc-profile-svg .prof-val{font-weight:700}.hdoc-profile-svg .axis-label{font-size:8px;fill:#111827}.hdoc-profile-svg .slope-label{font-size:9px;fill:#f05a24;font-weight:700}.hdoc-profile-svg .dh-label{font-size:8px;fill:#174ea6;font-weight:700}.hdoc-prof-table table{width:100%;border-collapse:collapse}.hdoc-prof-table th{background:#0b2a5b!important;color:#fff!important;font-size:8px!important;padding:4px!important;border:1px solid #8fa8c8!important}.hdoc-prof-table td{font-size:8px!important;color:#111827!important;padding:3.5px 4px!important;border:1px solid #a9b9cf!important;text-align:center!important}.hdoc-prof-remarks{border:1px solid #8fa8c8;padding:10px 12px;background:#fff}.hdoc-prof-remarks h2{margin:0 0 7px!important;color:#0b2a5b!important;font-size:10px!important;font-weight:800!important}.hdoc-prof-remarks ul{margin:0;padding-left:13px}.hdoc-prof-remarks li{font-size:8px!important;line-height:1.28;color:#111827!important}.pdf-screen-page .q1-head{padding:22px 26px 10px!important}.pdf-screen-page .pdf-sub{padding:0 26px!important}.pdf-screen-page .pdf-screen-frame{margin:0 26px!important}.pdf-screen-page footer{margin:12px 26px 0!important}.pdf-rd-frame .rd-overview-svg{background:#fff!important}.hdoc-map-empty{height:100%;display:grid;place-items:center;text-align:center;border:1px solid #8fa8c8;color:#111827;background:#fbfdff;font-weight:700}
@media print{#pdfPreview .pdf-page.q1-page{box-shadow:none!important;border:0!important;break-after:page!important}.hdoc-sheet{height:794px!important}.pdf-screen-page{padding:0!important}}
/* END FINAL PDF STYLE 1OP1 V1 */

/* PDF SITE UPDATE FINAL - DOCUMENTSTIJL EN VOLGORDE */
#pdfPreview .pdf-viewer-first-page .pdf-map-frame{
  height:620px!important;
  border:1.8px solid #0b2a5b!important;
  background:#fff!important;
  margin-top:10px!important;
}
#pdfPreview .pdf-viewer-first-page .pdf-map-live{
  height:100%!important;
  width:100%!important;
  background:#fff!important;
}
#pdfPreview .pdf-viewer-first-page .pdf-sub{
  font-size:12px!important;
  color:#0b2a5b!important;
  margin:8px 0 8px!important;
}
#pdfPreview .pdf-screen-page .pdf-screen-frame{
  height:620px!important;
  border:1.8px solid #0b2a5b!important;
  background:#fff!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
}
#pdfPreview .pdf-screen-page .pdf-screen-frame img{
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  display:block!important;
}
#pdfPreview .hdoc-designed-summary-page,
#pdfPreview .hdoc-designed-profile-page{
  background:#fff!important;
}
.hdoc-sheet{
  background:#fff!important;
  color:#111827!important;
  padding:22px 22px 20px!important;
  box-sizing:border-box!important;
  font-family:Arial,Helvetica,sans-serif!important;
  position:relative!important;
}
.hdoc-titlebar{
  display:grid!important;
  grid-template-columns:300px 1fr 330px!important;
  align-items:start!important;
  gap:18px!important;
  height:76px!important;
  border-bottom:2px solid #0b2a5b!important;
  padding:0 0 9px!important;
  margin:0 0 17px!important;
}
.hdoc-titlebar h1{
  font-size:38px!important;
  line-height:1!important;
  color:#0b2a5b!important;
  font-weight:800!important;
  text-align:center!important;
  margin:2px 0 0!important;
  letter-spacing:-.02em!important;
}
.hdoc-brand{
  display:flex!important;
  align-items:center!important;
  gap:14px!important;
  color:#111827!important;
}
.hdoc-logo-placeholder{
  width:64px!important;
  height:64px!important;
  position:relative!important;
  border:0!important;
  background:#fff!important;
  flex:0 0 auto!important;
}
.hdoc-logo-placeholder:before{
  content:""!important;
  position:absolute!important;
  left:11px!important;
  top:11px!important;
  width:42px!important;
  height:42px!important;
  border:4px solid #0b2a5b!important;
  border-radius:50%!important;
  box-shadow:inset 0 0 0 10px #fff!important;
}
.hdoc-logo-placeholder:after{
  content:""!important;
  position:absolute!important;
  left:30px!important;
  top:0!important;
  width:4px!important;
  height:64px!important;
  background:#0b2a5b!important;
  box-shadow:-30px 30px 0 -1px #0b2a5b,30px 30px 0 -1px #0b2a5b!important;
}
.hdoc-brand-name{
  font-size:20px!important;
  line-height:1.08!important;
  font-weight:800!important;
  color:#111827!important;
  white-space:pre-line!important;
}
.hdoc-client-logo-img{
  width:82px!important;
  height:58px!important;
  object-fit:contain!important;
  background:#fff!important;
  border:0!important;
  border-radius:0!important;
}
.hdoc-right-head{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-end!important;
  gap:13px!important;
}
.hdoc-stamp{
  border:1.5px solid #ff1616!important;
  color:#ff1616!important;
  background:#fff!important;
  padding:10px 16px!important;
  font-size:13px!important;
  font-weight:800!important;
  white-space:nowrap!important;
}
.hdoc-subbrand{
  font-size:11px!important;
  color:#0b2a5b!important;
  text-align:right!important;
}
.hdoc-page1-layout{
  display:grid!important;
  grid-template-columns:330px 1fr!important;
  gap:34px!important;
  height:615px!important;
}
.hdoc-leftcol{
  display:grid!important;
  grid-template-rows:auto auto 1fr!important;
  gap:17px!important;
}
.hdoc-block{
  border:1px solid #8fa8c8!important;
  background:#fff!important;
}
.hdoc-block h2{
  margin:0!important;
  background:#0b2a5b!important;
  color:#fff!important;
  font-size:12px!important;
  line-height:1!important;
  font-weight:800!important;
  padding:8px 9px!important;
  letter-spacing:.02em!important;
}
.hdoc-info{
  width:100%!important;
  border-collapse:collapse!important;
}
.hdoc-info th,.hdoc-info td{
  font-size:9.5px!important;
  line-height:1.25!important;
  padding:5.1px 8px!important;
  border:0!important;
  color:#111827!important;
  text-align:left!important;
}
.hdoc-info th{
  width:118px!important;
  font-weight:800!important;
}
.hdoc-textblock h2,.hdoc-mainmap h2{
  margin:0 0 10px!important;
  color:#0b2a5b!important;
  font-size:13px!important;
  font-weight:800!important;
}
.hdoc-textblock p{
  margin:0!important;
  color:#111827!important;
  font-size:9.7px!important;
  line-height:1.43!important;
}
.hdoc-meetstaat table{
  width:100%!important;
  border-collapse:collapse!important;
}
.hdoc-meetstaat table th{
  background:#0b2a5b!important;
  color:#fff!important;
  font-size:8.4px!important;
  font-weight:800!important;
  padding:4px 5px!important;
  border:1px solid #8fa8c8!important;
}
.hdoc-meetstaat table td{
  font-size:8.4px!important;
  padding:3.8px 5px!important;
  border:1px solid #a9b9cf!important;
  color:#111827!important;
  text-align:center!important;
}
.hdoc-note{
  margin:7px 0 0!important;
  font-size:7.6px!important;
  color:#374151!important;
  font-style:italic!important;
}
.hdoc-mainmap{
  position:relative!important;
  min-width:0!important;
}
.hdoc-map-shell{
  width:100%!important;
  height:505px!important;
  position:relative!important;
}
.hdoc-map-svg{
  width:100%!important;
  height:100%!important;
  display:block!important;
  background:#fff!important;
}
.hdoc-map-svg .coord-label{
  font-size:9.4px!important;
  fill:#111827!important;
}
.hdoc-map-svg .coord-label.small{
  font-size:8px!important;
}
.hdoc-map-svg .gridline{
  stroke:#dce3eb!important;
  stroke-width:.8!important;
  stroke-dasharray:2 2!important;
}
.hdoc-map-svg .survey-point{
  fill:#00803c!important;
  stroke:#005c2b!important;
  stroke-width:.9!important;
}
.hdoc-map-svg .point-label{
  font-size:8.6px!important;
  fill:#111827!important;
  font-weight:700!important;
}
.hdoc-map-svg .height-label{
  font-size:8px!important;
  fill:#f07a24!important;
}
.hdoc-map-svg .profile-name{
  font-weight:800!important;
}
.hdoc-map-svg .north text{
  font-size:13px!important;
  font-weight:800!important;
  fill:#111827!important;
}
.hdoc-map-svg .scale text{
  font-size:8.5px!important;
  fill:#111827!important;
}
.hdoc-legend{
  position:absolute!important;
  right:0!important;
  top:205px!important;
  width:137px!important;
  border:1px solid #8fa8c8!important;
  background:#fff!important;
  padding:10px 12px!important;
  box-sizing:border-box!important;
}
.hdoc-legend h3,.hdoc-remarks h3{
  margin:0 0 8px!important;
  color:#0b2a5b!important;
  font-size:10px!important;
  font-weight:800!important;
}
.hdoc-legend div{
  font-size:8px!important;
  color:#111827!important;
  margin:8px 0!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
}
.hdoc-remarks{
  position:absolute!important;
  right:0!important;
  bottom:0!important;
  width:250px!important;
  border:1px solid #8fa8c8!important;
  background:#fff!important;
  padding:10px 12px!important;
  box-sizing:border-box!important;
}
.hdoc-remarks ul{
  margin:0!important;
  padding-left:13px!important;
}
.hdoc-remarks li{
  font-size:8px!important;
  line-height:1.28!important;
  color:#111827!important;
  margin:2px 0!important;
}
.hdoc-footer{
  position:absolute!important;
  left:22px!important;
  right:22px!important;
  bottom:18px!important;
  border-top:2px solid #0b2a5b!important;
  padding-top:10px!important;
  display:grid!important;
  grid-template-columns:1fr 1.2fr 150px!important;
  gap:14px!important;
  align-items:end!important;
  color:#111827!important;
  font-size:8.7px!important;
}
.hdoc-footer div:first-child b{
  color:#0b2a5b!important;
}
.hdoc-footer div:last-child{
  text-align:right!important;
  font-size:11px!important;
}
.hdoc-profile-sheet{
  height:794px!important;
}
.hdoc-prof-layout{
  display:grid!important;
  grid-template-columns:285px 1fr!important;
  gap:18px!important;
  height:615px!important;
}
.hdoc-prof-side{
  display:grid!important;
  grid-template-rows:auto 1fr auto!important;
  gap:18px!important;
}
.hdoc-prof-main{
  display:grid!important;
  grid-template-rows:1fr 1fr 1fr!important;
  gap:11px!important;
}
.hdoc-prof-row{
  display:grid!important;
  grid-template-columns:54px minmax(0,1fr) 220px!important;
  gap:10px!important;
  align-items:start!important;
  border:1px solid #8fa8c8!important;
  background:#fff!important;
  padding:8px!important;
  min-height:0!important;
}
.hdoc-prof-label{
  background:#0b2a5b!important;
  color:#fff!important;
  font-size:25px!important;
  font-weight:900!important;
  width:42px!important;
  height:38px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.hdoc-prof-chart h3,.hdoc-prof-table h3{
  margin:0 0 5px!important;
  color:#0b2a5b!important;
  font-size:10.5px!important;
  font-weight:800!important;
}
.hdoc-prof-chart svg{
  width:100%!important;
  height:124px!important;
  background:#fff!important;
  border:0!important;
}
.hdoc-prof-chart svg text{
  font-size:7.8px!important;
  fill:#111827!important;
}
.hdoc-prof-table table{
  width:100%!important;
  border-collapse:collapse!important;
}
.hdoc-prof-table th{
  background:#0b2a5b!important;
  color:#fff!important;
  font-size:8px!important;
  padding:4px!important;
  border:1px solid #8fa8c8!important;
}
.hdoc-prof-table td{
  border:1px solid #a9b9cf!important;
  color:#111827!important;
  padding:3px 4px!important;
  font-size:8px!important;
  text-align:center!important;
}
.hdoc-prof-remarks{
  border:1px solid #8fa8c8!important;
  background:#fff!important;
  padding:10px 12px!important;
}
.hdoc-prof-remarks h2{
  color:#0b2a5b!important;
  font-size:10px!important;
  margin:0 0 7px!important;
}
.hdoc-prof-remarks ul{
  margin:0!important;
  padding-left:13px!important;
}
.hdoc-prof-remarks li{
  font-size:8px!important;
  line-height:1.28!important;
  color:#111827!important;
  margin:2px 0!important;
}
/* END PDF SITE UPDATE FINAL */

/* H6 PROFILE AND MAP LAYER FIX */
.hdoc-prof-row{
  min-height:184px!important;
  grid-template-columns:54px minmax(0,1fr) 218px!important;
}
.hdoc-prof-chart svg.hdoc-profile-svg{
  width:100%!important;
  height:150px!important;
  overflow:visible!important;
}
.hdoc-profile-svg .prof-grid{
  stroke:#dbe3ec!important;
  stroke-width:.8!important;
  stroke-dasharray:2 2!important;
}
.hdoc-profile-svg .prof-axis,
.hdoc-profile-svg .axis-label{
  fill:#111827!important;
  font-size:8px!important;
  font-weight:500!important;
}
.hdoc-profile-svg .prof-axis-line{
  stroke:#111827!important;
  stroke-width:1!important;
}
.hdoc-profile-svg .profile-dot{
  fill:#174ea6!important;
  stroke:#fff!important;
  stroke-width:1.1!important;
}
.hdoc-profile-svg .profile-value-label rect,
.hdoc-profile-svg .slope-clean-label rect,
.hdoc-profile-svg .dh-clean-label rect{
  fill:#fff!important;
  stroke:#c8d5e4!important;
  stroke-width:.6!important;
  opacity:.96!important;
}
.hdoc-profile-svg .profile-value-label text{
  fill:#111827!important;
  font-size:7.6px!important;
  font-weight:700!important;
}
.hdoc-profile-svg .slope-clean-label text{
  fill:#f07a24!important;
  font-size:8px!important;
  font-weight:800!important;
}
.hdoc-profile-svg .dh-clean-label text{
  fill:#174ea6!important;
  font-size:8px!important;
  font-weight:800!important;
}
.toggle button[data-base="light"],
.toggle button[data-base="topo"]{
  border-color:rgba(106,161,255,.45)!important;
}
.leaflet-tile-pane,
.leaflet-tile,
.leaflet-layer img{
  image-rendering:auto!important;
  filter:none!important;
  opacity:1!important;
}
/* END H6 PROFILE AND MAP LAYER FIX */

/* PROJECT UPLOAD GUARD AND EMPTY MAP FIX */
#map.basemap-visible .leaflet-tile-pane,
#map:not(.dxf-only) .leaflet-tile-pane{
  opacity:1!important;
  filter:none!important;
  display:block!important;
  z-index:200!important;
}
#map.basemap-visible .leaflet-tile,
#map:not(.dxf-only) .leaflet-tile{
  opacity:1!important;
  filter:none!important;
}
#map.basemap-visible{
  background:#eef3f7!important;
}
#map.basemap-visible::before,
#map.basemap-visible::after{
  display:none!important;
}
#map.basemap-visible .grid-layer,
#map.basemap-visible .dxf-grid,
#map.basemap-visible .rd-grid-bg{
  opacity:0!important;
  pointer-events:none!important;
}
.upload-warning-install{
  border:1px solid rgba(255,209,102,.8)!important;
  background:rgba(255,209,102,.12)!important;
  color:#FFD166!important;
}
/* END PROJECT UPLOAD GUARD AND EMPTY MAP FIX */

/* BASEMAP HARD FIX CSS */
#map.sc-basemap-hardfix,
#map.basemap-visible{
  background:#eef3f7!important;
}
#map.sc-basemap-hardfix:not(.dxf-only)::before,
#map.sc-basemap-hardfix:not(.dxf-only)::after,
#map.basemap-visible:not(.dxf-only)::before,
#map.basemap-visible:not(.dxf-only)::after{
  display:none!important;
  opacity:0!important;
  content:none!important;
}
#map.sc-basemap-hardfix .leaflet-map-pane,
#map.basemap-visible .leaflet-map-pane{
  z-index:1!important;
}
#map.sc-basemap-hardfix .leaflet-tile-pane,
#map.basemap-visible .leaflet-tile-pane,
#map:not(.dxf-only) .leaflet-tile-pane{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  filter:none!important;
  z-index:200!important;
}
#map.sc-basemap-hardfix .leaflet-tile,
#map.basemap-visible .leaflet-tile,
#map:not(.dxf-only) .leaflet-tile{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  filter:none!important;
  image-rendering:auto!important;
}
#map.sc-basemap-hardfix:not(.dxf-only) .dxf-grid,
#map.sc-basemap-hardfix:not(.dxf-only) .rd-grid-bg,
#map.sc-basemap-hardfix:not(.dxf-only) .grid-layer{
  display:none!important;
  opacity:0!important;
}
.toggle button[data-base="terrain"]{
  border-color:rgba(255,209,102,.55)!important;
}
.toggle button[data-base="terrain"].active{
  color:#FFD166!important;
}
/* END BASEMAP HARD FIX CSS */

/* KAARTLAGEN ECHTE FIX CSS */
#map.basemap-visible{
  background:#eef3f7!important;
}
#map.basemap-visible:not(.dxf-only)::before,
#map.basemap-visible:not(.dxf-only)::after{
  display:none!important;
  opacity:0!important;
  content:none!important;
}
#map.basemap-visible:not(.dxf-only) .leaflet-tile-pane,
#map:not(.dxf-only) .leaflet-tile-pane{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  filter:none!important;
  z-index:200!important;
}
#map.basemap-visible:not(.dxf-only) .leaflet-tile,
#map:not(.dxf-only) .leaflet-tile{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  filter:none!important;
  image-rendering:auto!important;
}
#map:not(.dxf-only) .dxf-grid,
#map:not(.dxf-only) .rd-grid-bg,
#map:not(.dxf-only) .grid-layer{
  display:none!important;
  opacity:0!important;
}
.toggle button[data-base="terrain"]{
  border-color:rgba(255,209,102,.55)!important;
}
.toggle button[data-base="terrain"].active{
  color:#FFD166!important;
}
/* END KAARTLAGEN ECHTE FIX CSS */

/* ALLE KAARTLAGEN DEFINITIEF */
#map.basemap-visible{
  background:#eef3f7!important;
}
#map.basemap-visible:not(.dxf-only)::before,
#map.basemap-visible:not(.dxf-only)::after{
  display:none!important;
  opacity:0!important;
  content:none!important;
}
#map.basemap-visible:not(.dxf-only) .leaflet-tile-pane,
#map:not(.dxf-only) .leaflet-tile-pane{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  filter:none!important;
  z-index:200!important;
}
#map.basemap-visible:not(.dxf-only) .leaflet-tile,
#map:not(.dxf-only) .leaflet-tile{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  filter:none!important;
  image-rendering:auto!important;
}
#map:not(.dxf-only) .dxf-grid,
#map:not(.dxf-only) .rd-grid-bg,
#map:not(.dxf-only) .grid-layer{
  display:none!important;
  opacity:0!important;
}
.toggle button[data-base]{
  padding-left:12px!important;
  padding-right:12px!important;
}
.toggle button[data-base="dxf"]{
  border-color:rgba(66,211,146,.7)!important;
}
.toggle button[data-base="luchtfoto"],
.toggle button[data-base="bgt"],
.toggle button[data-base="ahn"],
.toggle button[data-base="terrain"]{
  border-color:rgba(255,209,102,.55)!important;
}
.toggle button[data-base="luchtfoto"].active,
.toggle button[data-base="bgt"].active,
.toggle button[data-base="ahn"].active,
.toggle button[data-base="terrain"].active{
  color:#FFD166!important;
}
/* END ALLE KAARTLAGEN DEFINITIEF */


/* VIEWER BOVEN BREED LAYOUT V1 */
/* Nieuwe werkmachine-indeling:
   - Viewer volledig bovenaan over de breedte.
   - Upload, Projectgegevens en Preview/export daaronder naast elkaar.
   - Meer kaart/viewerruimte, minder geprop aan de rechterkant.
*/
.workgrid{
  width:100%!important;
  max-width:100vw!important;
  margin:0 auto!important;
  padding:12px 16px 18px!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr)!important;
  grid-template-areas:
    "viewer viewer viewer"
    "upload project preview"
    "profiles profiles profiles"
    "bar bar bar"
    "rules rules rules"!important;
  gap:14px!important;
  align-items:start!important;
  overflow:visible!important;
}
.viewer-panel{
  grid-area:viewer!important;
  height:clamp(620px,64vh,820px)!important;
  display:grid!important;
  grid-template-rows:auto minmax(520px,1fr)!important;
  overflow:hidden!important;
}
.viewer-map{
  min-height:520px!important;
}
.viewer-bar{
  min-height:56px!important;
  height:auto!important;
  flex-wrap:wrap!important;
  align-items:center!important;
  gap:8px!important;
  overflow:visible!important;
  white-space:normal!important;
}
.viewer-bar .toggle{
  flex-wrap:wrap!important;
  gap:6px!important;
}
.viewer-bar .toggle button{
  border-right:1px solid var(--line2)!important;
  border-radius:10px!important;
  margin:0!important;
  padding:9px 13px!important;
}
.viewer-bar span,
.viewer-bar>button{
  flex:0 0 auto!important;
}
.upload-panel{
  grid-area:upload!important;
  min-height:360px!important;
}
.project-panel{
  grid-area:project!important;
  min-height:360px!important;
}
.preview-panel{
  grid-area:preview!important;
  min-height:360px!important;
}
.upload-panel.compact,
.project-panel.compact,
.preview-panel.compact{
  padding:16px!important;
}
.layer-panel{
  max-height:250px!important;
  overflow:auto!important;
}
.fields{
  display:grid!important;
  gap:10px!important;
}
.preview-cards{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}
.actions,
.bottom-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:10px!important;
}
.actions button,
.bottom-actions button{
  flex:1 1 160px!important;
}
.profiles-panel{
  grid-area:profiles!important;
}
.bottom-bar{
  grid-area:bar!important;
}
.rules{
  grid-area:rules!important;
}

/* Grote monitoren: iets meer hoogte voor de viewer. */
@media (min-width:1500px){
  .viewer-panel{
    height:clamp(680px,68vh,900px)!important;
    grid-template-rows:auto minmax(600px,1fr)!important;
  }
  .viewer-map{
    min-height:600px!important;
  }
}

/* Middenformaat: viewer boven, onderblokken nog steeds netjes. */
@media (max-width:1200px){
  .workgrid{
    grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
    grid-template-areas:
      "viewer viewer"
      "upload project"
      "preview preview"
      "profiles profiles"
      "bar bar"
      "rules rules"!important;
  }
  .viewer-panel{
    height:620px!important;
  }
}

/* Mobiel/tablet: alles onder elkaar, viewer nog bruikbaar. */
@media (max-width:820px){
  .workgrid{
    padding:10px!important;
    grid-template-columns:1fr!important;
    grid-template-areas:
      "viewer"
      "upload"
      "project"
      "preview"
      "profiles"
      "bar"
      "rules"!important;
  }
  .viewer-panel{
    height:560px!important;
    grid-template-rows:auto minmax(430px,1fr)!important;
  }
  .viewer-map{
    min-height:430px!important;
  }
}
/* END VIEWER BOVEN BREED LAYOUT V1 */


/* BGT AHN OVERLAY UPDATE */
.toggle button[data-overlay]{
  border-color:rgba(255,209,102,.65)!important;
  background:rgba(255,209,102,.08)!important;
  color:#E8ECF8!important;
}
.toggle button[data-overlay].active{
  background:linear-gradient(180deg,rgba(255,209,102,.34),rgba(255,209,102,.14))!important;
  color:#FFD166!important;
  box-shadow:0 0 0 1px rgba(255,209,102,.55),0 0 18px rgba(255,209,102,.16)!important;
}
.toggle button[data-overlay="bgt"].active::after,
.toggle button[data-overlay="ahn"].active::after{
  content:" AAN";
  color:#42D392;
  font-weight:900;
  font-size:.82em;
}
#map:not(.dxf-only) .leaflet-overlay-pane,
#map:not(.dxf-only) .leaflet-tile-pane{
  visibility:visible!important;
}
/* END BGT AHN OVERLAY UPDATE */

/* DOCUMENT OPMERKINGEN EN SCHAAL FIX */
.hdoc-map-shell{
  height:535px!important;
}
.hdoc-map-svg .scale text{
  font-size:8.3px!important;
  fill:#111827!important;
}
.hdoc-map-svg .coord-label.small{
  font-size:7.7px!important;
}
.hdoc-legend{
  top:178px!important;
}
.hdoc-remarks{
  bottom:18px!important;
}
.hdoc-profile-note{
  margin-top:4px!important;
  padding:3px 6px!important;
  border:1px solid #d7e1ee!important;
  background:#f8fbff!important;
  color:#111827!important;
  font-size:7.4px!important;
  line-height:1.22!important;
  border-radius:3px!important;
}
.hdoc-prof-remarks li{
  font-size:7.7px!important;
}
/* END DOCUMENT OPMERKINGEN EN SCHAAL FIX */

/* PDF PROFIELKLEUREN H1-H6 */
.hdoc-prof-row{
  border-left:6px solid var(--prof-color,#0b2a5b)!important;
}
.hdoc-prof-label{
  background:var(--prof-color,#0b2a5b)!important;
  color:var(--prof-text,#fff)!important;
}
.hdoc-prof-dot{
  display:inline-block!important;
  width:9px!important;
  height:9px!important;
  border-radius:50%!important;
  margin-right:6px!important;
  vertical-align:middle!important;
  box-shadow:0 0 0 1px rgba(0,0,0,.18)!important;
}
.hdoc-prof-table thead tr th{
  background:var(--prof-color,#0b2a5b)!important;
  color:var(--prof-text,#fff)!important;
}
.hdoc-profile-note{
  border-left:4px solid var(--prof-color,#0b2a5b)!important;
}
.colored-profile-svg .profile-line{
  stroke:var(--prof-color,#0b2a5b)!important;
}
.colored-profile-svg .profile-points circle,
.colored-profile-svg g.profile-points{
  fill:var(--prof-color,#0b2a5b)!important;
}
.hdoc-map-svg .profile-name{
  font-weight:900!important;
}
/* END PDF PROFIELKLEUREN H1-H6 */

/* SLIMME VIEWER LABELS */
.pt-label.pt-code-label{
  pointer-events:none!important;
  max-width:130px!important;
  white-space:normal!important;
  line-height:1.08!important;
}
.pt-label.pt-label-smart{
  background:rgba(1,8,18,.68)!important;
  border:1px solid rgba(0,245,159,.38)!important;
  color:#f4fbff!important;
  font-size:10px!important;
  font-weight:760!important;
  border-radius:6px!important;
  padding:4px 6px!important;
  box-shadow:0 4px 10px rgba(0,0,0,.24)!important;
  backdrop-filter:blur(2px)!important;
}
.pt-label.pt-label-smart small{
  display:block!important;
  margin-top:1px!important;
  color:#cfe9ff!important;
  font-size:8.2px!important;
  font-weight:700!important;
}
.pt-label.pt-label-smart em{
  display:none!important;
}
.pt-label.pt-label-hover{
  background:rgba(1,8,18,.94)!important;
  border:1px solid rgba(0,245,159,.72)!important;
  color:#ffffff!important;
  font-size:11px!important;
  font-weight:800!important;
  border-radius:7px!important;
  padding:6px 8px!important;
  box-shadow:0 8px 18px rgba(0,0,0,.36)!important;
}
.pt-label.pt-label-hover small,
.pt-label.pt-label-hover em{
  display:block!important;
  margin-top:2px!important;
  color:#bfeaff!important;
  font-size:9px!important;
  font-style:normal!important;
}
.h-map-badge.h-map-badge-smart span{
  background:rgba(8,18,34,.70)!important;
  border:1px solid var(--h,#6AA1FF)!important;
  color:#fff!important;
  border-radius:999px!important;
  padding:4px 8px!important;
  box-shadow:0 4px 12px rgba(0,0,0,.24)!important;
  backdrop-filter:blur(2px)!important;
  font-size:10px!important;
}
.h-map-badge.h-map-badge-smart small{
  display:none!important;
}
/* Bij printscreen blijft de viewer leesbaar: labels niet als zwarte muur. */
.leaflet-tooltip.pt-label-smart{
  opacity:.82!important;
}
/* END SLIMME VIEWER LABELS */


/* STICKY KNOPPEN EN PDF MODAL FIX */
/* Viewer-knoppen: altijd boven de kaart en klikbaar. */
.viewer-panel{
  position:relative!important;
  overflow:hidden!important;
}
.viewer-bar{
  position:sticky!important;
  top:0!important;
  z-index:5000!important;
  background:linear-gradient(180deg,rgba(8,18,34,.98),rgba(8,18,34,.94))!important;
  border-bottom:1px solid rgba(106,161,255,.34)!important;
  box-shadow:0 8px 22px rgba(0,0,0,.26)!important;
  pointer-events:auto!important;
}
.viewer-bar,
.viewer-bar *{
  pointer-events:auto!important;
}
.viewer-bar .toggle{
  display:flex!important;
  flex-wrap:nowrap!important;
  gap:7px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  max-width:100%!important;
  scrollbar-width:thin!important;
  -webkit-overflow-scrolling:touch!important;
  padding-bottom:2px!important;
}
.viewer-bar .toggle::-webkit-scrollbar{
  height:7px!important;
}
.viewer-bar .toggle::-webkit-scrollbar-thumb{
  background:rgba(106,161,255,.45)!important;
  border-radius:999px!important;
}
.viewer-bar .toggle button,
.viewer-bar > button,
.viewer-bar .chip,
.viewer-bar span{
  position:relative!important;
  z-index:5010!important;
  flex:0 0 auto!important;
  white-space:nowrap!important;
}
.viewer-map,
#map{
  position:relative!important;
  z-index:1!important;
}
#map .leaflet-pane,
#map .leaflet-control-container{
  z-index:auto!important;
}
#map .leaflet-top,
#map .leaflet-bottom{
  z-index:900!important;
}

/* Fullscreen: toolbar blijft bovenin en kaart start eronder. */
.viewer-panel:fullscreen,
.viewer-panel:-webkit-full-screen{
  background:#07101f!important;
  display:grid!important;
  grid-template-rows:auto minmax(0,1fr)!important;
}
.viewer-panel:fullscreen .viewer-bar,
.viewer-panel:-webkit-full-screen .viewer-bar{
  position:sticky!important;
  top:0!important;
  z-index:8000!important;
  background:linear-gradient(180deg,rgba(7,16,31,.99),rgba(7,16,31,.96))!important;
}
.viewer-panel:fullscreen .viewer-map,
.viewer-panel:-webkit-full-screen .viewer-map{
  min-height:0!important;
  height:100%!important;
}

/* Rechter zwevende viewerknoppen mogen nooit over toolbar heen vallen. */
.viewer-tools,
.map-tools,
.viewer-side-buttons{
  z-index:3000!important;
}

/* PDF-preview modal: knoppen blijven boven de PDF en klikbaar. */
#pdfDialog{
  overflow:hidden!important;
}
#pdfDialog::backdrop{
  background:rgba(0,0,0,.62)!important;
}
#pdfDialog .modal-head,
#pdfDialog .pdf-head,
#pdfDialog header,
.pdf-preview-head{
  position:sticky!important;
  top:0!important;
  z-index:10000!important;
  background:#07101f!important;
  border-bottom:1px solid rgba(232,236,248,.18)!important;
  box-shadow:0 8px 22px rgba(0,0,0,.34)!important;
  pointer-events:auto!important;
}
#pdfDialog .modal-head *,
#pdfDialog .pdf-head *,
#pdfDialog header *,
.pdf-preview-head *{
  pointer-events:auto!important;
}
#pdfDialog button,
#pdfDialog .btn,
#pdfDialog a{
  position:relative!important;
  z-index:10020!important;
  pointer-events:auto!important;
}
#pdfPreview{
  position:relative!important;
  z-index:1!important;
  pointer-events:auto!important;
}
#pdfPreview .pdf-page{
  position:relative!important;
  z-index:1!important;
}
#pdfPreview .pdf-page *,
#pdfPreview iframe,
#pdfPreview canvas,
#pdfPreview img{
  max-width:100%!important;
}
#pdfDialog .modal-body,
#pdfDialog .pdf-body,
#pdfDialog .preview-body{
  position:relative!important;
  z-index:1!important;
  overflow:auto!important;
}

/* Veiligheidsregel: documentlagen mogen nooit boven modalheader liggen. */
#pdfPreview,
#pdfPreview *,
.pdf-page,
.pdf-page *{
  z-index:auto;
}
/* END STICKY KNOPPEN EN PDF MODAL FIX */


/* LAGEN PUNTEN HPROFIELEN STABIEL */
/* Kaartlagen nooit meer boven meetdata. */
#map .leaflet-pane.leaflet-baseTilePane-pane{
  z-index:180!important;
}
#map .leaflet-pane.leaflet-controlTilePane-pane{
  z-index:260!important;
  opacity:.96!important;
}
#map .leaflet-pane.leaflet-surveyLinePane-pane{
  z-index:520!important;
  pointer-events:none!important;
}
#map .leaflet-pane.leaflet-surveyPointPane-pane{
  z-index:650!important;
}
#map .leaflet-pane.leaflet-surveyLabelPane-pane{
  z-index:760!important;
  pointer-events:none!important;
}
#map .leaflet-pane.leaflet-surveyTooltipPane-pane{
  z-index:820!important;
  pointer-events:none!important;
}
#map .leaflet-control-container{
  z-index:900!important;
}
#map:not(.dxf-only) .leaflet-tile-pane{
  z-index:180!important;
}
#map:not(.dxf-only) .leaflet-overlay-pane{
  z-index:400!important;
}
.layer-row input[type="checkbox"]{
  cursor:pointer!important;
}
.layer-row{
  user-select:none!important;
}
/* BGT/AHN zijn bewust zachter als overlay. */
button[data-overlay].active{
  box-shadow:0 0 0 1px rgba(255,209,102,.75),0 0 18px rgba(255,209,102,.18)!important;
}
/* END LAGEN PUNTEN HPROFIELEN STABIEL */

/* LAGEN ECHT STABIEL - GEEN DUBBELE VIEWERLAGEN */
#map .leaflet-baseTilePane-pane{ z-index:180!important; }
#map .leaflet-controlTilePane-pane{ z-index:245!important; pointer-events:auto!important; }
#map .leaflet-surveyLinePane-pane{ z-index:520!important; pointer-events:none!important; }
#map .leaflet-surveyProfilePane-pane{ z-index:610!important; pointer-events:none!important; }
#map .leaflet-surveyPointPane-pane{ z-index:700!important; pointer-events:auto!important; }
#map .leaflet-surveyLabelPane-pane{ z-index:790!important; pointer-events:none!important; }
#map .leaflet-surveyTooltipPane-pane{ z-index:850!important; pointer-events:none!important; }
#map .leaflet-control-container{ z-index:900!important; }
#map:not(.dxf-only) .leaflet-tile-pane{ z-index:180!important; }
#map:not(.dxf-only) .leaflet-overlay-pane{ z-index:400!important; }
.layer-row input[type="checkbox"],
.layers-head button{
  cursor:pointer!important;
}
.layer-row{
  user-select:none!important;
}
button[data-overlay].active{
  box-shadow:0 0 0 1px rgba(255,209,102,.75),0 0 18px rgba(255,209,102,.18)!important;
}
/* END LAGEN ECHT STABIEL - GEEN DUBBELE VIEWERLAGEN */

/* FIT PROJECT ROBUUST */
.viewer-note,
#mapNote,
.map-note{
  z-index:1600!important;
  pointer-events:none!important;
}
#map .leaflet-marker-pane,
#map .leaflet-tooltip-pane,
#map .leaflet-surveyPointPane-pane,
#map .leaflet-surveyProfilePane-pane{
  pointer-events:auto;
}
/* END FIT PROJECT ROBUUST */



/* SURVEY CONTROL LOGO ECHT ZICHTBAAR 20260523_121718
   Doel: breed logo zichtbaar in alle headers; geen crop, geen nested picture, geen klein icoontje. */
.sc-main-logo,
.v50-header > .sc-main-logo,
.sc-page-header > .sc-main-logo,
.portal-header > .sc-main-logo,
.machine-header > .sc-main-logo,
header .sc-main-logo {
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  flex:0 0 clamp(300px, 28vw, 520px)!important;
  width:clamp(300px, 28vw, 520px)!important;
  min-width:300px!important;
  max-width:520px!important;
  height:auto!important;
  min-height:86px!important;
  padding:0!important;
  margin:0 22px 0 0!important;
  border:0!important;
  outline:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  overflow:visible!important;
  text-decoration:none!important;
  position:relative!important;
  z-index:40!important;
}
.sc-main-logo picture,
header .sc-main-logo picture {
  display:block!important;
  width:100%!important;
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
}
.sc-main-logo img,
header .sc-main-logo img,
.sc-header-logo-img {
  display:block!important;
  width:100%!important;
  min-width:260px!important;
  max-width:520px!important;
  height:auto!important;
  max-height:150px!important;
  object-fit:contain!important;
  object-position:left center!important;
  opacity:1!important;
  visibility:visible!important;
  transform:none!important;
  filter:drop-shadow(0 0 18px rgba(106,161,255,.34))!important;
}
/* oude logo wrappers niet meer als klein kaartje tonen */
.v50-brand,.sc-brand,.brand,.sc-header-logo-link {
  overflow:visible!important;
}
.v50-header,.sc-page-header,.portal-header,.machine-header {
  overflow:visible!important;
}
/* App header iets compacter houden maar wel leesbaar */
.machine-header > .sc-main-logo,
.machine-header .sc-main-logo {
  flex-basis:clamp(250px, 22vw, 410px)!important;
  width:clamp(250px, 22vw, 410px)!important;
  min-width:250px!important;
  max-width:410px!important;
  min-height:70px!important;
}
.machine-header .sc-main-logo img {
  max-width:410px!important;
}
/* Kleine ribbongrafiek in hero niet kapot maken */
.v71-brand-ribbon .sc-header-logo-picture,
.v71-brand-ribbon .sc-header-logo-img {
  width:82px!important;
  min-width:82px!important;
  max-width:82px!important;
  height:auto!important;
}
@media (max-width:1150px) {
  .sc-main-logo,
  .v50-header > .sc-main-logo,
  .sc-page-header > .sc-main-logo,
  .portal-header > .sc-main-logo,
  .machine-header > .sc-main-logo {
    flex:0 0 min(86vw, 500px)!important;
    width:min(86vw, 500px)!important;
    max-width:500px!important;
    min-width:240px!important;
    margin-right:0!important;
  }
  .sc-main-logo img { max-width:min(86vw,500px)!important; }
}
@media (max-width:700px) {
  .sc-main-logo,
  .machine-header > .sc-main-logo {
    flex-basis:min(92vw, 380px)!important;
    width:min(92vw, 380px)!important;
    min-width:220px!important;
    max-width:380px!important;
    min-height:58px!important;
  }
  .sc-main-logo img { max-width:min(92vw,380px)!important; }
}
/* END SURVEY CONTROL LOGO ECHT ZICHTBAAR */


/* CONTEXT_DOCUMENTS_SAFE_CORE_V6 */
.file-input-print-placeholder{
  display:inline-block;
  padding:6px 8px;
  border:1px solid rgba(15,61,62,.35);
  background:#f8fafc;
  color:#334155;
  font-size:9px;
}
body.print-only-pdf > *:not(#printOnlyRoot){
  display:none !important;
}
#printOnlyRoot{display:none;}
@media print{
  body.print-only-pdf{background:#fff !important;color:#111827 !important;overflow:visible !important;}
  body.print-only-pdf #printOnlyRoot{display:block !important;background:#fff !important;color:#111827 !important;}
  body.print-only-pdf #printOnlyRoot .pdf-access-note,
  body.print-only-pdf #printOnlyRoot .pdf-gate-note,
  body.print-only-pdf #printOnlyRoot button{display:none !important;}
  body.print-only-pdf #printOnlyRoot .pdf-page{box-shadow:none !important;border:0 !important;break-after:page !important;page-break-after:always !important;}
}
