:root{
  --blue:#3cbff0;
  --gradient:linear-gradient(135deg,#3cbff0 0%,#0e90c8 100%);--blue-light:#eef3ff;--black:#111111;--dark:#1e1e2e;
  --white:#ffffff;--off:#f8f7f4;--muted:#5e5d5a;--border:#e8e6e0;
  --success:#1a7a3c;--success-bg:#eaf5ee;
  --warning:#7a4a00;--warning-bg:#fff4e0;
  --danger:#b01a1a;--danger-bg:#fff0f0;
  --r:12px;--rsm:8px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{font-family:'Montserrat',sans-serif;background:var(--off);color:var(--black);font-size:14px;line-height:1.6;}
button,input,select,textarea{font-family:'Montserrat',sans-serif;}
.screen{display:none;width:100%;height:100%;}
.screen.active{display:flex;}

/* LOGIN */
#s-login{align-items:center;justify-content:center;background:var(--off);flex-direction:column;}
.login-box{width:100%;max-width:420px;padding:2rem;}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.lmark{width:36px;height:36px;background:var(--black);border-radius:8px;display:flex;align-items:center;justify-content:center;}
.lmark span{color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;}
.lname{font-size:15px;font-weight:700;}
.login-title{font-size:30px;font-weight:700;line-height:1.2;margin-bottom:6px;}
.login-title span{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:italic;}
.login-sub{font-size:13px;color:var(--muted);margin-bottom:2rem;}
.mode-bar{display:flex;background:#f2f1ee;border-radius:var(--rsm);padding:4px;margin-bottom:1.75rem;}
.mbtn{flex:1;padding:8px;font-size:12px;font-weight:700;border:none;background:none;border-radius:6px;cursor:pointer;color:var(--muted);transition:all .2s;letter-spacing:.03em;}
.mbtn.active{background:var(--white);color:var(--black);box-shadow:0 1px 4px rgba(0,0,0,.1);}
.field{margin-bottom:1rem;}
.field label{display:block;font-size:10px;font-weight:700;color:var(--muted);margin-bottom:5px;letter-spacing:.06em;text-transform:uppercase;}
.field input,.field select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:13px;background:var(--white);color:var(--black);outline:none;transition:border-color .15s;}
.field input:focus,.field select:focus{border-color:var(--blue);}
.btn-main{width:100%;padding:13px;background:var(--gradient);color:#fff;border:none;border-radius:var(--rsm);font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.04em;transition:opacity .15s;margin-top:4px;}
.btn-main:hover{opacity:.88;}
.l-err{font-size:12px;color:var(--danger);margin-top:10px;display:none;font-weight:500;}
.l-hint{font-size:11px;color:var(--muted);margin-top:1.25rem;text-align:center;}

/* ADMIN SHELL */
#s-admin{flex-direction:row;overflow:hidden;width:100%;height:100%;}
#s-admin.active{display:flex!important;}
.sidebar{width:250px;min-width:250px;height:100vh;background:var(--dark);display:flex;flex-direction:column;padding:1.5rem 0;overflow-y:auto;overflow-x:hidden;flex-shrink:0;scrollbar-width:none;}.sidebar::-webkit-scrollbar{display:none;}
.sb-logo{display:flex;align-items:center;gap:10px;padding:0 1.25rem 1.75rem;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:1.5rem;}
.sb-lmark{width:30px;height:30px;background:var(--blue);border-radius:7px;display:flex;align-items:center;justify-content:center;}
.sb-lmark span{color:#fff;font-size:10px;font-weight:700;}
.sb-lname{font-size:13px;font-weight:700;color:#fff;}
.sb-ltag{font-size:10px;color:rgba(255,255,255,.3);margin-left:auto;}
.sb-sec{padding:0 .875rem;margin-bottom:1.25rem;}
.sb-lbl{font-size:10px;color:rgba(255,255,255,.28);letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:0 .375rem;margin-bottom:4px;}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;cursor:pointer;font-size:12px;font-weight:600;color:rgba(255,255,255,.45);transition:background .15s,color .15s;margin-bottom:1px;letter-spacing:.02em;outline:none;}
.sb-item:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.85);}
.sb-item:focus{outline:none;background:rgba(255,255,255,.07);color:rgba(255,255,255,.85);}
.sb-item.active{background:rgba(60,191,240,.2);color:#fff;}
.sb-item.active:hover{background:rgba(60,191,240,.28);color:#fff;}
.sb-item.active:focus{background:rgba(60,191,240,.2);color:#fff;outline:none;}
.sb-item svg{opacity:.5;flex-shrink:0;width:16px;height:16px;}
.sb-item.active svg{opacity:1;}
.sb-badge{margin-left:auto;font-size:10px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.6);padding:2px 7px;border-radius:20px;font-weight:700;}
.sb-badge.blue{background:rgba(26,92,255,.35);color:#7fa8ff;}
.sb-badge.orange{background:rgba(255,140,0,.25);color:#ffb347;}
.sb-bottom{margin-top:auto;padding:0 .875rem;}
.sb-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;border:1px solid rgba(255,255,255,.1);}
.sb-av{width:30px;height:30px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;}
.sb-uname{font-size:12px;color:rgba(255,255,255,.75);font-weight:700;}
.sb-urole{font-size:10px;color:rgba(255,255,255,.3);}
.sb-out{margin-left:auto;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.25);padding:4px;transition:color .15s;}
.sb-out:hover{color:rgba(255,255,255,.7);}

/* MAIN */
.admin-main{flex:1;min-width:0;display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden;position:relative;}
.topbar-big{background:var(--white);border-bottom:1px solid var(--border);padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;}
.topbar-big h1{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1.2;}
.topbar-big p{font-size:12px;color:var(--muted);margin-top:3px;}
.topbar-right{display:flex;gap:8px;align-items:center;}
.apage{display:none;overflow-y:scroll;padding:1.5rem 2rem 3rem;flex-direction:column;gap:1.25rem;min-width:0;width:100%;box-sizing:border-box;}
.apage.active{display:flex;}
/* Scrollbar altijd aan de rechterkant, smal en subtiel */
.apage::-webkit-scrollbar{width:5px;}
.apage::-webkit-scrollbar-track{background:transparent;}
.apage::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.apage::-webkit-scrollbar-thumb:hover{background:#ccc;}
.portal-body::-webkit-scrollbar{width:5px;}
.portal-body::-webkit-scrollbar-track{background:transparent;}
.portal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.portal-body::-webkit-scrollbar-thumb:hover{background:#ccc;}

/* DASHBOARD GRID */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start;}
.dash-widget{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;position:relative;transition:box-shadow .15s;}
.dash-widget.col-12{grid-column:span 2;}
.dash-widget.col-8{grid-column:span 2;}
.dash-widget.col-6{grid-column:span 1;}
.dash-widget.col-4{grid-column:span 1;}
.dash-widget.col-3{grid-column:span 1;}
.dash-widget.dragging{opacity:.55;box-shadow:0 8px 32px rgba(0,0,0,.18);}
.dash-widget.drag-over{border-color:var(--blue);box-shadow:0 0 0 2px rgba(60,191,240,.3);}
.dash-widget-inner{padding:1.25rem 1.5rem;}
.dash-drag-handle{cursor:grab;color:var(--muted);font-size:12px;padding:2px 4px;opacity:0;transition:opacity .15s;display:inline-block;}
.dash-widget:hover .dash-drag-handle{opacity:1;}
.dash-widget-hidden{display:none!important;}
/* DOCUMENT EDITOR */
.doc-editor-wrap{background:var(--white);}
.doc-toolbar{display:flex;gap:2px;padding:8px 12px;border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;background:var(--off);}
.doc-tb-btn{padding:4px 8px;background:none;border:none;border-radius:5px;cursor:pointer;font-size:12px;font-weight:700;color:var(--muted);transition:all .15s;line-height:1.4;font-family:'Montserrat',sans-serif;}
.doc-tb-btn:hover{background:var(--border);color:var(--black);}
.doc-tb-sep{width:1px;height:20px;background:var(--border);margin:0 4px;flex-shrink:0;}
.doc-content{min-height:420px;max-height:70vh;overflow-y:auto;padding:1.75rem 2.5rem;outline:none;font-size:14px;line-height:1.8;}
.doc-content:focus{outline:none;}
.doc-content h1{font-size:26px;font-weight:700;margin-bottom:.75rem;letter-spacing:-.02em;line-height:1.2;}
.doc-content h2{font-size:19px;font-weight:700;margin-bottom:.5rem;margin-top:1.5rem;letter-spacing:-.01em;}
.doc-content h3{font-size:15px;font-weight:700;margin-bottom:.4rem;margin-top:1rem;}
.doc-content p{margin-bottom:.75rem;}
.doc-content ul,.doc-content ol{padding-left:1.5rem;margin-bottom:.75rem;}
.doc-content li{margin-bottom:.25rem;}
.doc-content table{width:100%;border-collapse:collapse;margin:1rem 0;}
.doc-content table td,.doc-content table th{border:1px solid var(--border);padding:8px 12px;font-size:13px;min-width:60px;}
.doc-content table th{background:var(--off);font-weight:700;}
.doc-content img{max-width:100%;border-radius:var(--rsm);margin:.5rem 0;display:block;}
.doc-content blockquote{border-left:3px solid var(--blue);padding:.5rem 1rem;color:var(--muted);margin:.75rem 0;font-style:italic;background:rgba(60,191,240,.06);border-radius:0 var(--rsm) var(--rsm) 0;}
.doc-title-inp{width:100%;border:none;border-bottom:2px solid var(--border);outline:none;font-size:20px;font-weight:700;font-family:'Montserrat',sans-serif;background:transparent;color:var(--black);padding:4px 0 8px;margin-bottom:12px;transition:border-color .15s;}
.doc-title-inp:focus{border-bottom-color:var(--blue);}
.doc-list-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.doc-list-item:last-child{border-bottom:none;}
.doc-list-item:hover{background:var(--off);}
/* NOTES TAB */
#ap-documenten.editing{padding:0!important;gap:0!important;overflow:hidden!important;}
/* Doc-editor overlay neemt grid-row 2, topbar blijft in grid-row 1 */
.doc-editor-overlay{grid-row:2;display:flex;flex-direction:column;background:var(--off);overflow:hidden;}
@media(max-width:640px){
  /* Op mobiel: editor scrollbaar, topbar (met hamburger) blijft boven */
  .doc-editor-overlay{overflow-y:auto;-webkit-overflow-scrolling:touch;}
  .doc-content{padding:24px 16px;min-height:400px;}
}
/* Doc editor fills full admin-main content area */
.doc-editor-overlay{grid-row:2;display:flex;flex-direction:column;background:var(--off);overflow:hidden;}
.note-item{background:var(--off);border:1px solid var(--border);border-radius:var(--rsm);padding:12px 14px;margin-bottom:8px;position:relative;}
.note-item.pinned{background:var(--warning-bg);border-color:rgba(122,74,0,.2);}
.note-item-meta{font-size:10px;color:var(--muted);margin-bottom:5px;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.note-item-text{font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-word;}
/* CARDS */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem 1.5rem;}
.card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem;}
.card-title{font-size:13px;font-weight:700;letter-spacing:-.01em;}

/* METRICS */
.mgrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;}
.mgrid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
.mcard{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.1rem 1.25rem;}
.mcard-lbl{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;}
.mcard-val{font-size:26px;font-weight:700;letter-spacing:-.03em;line-height:1;}
.mcard-delta{font-size:11px;margin-top:5px;font-weight:600;}
.dup{color:var(--success);}.dwarn{color:var(--warning);}

/* BUTTONS */
.btn-blue{padding:8px 16px;background:var(--gradient);color:#fff;border:none;border-radius:var(--rsm);font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.03em;transition:opacity .15s;}
.btn-blue:hover{opacity:.88;}
.btn-ghost{padding:8px 14px;background:none;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:12px;font-weight:600;cursor:pointer;color:var(--black);transition:border-color .15s;}
.btn-ghost:hover{border-color:#aaa;}
.btn-smb{padding:5px 10px;background:none;border:none;font-size:11px;font-weight:700;color:var(--blue);cursor:pointer;border-radius:6px;transition:all .15s;}
.btn-smb:hover{background:var(--blue-light);}
.btn-smr{padding:5px 10px;background:none;border:none;font-size:11px;font-weight:700;color:var(--muted);cursor:pointer;border-radius:6px;transition:all .15s;}
.btn-smr:hover{background:var(--danger-bg);color:var(--danger);}
.btn-back{display:flex;align-items:center;gap:6px;background:none;border:none;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;padding:0;margin-bottom:.25rem;transition:color .15s;}
.btn-back:hover{color:var(--black);}

/* TABLE */
.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.tbl th{text-align:left;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;padding:14px 14px 10px;border-bottom:1px solid var(--border);}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tbody tr:hover td{background:var(--off);}

/* PILLS */
.pill{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;letter-spacing:.03em;display:inline-block;}
.p-active{background:var(--success-bg);color:var(--success);}
.p-review{background:var(--warning-bg);color:var(--warning);}
.p-pending{background:#f2f1ee;color:var(--muted);}
.p-approved{background:var(--success-bg);color:var(--success);}
.p-changes{background:var(--danger-bg);color:var(--danger);}
.p-new{background:rgba(60,191,240,.12);color:var(--blue);}
.p-awaiting{background:var(--warning-bg);color:var(--warning);}
.p-link{background:#f2f1ee;color:var(--muted);}

/* PROGRESS */
.prog{display:inline-flex;align-items:center;gap:8px;}
.prog-track{width:72px;height:5px;background:var(--border);border-radius:3px;overflow:hidden;}
.prog-fill{height:100%;background:var(--gradient);border-radius:3px;}
.prog-pct{font-size:11px;color:var(--muted);font-weight:600;}

/* TOGGLE */
.toggle{position:relative;width:36px;height:20px;flex-shrink:0;}
.toggle input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:20px;cursor:pointer;transition:background .2s;}
.toggle-slider:before{content:'';position:absolute;width:14px;height:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;}
.toggle input:checked+.toggle-slider{background:var(--gradient);}
.toggle input:checked+.toggle-slider:before{transform:translateX(16px);}
.widget-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.widget-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--rsm);transition:border-color .15s;}
.widget-item.on{border-color:var(--blue);background:rgba(60,191,240,.08);}
.stat-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);}
.stat-toggle-row:last-child{border-bottom:none;}
.section-div{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding:4px 0 8px;border-bottom:1px solid var(--border);margin-bottom:12px;margin-top:4px;}

/* CLIENT GRID */
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;}
.client-block{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem;display:flex;flex-direction:column;gap:12px;transition:border-color .2s,box-shadow .2s;}
.client-block:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(26,92,255,.07);}
.cb-btns{display:flex;gap:6px;}
.cb-portal{flex:1;padding:9px;background:var(--gradient);color:#fff;border:none;border-radius:var(--rsm);font-size:11px;font-weight:700;cursor:pointer;transition:opacity .15s;letter-spacing:.02em;}
.cb-portal:hover{opacity:.88;}
.cb-icon{width:34px;height:34px;background:none;border:1.5px solid var(--border);border-radius:var(--rsm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;}
.cb-icon:hover{border-color:var(--blue);background:var(--blue-light);}
.cb-icon svg{width:14px;height:14px;stroke:var(--muted);}
.cb-icon:hover svg{stroke:var(--blue);}

/* TODO */
.phase-section{margin-bottom:1.25rem;}
.phase-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;padding-bottom:6px;border-bottom:1.5px solid var(--border);}
.phase-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.phase-title{font-size:12px;font-weight:700;letter-spacing:.03em;}
.phase-count{font-size:10px;font-weight:700;background:var(--off);color:var(--muted);padding:2px 7px;border-radius:20px;}
.todo-item{display:flex;align-items:flex-start;gap:8px;padding:5px 8px;border-radius:var(--rsm);transition:background .1s;margin-bottom:1px;}
.todo-item:hover{background:var(--off);}
.todo-body{flex:1;min-width:0;}
.todo-text{font-size:12px;font-weight:600;line-height:1.35;}
.todo-text.done{text-decoration:line-through;color:var(--muted);}
.todo-tags{display:flex;gap:4px;margin-top:2px;flex-wrap:wrap;align-items:center;}
.todo-tag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--off);color:var(--muted);}
.todo-tag.client{background:var(--blue-light);color:var(--blue);}
.assignee-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 8px 2px 3px;border-radius:20px;background:var(--off);}
.assignee-dot{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#fff;flex-shrink:0;}
.todo-actions{display:flex;gap:4px;flex-shrink:0;align-items:center;}
.phase-sel{padding:4px 8px;border:1px solid var(--border);border-radius:5px;font-size:10px;font-weight:600;cursor:pointer;background:var(--white);outline:none;color:var(--black);}
.todo-del{padding:3px 7px;background:none;border:none;font-size:11px;color:var(--muted);cursor:pointer;border-radius:5px;transition:all .15s;}
.todo-del:hover{background:var(--danger-bg);color:var(--danger);}
.todo-desc{font-size:12px;color:var(--muted);line-height:1.6;margin-top:6px;padding:8px 10px;background:var(--off);border-radius:var(--rsm);border-left:2.5px solid var(--border);display:none;}
.todo-item.expanded .todo-desc{display:block;}
.todo-expand-btn{background:none;border:none;cursor:pointer;padding:2px 5px;color:var(--muted);font-size:10px;border-radius:4px;transition:all .15s;line-height:1;margin-top:1px;}
.todo-expand-btn:hover{background:var(--off);color:var(--black);}
.todo-add-row{display:flex;gap:8px;margin-bottom:16px;padding-bottom:16px;border-bottom:1.5px solid var(--border);flex-wrap:wrap;}
.todo-add-row input,.todo-add-row select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:12px;outline:none;transition:border-color .15s;background:var(--white);}
.todo-add-row input:focus,.todo-add-row select:focus{border-color:var(--blue);}
.todo-add-row .t-main{flex:1;min-width:180px;}
.todo-add-row button{padding:8px 16px;background:var(--blue);color:#fff;border:none;border-radius:var(--rsm);font-size:12px;font-weight:700;cursor:pointer;}

/* PW */
.pw-row{display:flex;align-items:center;gap:8px;}
.pw-dots{font-family:monospace;letter-spacing:2px;color:var(--muted);font-size:13px;display:inline-block;min-width:10ch;}
.pw-show{background:none;border:none;font-size:10px;font-weight:700;color:var(--blue);cursor:pointer;padding:2px 7px;border-radius:5px;}
.pw-show:hover{background:var(--blue-light);}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:center;justify-content:center;}
.modal-bg.open{display:flex;}
.modal{background:var(--white);border-radius:var(--r);padding:2rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;}
.modal-title{font-size:20px;font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem;}
.mf{margin-bottom:1rem;}
.mf label{display:block;font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.07em;text-transform:uppercase;margin-bottom:5px;}
.mf input,.mf select,.mf textarea{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:13px;color:var(--black);background:var(--white);outline:none;transition:border-color .15s;}
.mf input:focus,.mf select:focus,.mf textarea:focus{border-color:var(--blue);}
.mf textarea{resize:vertical;min-height:80px;}
.mrow{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--white);z-index:1;}

