:root{--blue:#4168b2;--orange:#ff9818;--green:#75bf48;--yellow:#ffc20e;--bg:#f7f9fd;--line:#e4e9f2;--text:#101a2f;--muted:#64748b}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:var(--blue);text-decoration:none}.brand{font-size:54px;font-weight:500;letter-spacing:-5px;line-height:1}.brand span:nth-child(1){color:var(--blue)}.brand span:nth-child(2){color:var(--green)}.brand span:nth-child(3){color:var(--orange)}.brand:before{content:'•••';display:block;color:var(--yellow);font-size:22px;letter-spacing:9px;margin-left:37px;margin-bottom:-12px}.login{display:grid;place-items:center;min-height:100vh;background:white}.login-card{width:390px;background:white;border:1px solid var(--line);border-radius:18px;padding:34px;box-shadow:0 20px 60px #15233b14}.login-card h1{margin:25px 0 8px}.login-card p{color:var(--muted)}input{width:100%;padding:15px;border:1px solid var(--line);border-radius:10px;margin:14px 0;font-size:18px}button{border:0;border-radius:10px;padding:13px 18px;background:var(--blue);color:white;font-weight:700;cursor:pointer}.err{background:#fff2f2;color:#b91c1c;padding:12px;border-radius:10px}aside{position:fixed;left:0;top:0;bottom:0;width:255px;background:white;border-right:1px solid var(--line);padding:22px 15px}nav{margin-top:35px}nav a{display:block;padding:15px 18px;border-radius:10px;color:#17223a;margin:5px 0}nav a.active,nav a:hover{background:#eef4ff;color:var(--blue);font-weight:700}.foot{position:absolute;bottom:25px;color:var(--muted);left:28px}main{margin-left:255px}header{height:84px;background:white;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 34px}.dot{display:inline-block;width:10px;height:10px;background:#27c281;border-radius:50%}.layout{display:grid;grid-template-columns:1fr 430px;gap:20px;padding:24px}.list,.detail{background:white;border:1px solid var(--line);border-radius:14px;box-shadow:0 10px 30px #13233c08}.filters{padding:20px;border-bottom:1px solid var(--line)}.filters a{display:inline-block;border:1px solid var(--line);border-radius:9px;padding:11px 18px;margin-right:8px;background:white}.filters a:first-child{background:var(--blue);color:white}table{width:100%;border-collapse:collapse}th{font-size:12px;text-transform:uppercase;color:var(--muted);text-align:left;padding:18px}td{padding:18px;border-top:1px solid var(--line)}tr{cursor:pointer}tr:hover{background:#fafcff}.status{display:inline-block;border-radius:999px;padding:7px 13px;font-weight:700;font-size:13px;background:#eef4ff;color:var(--blue)}.status.pending{background:#ffefbd;color:#9a6400}.status.processing{background:#e6f0ff;color:#155bd6}.status.completed{background:#e8f7e2;color:#238631}.status.cancelled{background:#ffe6e8;color:#d92833}.detail{padding:25px}.detail-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:18px}.detail h2{color:var(--blue);margin:0}.detail h3{margin-top:24px}.detail p{line-height:1.8;color:#34425a}.prod,.total{display:flex;justify-content:space-between;gap:20px;padding:12px 0;border-bottom:1px solid var(--line)}.prod small{display:block;color:var(--muted);margin-top:4px}.total{font-size:18px;border:0;margin-top:10px}.actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:28px}.green{background:#30a23d}.blue{background:var(--blue)}.red{background:#ee4b55}.print{margin-top:12px;width:100%;background:white;color:#17223a;border:1px solid var(--line)}@media(max-width:1100px){aside{position:static;width:auto;height:auto}.foot{display:none}main{margin:0}.layout{grid-template-columns:1fr}.detail{order:-1}}@media print{aside,header,.filters,.actions,.print{display:none}main{margin:0}.layout{display:block}.list{display:none}.detail{border:0;box-shadow:none}}
.searchbar{display:flex;gap:10px;padding:20px 20px 0 20px;align-items:center}.searchbar input{margin:0;font-size:15px}.searchbar button{white-space:nowrap}.searchbar .clear{padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:white}.ai-box{border-top:1px solid var(--line);padding:22px}.ai-box h2{margin:0 0 8px}.ai-box p{color:var(--muted);margin:0 0 12px}.ai-box form{display:flex;gap:10px}.ai-box input{margin:0;font-size:15px}.ai-answer{margin-top:14px;background:#f7f9fd;border:1px solid var(--line);border-radius:12px;padding:15px;line-height:1.6}.print{display:block;text-align:center}.print-page{background:#edf1f7;padding:30px}.print-sheet{max-width:850px;margin:0 auto;background:white;border:1px solid var(--line);border-radius:12px;padding:35px}.print-top{display:flex;justify-content:space-between;gap:20px;align-items:flex-start}.print-total{text-align:right;font-size:22px;font-weight:800;margin-top:25px}.no-print{margin-top:25px}#busy{position:fixed;inset:0;background:rgba(255,255,255,.78);backdrop-filter:blur(3px);z-index:9999;display:none;place-items:center;text-align:center;font-weight:800;color:var(--blue)}body.loading #busy{display:grid}.sun{width:54px;height:54px;border-radius:50%;border:7px solid var(--yellow);border-top-color:var(--orange);animation:spin .8s linear infinite;margin:0 auto 14px}@keyframes spin{to{transform:rotate(360deg)}}@media print{.no-print,#busy{display:none!important}.print-page{background:white;padding:0}.print-sheet{border:0;border-radius:0;max-width:none;padding:0}.print-sheet table{width:100%;border-collapse:collapse}.print-sheet td,.print-sheet th{border-bottom:1px solid #ddd}}
/* v0.2.6 verbeteringen: sneller zoeken, bladerfunctie, aparte AI-pagina */
.filters a:first-child{background:white;color:var(--blue)}
.filters a.active-filter{background:var(--blue)!important;color:white!important}
.count{float:right;color:var(--muted);padding:11px 0;font-size:14px}.searchbar-big{padding:22px}.searchbar-big input{font-size:18px;padding:17px 18px}.searchbar-big button{padding:16px 24px}.pager{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px;border-top:1px solid var(--line)}.pager a{border:1px solid var(--line);background:white;border-radius:10px;padding:11px 16px}.pager span{color:var(--muted)}.busy-card{background:white;border:1px solid var(--line);border-radius:18px;padding:30px 40px;box-shadow:0 20px 70px #13233c18}.ai-page{padding:28px}.ai-panel{background:white;border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px #13233c08;padding:34px;max-width:1180px}.ai-panel h2{margin:0 0 10px;font-size:32px}.ai-panel p{color:var(--muted);font-size:17px}.ai-large-form{margin-top:24px}.ai-large-form textarea{width:100%;min-height:145px;border:1px solid var(--line);border-radius:14px;padding:20px;font-size:21px;font-family:inherit;resize:vertical}.ai-large-form button{margin-top:14px;font-size:17px;padding:16px 26px}.ai-answer-big{font-size:18px;margin-top:26px;padding:24px}.ai-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:20px}.ai-stats div{border:1px solid var(--line);border-radius:14px;padding:18px;background:#f7f9fd}.ai-stats b{display:block;font-size:24px}.ai-stats span{color:var(--muted)}
@media(max-width:800px){.searchbar{display:block}.searchbar button,.searchbar .clear{display:block;width:100%;margin-top:10px;text-align:center}.count{float:none;display:block}.ai-stats{grid-template-columns:1fr}.ai-panel{padding:22px}.ai-large-form textarea{font-size:18px}}
.searchbar .cachelink{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid #dbe5f2;border-radius:10px;padding:0 14px;color:#3f66b5;background:#fff;white-space:nowrap;font-weight:600}
.searchbar .cachelink:hover{background:#f5f8ff}
/* v0.2.9: complete klantgegevens en klantgeschiedenis */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:8px 0 18px}.info-grid>div{border:1px solid var(--line);background:#f9fbff;border-radius:12px;padding:12px}.info-grid label{display:block;font-size:12px;text-transform:uppercase;color:var(--muted);font-weight:800;margin-bottom:6px}.info-grid strong{font-size:15px;line-height:1.45}.info-grid .wide{grid-column:1/-1}.info-grid.compact strong{font-size:14px}.related{border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:18px}.related a{display:grid;grid-template-columns:90px 1fr 90px 100px;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line);color:var(--text);font-size:14px}.related a:last-child{border-bottom:0}.related a:hover{background:#f7f9fd}.related span{color:var(--muted)}.related em{font-style:normal;color:var(--blue);font-weight:700;text-align:right}@media(max-width:700px){.info-grid{grid-template-columns:1fr}.related a{grid-template-columns:1fr}.related em{text-align:left}}
/* v0.3.0: klantenoverzicht en bulk orderverwerking */
.checkcol{width:42px;text-align:center}.checkcol input{width:auto;margin:0;transform:scale(1.15)}.bulkform table tr td:not(.checkcol){cursor:pointer}.bulkbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 18px;border-top:1px solid var(--line);background:#fbfcff}.bulkbar span{color:var(--muted);font-weight:700;margin-right:6px}.bulkbar button{padding:10px 14px}.customer-orders a{grid-template-columns:100px 1fr 100px 120px}.list small{color:var(--muted)}
@media(max-width:700px){.bulkbar{display:grid;grid-template-columns:1fr}.bulkbar button{width:100%}.customer-orders a{grid-template-columns:1fr}}
/* v0.3.1: omzetpagina */
.revenue-page{padding:28px}.revenue-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;background:white;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:0 10px 30px #13233c08}.revenue-head h2{font-size:34px;margin:0 0 8px}.revenue-head p{margin:0;color:var(--muted)}.year-nav{display:flex;gap:10px;flex-wrap:wrap}.year-nav a{border:1px solid var(--line);border-radius:10px;padding:11px 15px;background:white;color:var(--blue);font-weight:700}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:18px 0}.kpi-grid div{background:white;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 10px 30px #13233c08}.kpi-grid span{display:block;color:var(--muted);font-weight:700;margin-bottom:8px}.kpi-grid b{font-size:23px}.chart-card,.revenue-table{background:white;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 10px 30px #13233c08;margin-top:18px}.chart-card h3{margin:0 0 20px}.bar-chart{height:330px;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px;align-items:end}.bar-item{height:100%;display:grid;grid-template-rows:auto 1fr auto;gap:8px;min-width:0}.bar-value{text-align:center;font-size:12px;color:var(--muted);white-space:nowrap;transform:rotate(-24deg);height:24px}.bar-track{position:relative;background:#f0f4fb;border:1px solid var(--line);border-radius:12px;overflow:hidden}.bar-fill{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,var(--orange),var(--yellow));border-radius:12px 12px 0 0}.bar-label{text-align:center;font-weight:800;color:#334155}.bar-label small{display:block;font-size:11px;color:var(--muted);font-weight:600;margin-top:3px}.revenue-table table tr{cursor:default}.revenue-table table tr:hover{background:transparent}@media(max-width:1050px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.bar-chart{overflow-x:auto;grid-template-columns:repeat(12,70px);padding-bottom:10px}.revenue-head{display:block}.year-nav{margin-top:16px}}@media(max-width:600px){.kpi-grid{grid-template-columns:1fr}.revenue-page{padding:16px}.revenue-head,.chart-card,.revenue-table{padding:18px}.bar-value{transform:none;font-size:11px}}
/* v0.3.6: sorteren en klant top 10 */
.sortbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:16px 20px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fbfcff}.sortbar span:first-child{font-weight:800;color:var(--muted);margin-right:4px}.sortbar a{border:1px solid var(--line);background:white;border-radius:10px;padding:9px 12px;color:var(--blue);font-weight:700}.sortbar a.active-sort{background:var(--blue);color:white;border-color:var(--blue)}.topcustomers{padding:18px 20px;border-bottom:1px solid var(--line);background:#fff}.topcustomers h3{margin:0 0 14px;font-size:18px}.topgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.topgrid a{display:grid;grid-template-columns:1fr auto;gap:4px 12px;border:1px solid var(--line);border-radius:12px;padding:12px;background:#f9fbff;color:var(--text)}.topgrid a:hover{background:#eef4ff}.topgrid b{grid-column:1/-1}.topgrid span,.topgrid small{color:var(--muted)}.topgrid strong{text-align:right;color:var(--blue)}@media(max-width:900px){.topgrid{grid-template-columns:1fr}.sortbar .count{width:100%}}

.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}
.info-grid>div{background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.info-grid .wide{grid-column:1/-1}
.info-grid label{display:block;font-size:12px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:10px;letter-spacing:.03em}
.info-grid strong{display:block;font-size:18px;line-height:1.5;color:#0f172a}
.info-grid.compact strong{font-size:20px}
.detail h3{margin:26px 0 12px;border-bottom:1px solid var(--line);padding-bottom:8px}
.related a{display:grid;grid-template-columns:80px 1fr 110px 110px;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);color:inherit}
.actions{position:sticky;bottom:0;background:white;padding-top:12px}

/* v0.3.9: orderdetail als kassabon/factuur, zonder blokkenbende */
.detail{padding:24px 28px}.detail-head{margin-bottom:18px}.detail h3{margin:0 0 10px;border:0;padding:0;font-size:18px;color:#0f172a}.receipt-block{padding:18px 0;border-bottom:1px solid var(--line)}.receipt-block:first-of-type{padding-top:6px}.receipt-lines{display:block}.receipt-line{display:grid;grid-template-columns:118px 1fr;gap:14px;align-items:start;padding:8px 0;border-bottom:1px dashed #dbe3ef}.receipt-line:last-child{border-bottom:0}.receipt-line span,.address-row span{font-size:12px;line-height:1.3;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:800}.receipt-line strong,.address-row strong{font-size:15px;line-height:1.45;color:#0f172a;font-weight:700;word-break:break-word}.address-lines{display:grid;gap:12px}.address-row{display:grid;grid-template-columns:118px 1fr;gap:14px;padding:10px 0;border-bottom:1px dashed #dbe3ef}.address-row:last-child{border-bottom:0}.total-line{margin-top:4px;padding-top:12px;border-top:2px solid var(--line);border-bottom:0}.total-line strong{font-size:18px}.prod{padding:11px 0;border-bottom:1px dashed #dbe3ef}.prod span{font-size:15px;line-height:1.35}.prod b{font-size:15px;white-space:nowrap}.total{border-top:2px solid var(--line);margin-top:12px;padding-top:14px}.actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.92),#fff);padding-top:14px;margin-top:18px}.print{border-radius:10px;padding:12px;margin-top:10px}.info-grid{display:block}.info-grid>div{background:transparent;border:0;border-radius:0;padding:0}.info-grid label,.info-grid strong{display:initial}
@media(max-width:700px){.detail{padding:20px}.receipt-line,.address-row{grid-template-columns:1fr;gap:4px}.receipt-line strong,.address-row strong{font-size:16px}.actions{grid-template-columns:1fr}.actions button{width:100%}}

/* v0.3.10 readability */ .receipt-line span,.address-row span{font-weight:600;display:block;margin-bottom:4px}.receipt-line strong,.address-row strong{font-weight:500;line-height:1.7}.receipt-line,.address-row{padding:12px 0}.detail{font-size:15px}.prod span,.prod b{font-weight:500}.detail h3{font-size:24px;margin-bottom:14px}.receipt-block{padding:22px 0} 
/* v0.3.11: rechter orderpaneel als rustige kassabon/factuur */
.receipt-panel{padding:28px 32px;line-height:1.55;font-size:15px;color:#17223a}
.receipt-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:6px}
.receipt-header h2{margin:2px 0 0;color:var(--blue);font-size:26px;line-height:1.15;font-weight:700}
.receipt-kicker{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
.receipt-section{padding:20px 0;border-bottom:1px solid var(--line)}
.receipt-section h3{margin:0 0 11px!important;padding:0!important;border:0!important;font-size:17px!important;line-height:1.25;color:#0f172a;font-weight:700}
.receipt-section div{font-weight:400;line-height:1.55;margin:0;color:#101a2f}
.receipt-name{font-size:18px;font-weight:700!important;margin-bottom:2px!important;color:#0f172a!important}
.receipt-muted{color:#3d4b63!important;font-weight:400!important;word-break:break-word}
.receipt-meta dl{margin:0;display:grid;gap:7px}
.receipt-meta dl>div{display:grid;grid-template-columns:128px minmax(0,1fr);gap:14px;align-items:start;margin:0}
.receipt-meta dt{font-size:14px;color:var(--muted);font-weight:400;margin:0}
.receipt-meta dd{font-size:14px;color:#0f172a;font-weight:500;margin:0;word-break:break-word}
.receipt-products{display:grid;gap:0;margin-top:4px}
.receipt-product{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:start;padding:12px 0;border-bottom:1px dashed #dbe3ef}
.receipt-product span{display:block;font-size:15px;line-height:1.45;font-weight:400;color:#0f172a}
.receipt-product small{display:block;margin-top:2px;color:var(--muted);font-size:13px;font-weight:400}
.receipt-product strong{white-space:nowrap;font-size:15px;line-height:1.45;font-weight:600;color:#0f172a}
.receipt-grandtotal{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;margin-top:14px;padding-top:14px;border-top:2px solid var(--line);font-size:18px}
.receipt-grandtotal span{font-weight:700!important;color:#0f172a!important}
.receipt-grandtotal strong{font-weight:700;color:#0f172a}
.receipt-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.9),#fff);padding-top:16px;margin-top:16px}
.receipt-panel .print{display:block;text-align:center;border-radius:10px;padding:13px 16px;margin-top:10px;background:white;color:#17223a;border:1px solid var(--line);font-weight:600}
.receipt-panel .related a{display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px dashed #dbe3ef;color:#17223a}
.receipt-panel .related a:last-child{border-bottom:0}
.receipt-panel .related b,.receipt-panel .related span,.receipt-panel .related em{font-size:13px;font-weight:400;font-style:normal}
@media(max-width:700px){.receipt-panel{padding:22px}.receipt-meta dl>div{grid-template-columns:1fr;gap:1px}.receipt-actions{grid-template-columns:1fr}.receipt-panel .related a{grid-template-columns:1fr auto}}


/* v0.4.1 fase 1 afronding */
.dashboard-page{padding:28px}
.dash-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:20px}
.dash-card{background:white;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 8px 24px #13233c08}
.dash-card span{display:block;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.dash-card b{display:block;font-size:28px;font-weight:650;letter-spacing:-.02em}
.dash-card small{display:block;color:var(--muted);margin-top:8px}
.dash-card.accent{border-color:#d7e4ff;background:linear-gradient(180deg,#ffffff,#f5f8ff)}
.dash-two{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:20px}
.dash-panel{background:white;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 8px 24px #13233c08}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.panel-head h2{margin:0;font-size:20px;font-weight:650}
.panel-head span,.panel-head a{color:var(--muted);font-size:14px}
.mini-chart{height:210px;display:flex;align-items:flex-end;gap:5px;border-bottom:1px solid var(--line);padding-top:10px}
.mini-chart div{flex:1;height:100%;display:flex;align-items:flex-end}
.mini-chart i{display:block;width:100%;background:#4168b2;border-radius:8px 8px 0 0;min-height:4px;opacity:.82}
.top-one b{display:block;font-size:22px;font-weight:650;margin-bottom:12px}
.top-one span{display:block;font-size:30px;font-weight:650;color:var(--blue);margin-bottom:8px}
.top-one small{color:var(--muted)}
.receipt-section div,.receipt-section dd,.receipt-section p{font-weight:400!important;line-height:1.65}
.receipt-section h3{font-weight:650;letter-spacing:.03em}
.detail b,.list b{font-weight:650}
@media(max-width:1100px){.dash-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-two{grid-template-columns:1fr}}
@media(max-width:700px){.dash-grid{grid-template-columns:1fr}.dashboard-page{padding:16px}}