/* TOAST */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--dark);color:#fff;padding:11px 18px;border-radius:var(--rsm);font-size:13px;font-weight:600;opacity:0;transform:translateY(8px);transition:all .25s;pointer-events:none;z-index:999;}
.toast.show{opacity:1;transform:translateY(0);}

/* CLIENT DETAIL */
.client-detail-hero{background:var(--dark);border-radius:var(--r);padding:1.5rem 2rem;color:#fff;display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;}
.client-detail-hero h2{font-size:20px;font-weight:700;letter-spacing:-.02em;}
.client-detail-hero p{font-size:12px;color:rgba(255,255,255,.5);margin-top:3px;}
.ctabs{display:flex;border-bottom:1px solid var(--border);background:var(--white);border-radius:var(--r) var(--r) 0 0;}
.ctab{padding:12px 20px;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s;}
.ctab:hover{color:var(--black);}
.ctab.active{color:var(--blue);border-bottom-color:var(--blue);}
.ctab-page{display:none;background:var(--white);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--r) var(--r);padding:1.5rem;}
.ctab-page.active{display:block;}
.milestone-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);}
.milestone-row:last-child{border-bottom:none;}
.ms-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;}

/* CHAT */
.chat-wrap{display:flex;flex-direction:column;height:300px;}
.chat-msgs{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:2px;}
.chat-msg{display:flex;gap:8px;align-items:flex-end;}
.chat-msg.mine{flex-direction:row-reverse;}
.chat-msg.mine>div:last-child{align-items:flex-end;display:flex;flex-direction:column;}
.chat-bubble{max-width:78%;padding:9px 13px;font-size:12px;line-height:1.5;word-break:break-word;}
.chat-msg:not(.mine) .chat-bubble{background:var(--off);color:var(--black);border-radius:4px 12px 12px 12px;}
.chat-msg.mine .chat-bubble{background:var(--gradient);color:#fff;border-radius:12px 4px 12px 12px;}
.chat-cav{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;flex-shrink:0;}
.chat-meta{font-size:10px;color:var(--muted);margin-top:2px;}
.chat-msg.mine .chat-meta{text-align:right;}
.chat-input-row{display:flex;gap:8px;padding-top:10px;border-top:1px solid var(--border);margin-top:10px;}
.chat-inp{flex:1;padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:12px;outline:none;transition:border-color .15s;}
.chat-inp:focus{border-color:var(--blue);}
.chat-send{padding:9px 16px;background:var(--gradient);color:#fff;border:none;border-radius:var(--rsm);font-size:12px;font-weight:700;cursor:pointer;}

/* CONTACT */
.contact-person{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--rsm);margin-bottom:8px;}
.contact-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;}
.contact-name{font-size:13px;font-weight:700;}
.contact-role{font-size:11px;color:var(--muted);}
.contact-btns{display:flex;gap:6px;margin-left:auto;}
.cta-btn{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;text-decoration:none;}
.cta-btn:hover{background:var(--blue);border-color:var(--blue);}
.cta-btn:hover svg{stroke:#fff;}
.cta-btn svg{width:14px;height:14px;stroke:var(--muted);transition:stroke .15s;}

/* PORTAL */
#s-portal{flex-direction:column;height:100vh;overflow:hidden;background:var(--white);}
@supports(height:100dvh){#s-portal{height:100dvh;}}
@media(max-width:640px){
  #s-portal{height:100vh;height:-webkit-fill-available;}
  @supports(height:100dvh){#s-portal{height:100dvh;}}
}
.portal-nav{background:var(--white);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:58px;flex-shrink:0;}
.p-logo{display:flex;align-items:center;gap:10px;}
.p-lmark{width:28px;height:28px;background:var(--black);border-radius:6px;display:flex;align-items:center;justify-content:center;}
.p-lmark span{color:#fff;font-size:10px;font-weight:700;}
.p-lname{font-size:13px;font-weight:700;}
.p-ctag{font-size:12px;color:var(--muted);font-weight:600;padding-left:12px;border-left:1.5px solid var(--border);margin-left:2px;}
.kb-tabs{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;background:var(--off);border-radius:var(--rsm);padding:3px;}
.kb-tabs::-webkit-scrollbar{display:none;}
.kb-tab{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;color:var(--muted);transition:background .15s,color .15s;white-space:nowrap;outline:none;}
.kb-tab:hover{color:var(--black);background:rgba(0,0,0,.04);}
.kb-tab:focus{outline:none;}
.kb-tab.active{background:var(--white);color:var(--black);box-shadow:0 1px 4px rgba(0,0,0,.08);}
.kb-tab.active:hover{background:var(--white);color:var(--black);}
.kb-tab.active:focus{background:var(--white);color:var(--black);outline:none;}
.kb-tab svg{opacity:.5;flex-shrink:0;}
.kb-tab.active svg{opacity:1;}
.kb-page{display:none;}
.kb-page.active{display:block;}
.ptabs{display:flex;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0;}.ptabs::-webkit-scrollbar{display:none;}
.ptab{padding:0 16px;height:58px;display:flex;align-items:center;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:color .15s,border-color .15s;outline:none;}
.ptab:hover{color:var(--black);}
.ptab:focus{outline:none;color:var(--black);}
.ptab.active{color:var(--blue);border-bottom-color:var(--blue);}
.ptab.active:hover{color:var(--blue);}
.ptab.active:focus{color:var(--blue);outline:none;}
.p-out{background:none;border:none;font-size:12px;color:var(--muted);cursor:pointer;font-weight:700;padding:7px 14px;border-radius:var(--rsm);}
.p-out:hover{background:var(--off);color:var(--black);}
/* Portal body: max-width voor alle tabs behalve planning */
.portal-body{flex:1;overflow-y:auto;padding:1.75rem 2rem 3rem;width:100%;display:flex;flex-direction:column;gap:1.25rem;background:var(--white);min-height:0;}
/* Alle ptab-pages behalve planning krijgen max-width centrering */
.ptab-page:not(#pp-planning){max-width:1000px;margin-left:auto;margin-right:auto;width:100%;}
/* Planning tab volledige breedte — zie regels boven bij content kalender CSS */
.ptab-page{display:none;flex-direction:column;gap:1.25rem;width:100%;min-width:0;}
.ptab-page.active{display:flex;}
.p-hero{background:var(--dark);border-radius:var(--r);padding:1.75rem 2rem;color:#fff;display:flex;align-items:center;justify-content:space-between;}
.p-hero h2{font-size:20px;font-weight:700;letter-spacing:-.02em;}
.p-hero h2 span{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:italic;}
.p-hero p{font-size:12px;color:rgba(255,255,255,.5);margin-top:3px;}

/* PORTAL PROJECT CARDS */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;}
.proj-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem;cursor:pointer;transition:border-color .2s,box-shadow .2s;}
.proj-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(26,92,255,.08);}
.proj-card-type{font-size:10px;font-weight:700;color:var(--blue);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;}
.proj-card-name{font-size:14px;font-weight:700;margin-bottom:4px;}
.proj-card-sub{font-size:11px;color:var(--muted);margin-bottom:14px;}
.proj-card-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:8px;}
.proj-card-fill{height:100%;background:var(--gradient);border-radius:3px;}
.proj-card-foot{display:flex;align-items:center;justify-content:space-between;}
.proj-card-pct{font-size:12px;font-weight:700;color:var(--blue);}
.proj-card-due{font-size:11px;color:var(--muted);}

/* PROJECT DETAIL */
.proj-detail-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--white);border-radius:var(--r) var(--r) 0 0;}
.pdtab{padding:12px 20px;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:color .15s,border-color .15s;outline:none;}
.pdtab:hover{color:var(--black);}
.pdtab:focus{outline:none;color:var(--black);}
.pdtab.active{color:var(--blue);border-bottom-color:var(--blue);}
.pdtab.active:hover{color:var(--blue);}
.pdtab.active:focus{color:var(--blue);outline:none;}
.pdtab-page{display:none;background:var(--white);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--r) var(--r);padding:1.5rem;}
.pdtab-page.active{display:block;}

/* STATUS TIMELINE */
.status-timeline{display:flex;align-items:flex-start;margin:1rem 0;}
.st-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;}
.st-step:not(:last-child)::after{content:'';position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--border);z-index:0;}
.st-step.done::after{background:var(--blue);}
.st-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;z-index:1;position:relative;}
.st-step.done .st-dot{background:var(--gradient);border-color:transparent;color:#fff;}
.st-step.current .st-dot{border-color:var(--blue);color:var(--blue);}
.st-label{font-size:10px;font-weight:700;color:var(--muted);margin-top:6px;text-align:center;letter-spacing:.03em;}
.st-step.done .st-label,.st-step.current .st-label{color:var(--blue);}

/* DELIV ROW */
.deliv-row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);}
.deliv-row:last-child{border-bottom:none;}
.deliv-row-icon{width:36px;height:28px;background:var(--blue-light);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;}
.deliv-row-info{flex:1;}
.deliv-row-name{font-size:13px;font-weight:700;}
.deliv-row-meta{font-size:11px;color:var(--muted);}
.deliv-row-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.btn-approve-sm{padding:6px 14px;background:var(--gradient);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;}
.btn-req-sm{padding:6px 12px;background:none;border:1.5px solid var(--border);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;color:var(--black);}
.btn-req-sm:hover{border-color:var(--blue);color:var(--blue);}
.approved-note{font-size:12px;font-weight:700;color:var(--success);display:flex;align-items:center;gap:6px;}
.comments-wrap{margin-top:.875rem;border-top:1px solid var(--border);padding-top:.875rem;display:none;flex-direction:column;gap:10px;}
.comment{display:flex;gap:10px;}
.c-av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;}
.c-av.agency{background:var(--dark);color:#fff;}
.c-av.client{background:var(--blue-light);color:var(--blue);}
.c-body{flex:1;}
.c-author{font-size:11px;font-weight:700;}
.c-time{font-weight:400;color:var(--muted);margin-left:6px;}
.c-text{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.5;}
.c-input-row{display:flex;gap:8px;}
.c-input-row input{flex:1;padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:12px;outline:none;transition:border-color .15s;}
.c-input-row input:focus{border-color:var(--blue);}
.c-input-row button{padding:9px 16px;background:var(--blue);color:#fff;border:none;border-radius:var(--rsm);font-size:12px;font-weight:700;cursor:pointer;}

/* STATS SORT */
.sort-btn{padding:6px 14px;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:var(--white);color:var(--muted);transition:all .15s;}
.sort-btn.active{background:var(--gradient);color:#fff;border-color:var(--blue);}
.sort-dir{padding:6px 12px;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:var(--white);color:var(--black);transition:all .15s;}
.sort-dir:hover{border-color:var(--blue);}
.tc-bar-wrap{flex:1;height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin:0 10px;}
.tc-bar-fill{height:100%;background:var(--blue);border-radius:3px;}

/* SUBTASKS */
.subtask-list{margin-top:8px;padding-left:26px;display:flex;flex-direction:column;gap:4px;}
.subtask-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);}
.subtask-check{width:13px;height:13px;border-radius:3px;border:1.5px solid var(--border);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.subtask-check:hover{border-color:var(--blue);}
.subtask-check.done{background:var(--blue);border-color:var(--blue);}
.subtask-check.done::after{content:'';width:5px;height:3px;border-left:1.5px solid #fff;border-bottom:1.5px solid #fff;transform:rotate(-45deg) translateY(-1px);display:block;}
.subtask-text.done{text-decoration:line-through;color:var(--muted);}
.add-subtask-row{display:flex;gap:6px;margin-top:6px;padding-left:26px;}
.add-subtask-row input{flex:1;padding:5px 10px;border:1px solid var(--border);border-radius:5px;font-size:11px;outline:none;}
.add-subtask-row input:focus{border-color:var(--blue);}
.add-subtask-row button{padding:5px 10px;background:var(--blue);color:#fff;border:none;border-radius:5px;font-size:10px;font-weight:700;cursor:pointer;}
/* MULTI-ASSIGNEE */
.assignee-checks{display:flex;gap:6px;flex-wrap:wrap;}
.assignee-check-item{display:flex;align-items:center;gap:5px;padding:4px 10px;border:1.5px solid var(--border);border-radius:20px;cursor:pointer;font-size:11px;font-weight:700;color:var(--muted);transition:all .15s;user-select:none;}
.assignee-check-item.selected{color:#fff;border-color:transparent;}
/* BEHEER / INVOICE */
.inv-status-pill{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;}
.inv-betaald{background:var(--success-bg);color:var(--success);}
.inv-openstaand{background:var(--warning-bg);color:var(--warning);}
/* TEAM CARDS */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.team-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem;display:flex;flex-direction:column;gap:10px;}
.team-card-top{display:flex;align-items:center;gap:10px;}
.team-card-name{font-size:14px;font-weight:700;}
.team-card-role{font-size:11px;color:var(--muted);}
.team-card-btns{display:flex;gap:6px;margin-top:4px;}
/* CLIENT ACCOUNTS TABLE */
.ca-table-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
/* MONTH TABS */
.month-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1rem;}
.month-tab{padding:6px 14px;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:var(--white);color:var(--muted);transition:all .15s;}
.month-tab.active{background:var(--gradient);color:#fff;border-color:var(--blue);}
/* HERO PORTAL EXTENDED */
.portal-hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;}
.phs-item{background:rgba(255,255,255,.07);border-radius:8px;padding:10px 14px;}
.phs-label{font-size:10px;font-weight:700;color:rgba(255,255,255,.4);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;}
.phs-val{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1;}
.phs-delta{font-size:10px;font-weight:600;color:rgba(255,255,255,.5);margin-top:3px;}

/* PROJECT FEEDBACK */
.proj-feedback-approved{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--success);background:var(--success-bg);padding:10px 14px;border-radius:var(--rsm);}
.proj-feedback-changes{font-size:12px;color:var(--danger);font-weight:700;background:var(--danger-bg);padding:10px 14px;border-radius:var(--rsm);}
.proj-status-note{font-size:12px;color:rgba(255,255,255,.65);background:rgba(255,255,255,.07);border-radius:var(--rsm);padding:10px 14px;margin-top:10px;line-height:1.55;border-left:3px solid rgba(26,92,255,.5);}
.feedback-textarea{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:12px;resize:vertical;min-height:80px;outline:none;font-family:'Montserrat',sans-serif;transition:border-color .15s;margin-bottom:8px;}
.feedback-textarea:focus{border-color:var(--blue);}
/* DELIVERABLES */
.deliv-type-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;}
.deliv-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.25rem;display:flex;align-items:center;gap:14px;transition:border-color .15s;}
.deliv-card:hover{border-color:var(--blue);}
.deliv-proj-section{margin-bottom:1.25rem;}
.deliv-proj-header{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;padding-bottom:6px;border-bottom:1.5px solid var(--border);}
/* LINK CARD */
.link-row-card:hover{border-color:var(--blue);}
.link-icon{width:32px;height:32px;background:var(--blue-light);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.link-title{font-size:13px;font-weight:700;flex:1;}
.link-sub{font-size:11px;color:var(--muted);}
.link-open-btn{padding:6px 13px;background:var(--gradient);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;}

/* ═══ BRANDBOOK ════════════════════════════════════════ */
.bb-section{margin-bottom:2rem;}
.bb-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.bb-section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.bb-field{margin-bottom:12px;}
.bb-field label{display:block;font-size:11px;font-weight:700;color:var(--muted);margin-bottom:5px;letter-spacing:.04em;}
.bb-field input,.bb-field textarea,.bb-field select{width:100%;padding:8px 11px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:13px;background:var(--white);transition:border .15s;box-sizing:border-box;font-family:inherit;}
.bb-field input:focus,.bb-field textarea:focus{outline:none;border-color:var(--blue);}
.bb-field textarea{resize:vertical;min-height:72px;line-height:1.6;}
.bb-colors{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:6px;}
.bb-color-chip{width:36px;height:36px;border-radius:8px;border:2px solid rgba(0,0,0,.08);cursor:pointer;position:relative;flex-shrink:0;transition:transform .1s;display:flex;align-items:center;justify-content:center;}
.bb-color-chip:hover{transform:scale(1.1);}
.bb-color-chip input[type=color]{opacity:0;position:absolute;inset:0;cursor:pointer;width:100%;height:100%;border:none;padding:0;}
.bb-add-color{width:36px;height:36px;border-radius:8px;border:1.5px dashed var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--muted);background:none;transition:all .15s;flex-shrink:0;}
.bb-add-color:hover{border-color:var(--blue);color:var(--blue);}
.bb-font-row{display:flex;gap:8px;align-items:center;margin-bottom:8px;}
.bb-font-row input{flex:1;}
.bb-font-preview{font-size:20px;min-width:60px;text-align:center;padding:4px 8px;background:var(--off);border-radius:var(--rsm);}
.bb-remove{background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;padding:4px;line-height:1;transition:color .15s;}
.bb-remove:hover{color:var(--danger,#dc2626);}
.bb-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--off);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:600;margin:3px;}
.bb-tag button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:12px;line-height:1;padding:0;}
.bb-tag-input{display:flex;gap:6px;margin-top:6px;}
.bb-tag-input input{flex:1;padding:6px 10px;border:1.5px solid var(--border);border-radius:var(--rsm);font-size:12px;}
.bb-tag-input button{padding:6px 12px;background:var(--blue);color:#fff;border:none;border-radius:var(--rsm);cursor:pointer;font-size:12px;font-weight:700;}
.bb-save-row{position:sticky;bottom:0;background:var(--white);padding:12px 0 4px;border-top:1px solid var(--border);margin-top:1rem;display:flex;gap:8px;align-items:center;}
/* ═══ CONTENT KALENDER ═══ */
.cal-tabs{display:flex;gap:2px;background:#f2f1ee;border-radius:var(--rsm);padding:3px;margin-bottom:1.25rem;width:fit-content;}
.cal-tab{padding:7px 18px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;color:var(--muted);transition:background .15s,color .15s;border:none;background:none;letter-spacing:.02em;outline:none;}
.cal-tab:hover{background:rgba(0,0,0,.05);color:var(--black);}
.cal-tab:focus{outline:none;}
.cal-tab.active{background:var(--white);color:var(--black);box-shadow:0 1px 4px rgba(0,0,0,.1);}
.cal-tab.active:hover{background:var(--white);color:var(--black);}
.cal-tab.active:focus{background:var(--white);color:var(--black);outline:none;}
.cal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;}
/* Portal planning tab: neemt volledige breedte van portal-body */
#pp-planning{
  padding:0!important;
  max-width:none!important;
  margin:0!important;
  width:100%!important;
  gap:0!important;
}
/* Koptekst planning heeft eigen padding */
#pp-planning-header{
  padding:1.75rem 2rem .75rem;
  flex-shrink:0;
}
/* Maandkalender neemt resterende breedte */
#pp-planning #p-cal-grid{width:100%;padding:0 2rem 2rem;}
#pp-planning .month-cal-wrap{width:100%;box-sizing:border-box;}
#pp-planning .cal-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));width:100%;}
.cal-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,box-shadow .15s;position:relative;}
.cal-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(60,191,240,.08);}
.cal-card-platform{display:flex;align-items:center;gap:6px;margin-bottom:2px;}
.cal-platform-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:.04em;}
.plat-tiktok{background:#f0f0f0;color:#111;}
.plat-instagram{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;}
.plat-linkedin{background:#0077b5;color:#fff;}
.cal-card-time{font-size:11px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:4px;}
.cal-card-desc{font-size:12px;color:var(--black);line-height:1.55;flex:1;}
.cal-card-link{font-size:11px;color:var(--blue);font-weight:700;text-decoration:none;display:flex;align-items:center;gap:4px;width:fit-content;}
.cal-card-link:hover{text-decoration:underline;}
.cal-card-status{display:flex;align-items:center;gap:6px;margin-top:4px;padding-top:8px;border-top:1px solid var(--border);}
.cal-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.cal-status-label{font-size:10px;font-weight:700;letter-spacing:.04em;}
.cal-card-actions{position:absolute;top:10px;right:10px;display:flex;gap:4px;opacity:0;transition:opacity .15s;}
.cal-card:hover .cal-card-actions{opacity:1;}
.cal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--muted);text-align:center;gap:8px;grid-column:1/-1;}
.cal-sort-bar{display:flex;align-items:center;gap:8px;margin-bottom:1rem;flex-wrap:wrap;}

/* ═══ MONTHLY CALENDAR GRID ═══ */
.month-cal-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.month-cal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:var(--dark);}
.month-cal-title{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.02em;}
.month-cal-title span{color:var(--blue);font-style:italic;}
.month-cal-nav{display:flex;gap:6px;align-items:center;}
.month-cal-nav button{width:32px;height:32px;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--rsm);background:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:'Montserrat',sans-serif;}
.month-cal-nav button:hover{border-color:var(--blue);color:#fff;background:rgba(60,191,240,.15);}
.month-cal-nav .today-btn{width:auto;padding:0 14px;font-size:11px;font-weight:700;letter-spacing:.04em;}
.month-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);}
.month-cal-dayname{padding:8px 4px;text-align:center;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);background:var(--off);}
.month-cal-cell{min-height:96px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:4px;position:relative;transition:background .1s;vertical-align:top;}
.month-cal-cell:nth-child(7n){border-right:none;}
.month-cal-cell:hover{background:rgba(60,191,240,.03);}
.month-cal-cell.other-month{background:var(--off);}
.month-cal-cell.other-month .month-cal-daynr{color:var(--border);}
.month-cal-cell.today .month-cal-daynr{background:var(--blue);color:#fff;border-radius:50%;}
.month-cal-cell.today{background:rgba(60,191,240,.04);}
.month-cal-daynr{font-size:11px;font-weight:700;color:var(--muted);width:22px;height:22px;display:flex;align-items:center;justify-content:center;margin-bottom:2px;cursor:default;}
.month-cal-event{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:opacity .1s;display:flex;align-items:center;gap:3px;}
.month-cal-event:hover{opacity:.8;}
.month-cal-event .evdot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.month-cal-more{font-size:10px;font-weight:700;color:var(--blue);cursor:pointer;padding:1px 4px;border-radius:3px;}
.month-cal-more:hover{background:var(--blue-light);}
.month-cal-add-cell{position:absolute;bottom:4px;right:4px;width:18px;height:18px;border-radius:4px;background:none;border:1px dashed var(--border);color:var(--muted);font-size:14px;display:none;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;line-height:1;}
.month-cal-cell:hover .month-cal-add-cell{display:flex;}
.month-cal-add-cell:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}

/* Portal mobiele kalender lijstweergave */
.p-cal-list-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 12px;border-radius:var(--rsm);margin-bottom:4px;
  background:var(--white);border:1px solid var(--border);
  cursor:pointer;transition:border-color .15s,box-shadow .15s;
}
.p-cal-list-item:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(60,191,240,.1);}
.p-cal-list-today{border-left:3px solid var(--blue)!important;}
.p-cal-list-icon{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;
}

/* Cal event context menu button hover fix */
.cal-event-menu-btn{
  display:flex;align-items:center;gap:8px;width:100%;
  padding:7px 12px;background:none;border:none;cursor:pointer;
  font-size:12px;font-weight:600;color:var(--black);
  border-radius:6px;font-family:'Montserrat',sans-serif;
  transition:background .12s,color .12s;outline:none;
}
.cal-event-menu-btn:hover{background:var(--off);}
.cal-event-menu-btn:focus{outline:none;background:var(--off);}
.cal-event-menu-btn.danger{color:var(--danger);}
.cal-event-menu-btn.danger:hover{background:var(--danger-bg);}
.cal-event-menu-btn.danger:focus{background:var(--danger-bg);outline:none;}
.cal-event-menu-link{
  display:flex;align-items:center;gap:8px;width:100%;
  padding:7px 12px;background:none;border:none;cursor:pointer;
  font-size:12px;font-weight:600;color:var(--blue);
  border-radius:6px;text-decoration:none;font-family:'Montserrat',sans-serif;
  transition:background .12s;outline:none;
}
.cal-event-menu-link:hover{background:var(--off);}
.cal-event-menu-link:focus{outline:none;background:var(--off);}

/* SLIDE-IN ANIMATIE TABBLADEN */
@keyframes slideInLeft{
  from{opacity:0;transform:translateX(-22px);}
  to{opacity:1;transform:translateX(0);}
}
.apage.slide-in{animation:slideInLeft .22s cubic-bezier(.4,0,.2,1) both;}

/* ═══ MOBILE: Responsiviteit ═══ */
@media(max-width:640px){
  /* Kalenderraster */
  .month-cal-cell{min-height:60px;padding:2px;}
  .month-cal-event{font-size:9px;padding:1px 4px;}
  .month-cal-daynr{font-size:10px;width:18px;height:18px;}
  .month-cal-header{padding:.75rem 1rem;flex-wrap:wrap;gap:8px;}
  .month-cal-title{font-size:15px;}
  .month-cal-nav{gap:4px;}
  .month-cal-nav button{width:28px;height:28px;font-size:14px;}

  /* Sidebar als slide-over overlay */
  .sidebar{
    transform:translateX(-100%);
    position:fixed;z-index:500;top:0;left:0;height:100vh;
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    width:260px!important;min-width:260px!important;
    overflow-y:auto;padding:1.5rem 0;
  }
  .sidebar.mob-open{transform:translateX(0);}

  /* Hamburger altijd zichtbaar op mobiel, op alle paginas */
  #mob-menu-btn{display:none;}

  /* Admin main neemt volledige breedte */
  .admin-main{width:100%;margin-left:0;}

  /* Topbar */
  .topbar-big{padding:.875rem 1rem;flex-wrap:nowrap;gap:8px;align-items:center;}
  .topbar-big h1{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .topbar-big > div:nth-child(2){flex:1;min-width:0;}
  .topbar-big p{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .topbar-right{flex-wrap:wrap;gap:6px;flex-shrink:0;}

  /* Paginascrolling: altijd naar beneden scrollbaar */
  .apage{
    padding:.875rem 1rem 4rem;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    /* grid-row zit al correct in admin-main */
  }

  /* Grids */
  .mgrid{grid-template-columns:1fr 1fr;}
  .mgrid3{grid-template-columns:1fr;}
  .dash-grid{grid-template-columns:1fr;}
  .dash-widget.col-6,.dash-widget.col-4,.dash-widget.col-3{grid-column:span 1;}
  .proj-grid{grid-template-columns:1fr;}
  .clients-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr;}

  /* Knoppen: minimale raakoppervlakte 44px */
  .btn-blue,.btn-ghost,.btn-main{min-height:44px;padding:10px 14px;}
  .btn-smb,.btn-smr{min-height:36px;padding:5px 10px;font-size:11px;}
  .cb-portal{min-height:40px;}
  .cb-btns{flex-wrap:wrap;}

  /* Modals: bottom-sheet stijl */
  .modal-bg{align-items:flex-end;}
  .modal{
    padding:1.25rem 1rem 2rem;
    max-width:100%!important;
    width:100%;
    margin:0;
    border-radius:16px 16px 0 0;
    max-height:90vh;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .modal-title{font-size:17px;margin-bottom:1.25rem;}
  .mrow{grid-template-columns:1fr;}
  .modal-footer{flex-direction:column-reverse;gap:8px;padding-top:1rem;}
  .modal-footer .btn-ghost,
  .modal-footer .btn-blue{width:100%;text-align:center;justify-content:center;min-height:48px;}

  /* Tabellen: wrapper horizontaal scrollbaar, tabel zelf heeft min-width */
  .tbl{font-size:12px;min-width:500px;}
  .tbl th,.tbl td{padding:8px 10px;white-space:nowrap;}
  /* Elke card met een tabel erin moet overflow:auto krijgen */
  .card{overflow:hidden;}
  .card > div{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .ca-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}

  /* Klantdetail */
  .ctabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;border-radius:var(--r) var(--r) 0 0;}
  .ctab{white-space:nowrap;flex-shrink:0;padding:10px 14px;font-size:11px;}
  .ctab-page{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    /* Voorkomt dat content buiten het scherm valt */
    max-width:100vw;
  }
  .proj-detail-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;}
  .pdtab{white-space:nowrap;flex-shrink:0;font-size:11px;padding:10px 14px;}
  .pdtab-page{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .client-detail-hero{flex-direction:column;gap:10px;padding:1rem;}
  .client-detail-hero > div:last-child{align-items:flex-start!important;}

  /* Kaartkoppen */
  .card-hdr{flex-wrap:wrap;gap:8px;}

  /* Content kalender tabs */
  .cal-tabs{flex-wrap:wrap;width:100%;}
  .cal-tab{flex:1;text-align:center;font-size:11px;padding:7px 10px;}

  /* Content kalender grid: altijd één kolom op mobiel */
  .cal-grid{grid-template-columns:1fr!important;}
  #pp-planning .cal-grid{grid-template-columns:1fr!important;padding:0 1rem 1rem;}
  .cal-card{min-width:0;}

  /* Rapportage grids naar kolom */
  #ap-rapportage > div[style*="grid-template-columns:1.6fr"],
  #ap-rapportage > div[style*="grid-template-columns:1fr 1fr"]{
    display:flex!important;flex-direction:column!important;
  }

  /* Portal navigatie: hamburgermenu tonen, tabs verbergen */
  #portal-mob-btn{display:flex!important;}
  #portal-mob-logout{display:flex!important;margin-left:auto;}
  .ptabs{display:none!important;}
  .p-out{display:none!important;}
  .portal-nav{padding:.75rem 1rem;height:auto;justify-content:flex-start;gap:8px;}
  .portal-nav .p-logo{flex:1;min-width:0;justify-content:center;}

  .portal-body{
    padding:1rem 1rem 4rem;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    background:var(--white);
    flex:1;
    min-height:0;
  }

  /* Portal tab-pages: volledig doorzichtig — witte portal-body is de achtergrond */
  .ptab-page{
    width:100%;
    min-width:0;
    overflow-x:visible;
    overflow-y:visible;
    background:transparent!important;
  }
  .ptab-page.active{
    background:transparent!important;
    display:flex;
  }

  /* Overview hero compacter */
  .p-hero{flex-direction:column;padding:1.25rem;}
  .portal-hero-stats{grid-template-columns:1fr 1fr;}
  #pp-overview > div[style*="grid-template-columns:1.4fr"]{
    display:flex!important;flex-direction:column!important;
  }

  /* Portal planning: volledige breedte, scrollbaar, zichtbaar */
  #pp-planning{
    overflow-x:visible!important;
    overflow-y:visible!important;
    padding:0!important;
    max-width:none!important;
    margin:0!important;
    width:100%!important;
    gap:0!important;
  }
  #pp-planning-header{padding:1rem 0 .75rem!important;}
  #pp-planning #p-cal-grid{
    padding:0!important;
    width:100%;
  }
  #pp-planning .month-cal-wrap{width:100%;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  #pp-planning .month-cal-grid{min-width:320px;}

  /* Projectdetail tabs: niet-actieve pages transparant (geen grijs) */
  .proj-detail-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;}
  .pdtab{white-space:nowrap;flex-shrink:0;font-size:11px;padding:10px 14px;}
  .pdtab-page{
    display:none;
    background:var(--white);
    border:1px solid var(--border);
    border-top:none;
    border-radius:0 0 var(--r) var(--r);
    padding:1rem;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .pdtab-page.active{display:block;}

  /* Contactpersonen wrappen op smal scherm */
  .contact-person{flex-wrap:wrap;gap:8px;}
  .contact-btns{margin-left:0;flex-wrap:wrap;}

  /* Projectfasen stepper: fix overflow op smal scherm */
  .status-timeline{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;}
  .st-step{min-width:56px;}
  .st-dot{width:26px;height:26px;font-size:9px;}
  .st-label{font-size:9px;}

  /* Login */
  .login-box{padding:1.5rem 1.25rem;}
  .login-title{font-size:24px;}
  .mode-bar{flex-wrap:wrap;}
}

/* Portal hamburger knop — standaard verborgen, mobiel zichtbaar */
#portal-mob-btn{
  display:none;
  align-items:center;justify-content:center;
  width:40px;height:40px;
  background:none;border:1.5px solid var(--border);border-radius:var(--rsm);
  cursor:pointer;flex-shrink:0;margin-right:8px;transition:border-color .15s;
}
#portal-mob-btn:hover{border-color:var(--blue);}
#portal-mob-btn svg{pointer-events:none;}

/* Uitlogknop mobiel portaal — standaard verborgen, alleen mobiel zichtbaar */
#portal-mob-logout{
  display:none;
  align-items:center;justify-content:center;
  width:40px;height:40px;
  background:none;border:1.5px solid var(--border);border-radius:var(--rsm);
  cursor:pointer;flex-shrink:0;margin-left:auto;
  color:var(--muted);transition:border-color .15s,color .15s;
}
#portal-mob-logout:hover{border-color:var(--danger);color:var(--danger);}

/* Hamburger-knop admin - standaard onzichtbaar, mobiel zichtbaar via media query */
#mob-menu-btn{
  display:none;
  align-items:center;justify-content:center;
  width:40px;height:40px;
  background:none;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--rsm);
  cursor:pointer;flex-shrink:0;margin-right:12px;transition:border-color .15s;color:#fff;
}
#mob-menu-btn:hover{border-color:rgba(255,255,255,.4);}
#mob-menu-btn svg{pointer-events:none;}

/* Mobiele backdrop */
#mob-backdrop{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  z-index:499;
}
#mob-backdrop.open{display:block;}

/* Hyperlinks in document editor */
.doc-content a{color:var(--blue);text-decoration:underline;cursor:pointer;}
.doc-content a:hover{opacity:.75;}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET (max-width: 1024px)
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  /* Sidebar smaller on tablet */
  .sidebar{width:220px;min-width:220px;}
  .sb-logo{padding:1.25rem 1rem;}

  /* Grids: 2 columns on tablet */
  .mgrid{grid-template-columns:repeat(2,1fr);}
  .clients-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .kpi-grid{grid-template-columns:repeat(2,1fr);}

  /* Pipeline kanban: 3 columns max */
  #ctab-cpipeline [style*="grid-template-columns:repeat(auto-fill,minmax(320px"],
  [id^="portal-pipeline-items"] [style*="grid-template-columns:repeat(auto-fill"]{
    grid-template-columns:repeat(2,1fr)!important;
  }

  /* Portal dashboard cards: 2 cols */
  #p-dashboard-grid{grid-template-columns:1fr 1fr!important;}

  /* Stats table: allow horizontal scroll */
  #ap-stats .card{overflow-x:auto;}
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET PORTRAIT (max-width: 768px)
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* ── Hamburger zichtbaar op tablet ── */
  #mob-menu-btn{display:flex!important;}

  /* ── Admin sidebar als slide-over ── */
  .sidebar{
    transform:translateX(-100%);
    position:fixed;z-index:500;top:0;left:0;height:100vh;
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    width:260px!important;min-width:260px!important;
    overflow-y:auto;
    box-shadow:4px 0 24px rgba(0,0,0,.15);
  }
  .sidebar.mob-open{transform:translateX(0);}
  .admin-main{margin-left:0;width:100%;}
  #mob-menu-btn{display:none;}

  /* ── Grids naar 1 kolom ── */
  .mgrid{grid-template-columns:1fr!important;}
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
  .clients-grid{grid-template-columns:1fr!important;}
  .team-grid{grid-template-columns:1fr!important;}
  .dash-grid{grid-template-columns:1fr!important;}
  .dash-widget.col-6,.dash-widget.col-4,.dash-widget.col-3{grid-column:span 1!important;}

  /* ── Pipeline op tablet ── */
  #ctab-cpipeline [style*="grid-template-columns:repeat(auto-fill,minmax(320px"],
  [id^="portal-pipeline-items"] [style*="grid-template-columns:repeat(auto-fill"]{
    grid-template-columns:1fr!important;
  }
  /* Fase summary kaarten: 3 kolommen */
  #ctab-cpipeline > div:first-child{
    grid-template-columns:repeat(3,1fr)!important;
  }

  /* ── Portal ── */
  #p-dashboard-grid{grid-template-columns:1fr!important;}
  .p-hero{flex-direction:column;padding:1.25rem;}
  .portal-hero-stats{grid-template-columns:1fr 1fr;}
  #pp-overview > div[style*="grid-template-columns"]{
    display:flex!important;flex-direction:column!important;
  }

  /* Portal tabs: scrollbaar */
  .ptabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;}
  .ptab{white-space:nowrap;flex-shrink:0;font-size:12px;padding:10px 14px;}

  /* ── Modals: bottom sheet ── */
  .modal-bg{align-items:flex-end!important;}
  .modal{
    padding:1.25rem 1.1rem 2rem;
    max-width:100%!important;width:100%;margin:0;
    border-radius:16px 16px 0 0;
    max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
  }
  .mrow{grid-template-columns:1fr!important;}
  .modal-footer{flex-direction:column-reverse;gap:8px;padding-top:1rem;}
  .modal-footer .btn-ghost,.modal-footer .btn-blue{
    width:100%;text-align:center;justify-content:center;min-height:48px;
  }

  /* ── Klantdetail tabs ── */
  .ctabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;}
  .ctab{white-space:nowrap;flex-shrink:0;padding:10px 14px;font-size:11px;}

  /* ── Topbar ── */
  .topbar-big{padding:.875rem 1rem;flex-wrap:nowrap;gap:8px;}
  .topbar-big h1{font-size:16px;}
  .topbar-big p{font-size:11px;}

  /* ── Knoppen ── */
  .btn-blue,.btn-ghost,.btn-main{min-height:44px;}
  .cb-btns{flex-wrap:wrap;}

  /* ── Facturen/Offertes tabel ── */
  .tbl{font-size:12px;}
  .card{overflow:hidden;}
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — TELEFOON (max-width: 640px)
   — bestaande rules aangevuld hieronder
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:640px){
  /* ── Hamburger zichtbaar op mobiel ── */
  #mob-menu-btn{display:flex!important;}

  /* ── Pipeline kaartjes: volledig breed ── */
  [id^="pipeline-kanban-"] [style*="grid-template-columns"],
  [id^="portal-pipeline-items"] [style*="grid-template-columns"]{
    grid-template-columns:1fr!important;
  }
  /* Fase summary kaarten: 3 per rij op telefoon */
  .plcard-fase-summary{grid-template-columns:repeat(3,1fr)!important;}

  /* ── Portal bottom nav: alleen op portaal scherm ── */
  body[data-screen="s-portal"] #p-bottom-nav{display:flex!important;}
  .ptabs{display:none!important;}
  .p-out{display:none!important;}
  .portal-nav{padding:.75rem 1rem;}

  /* Bottom nav items */
  #p-bottom-nav{
    display:flex;
    position:fixed;bottom:0;left:0;right:0;z-index:200;
    background:var(--white);border-top:1.5px solid var(--border);
    padding:6px 8px max(8px,env(safe-area-inset-bottom));
    flex-direction:row;justify-content:space-around;align-items:center;
    gap:4px;
  }
  .p-bnav-item{
    display:flex;flex-direction:column;align-items:center;
    gap:2px;padding:6px 12px;border-radius:10px;
    font-size:9px;font-weight:700;color:var(--muted);
    background:none;border:none;cursor:pointer;
    transition:all .15s;font-family:'Montserrat',sans-serif;
    letter-spacing:.04em;text-transform:uppercase;
    flex:1;max-width:80px;
  }
  .p-bnav-item svg{width:20px;height:20px;}
  .p-bnav-item.active{color:var(--blue);}
  .p-bnav-item.active svg{stroke:var(--blue);}

  /* Extra padding onderaan portal body voor bottom nav */
  .portal-body{padding-bottom:80px!important;}
  .ptab-page{padding-bottom:80px;}

  /* ── Pipeline maand-selector op mobiel ── */
  #pipeline-month-sel-,
  [id^="pipeline-month-sel-"],
  [id^="portal-pipeline-month-"]{
    max-width:100%!important;width:100%!important;
  }
  [id^="pipeline-month-sel-"] + button{
    width:100%!important;
  }

  /* ── Portal dashboard grid: 1 kolom ── */
  #p-dashboard-grid{grid-template-columns:1fr!important;}

  /* ── Video embed op smal scherm ── */
  .plcard-embed-wrap{padding-top:56.25%;}

  /* ── Script modal fields ── */
  [style*="grid-template-columns:1fr 1fr 1fr"]{
    grid-template-columns:1fr!important;
  }

  /* ── KPI grid: 2 kolommen ── */
  .kpi-grid{grid-template-columns:repeat(2,1fr)!important;}

  /* ── Fase summary 3 kolommen ── */
  #ctab-cpipeline > div:first-child{
    grid-template-columns:repeat(3,1fr)!important;
  }
}

/* ── Portal bottom nav: standaard verborgen (desktop) ── */
#p-bottom-nav{display:none;}
