:root{--sings-red:#e02b20;--sings-dark:#151b26;--sings-bluebar:#2f3a4a;--sings-copy:#2d3748;--sings-muted:#4a5568;--sings-bg:#f7fafc;--sings-border:#c0c0c0}*{box-sizing:border-box}body.sings-page{margin:0;background:var(--sings-bg);color:var(--sings-copy);font-family:-apple-system,"system-ui","Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;font-size:17px;line-height:1.5}.skip-link{position:absolute;left:-999px;top:auto}.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:5}.site-shell{max-width:1280px;margin:0 auto;padding:0 24px}.site-header{height:119px;background:#fff;border:0;box-shadow:none}.header-inner{height:119px;display:grid;grid-template-columns:260px 1fr 229px;align-items:center;gap:0}.brand{display:flex;align-items:center;height:119px;text-decoration:none}.brand-logo{width:160px;height:102px;object-fit:contain;display:block}.brand-mark,.brand-text{display:none}.primary-nav{height:119px;display:flex;justify-content:center;align-items:center;gap:0}.primary-nav a{color:var(--sings-muted);text-decoration:none;font-size:20px;font-weight:400;padding:12px;line-height:32px}.primary-nav a:hover{color:var(--sings-red)}.appointment-cta{display:flex;align-items:center;justify-content:center;height:119px;width:229px;background:var(--sings-red);color:#fff;text-decoration:none;font-size:18px;font-weight:400;text-transform:uppercase;letter-spacing:0;padding:0;border-radius:0}.appointment-cta:hover{background:var(--sings-red)}.booking-page{max-width:none;margin:0;padding:80px 24px 81px;background:var(--sings-bg);min-height:619px}.booking-card{width:min(100%,1232px);margin:0 auto;background:#fff;border:1px solid #ddd;border-radius:4px;padding:0 0 0;box-shadow:none;min-height:457px}.bookly-steps{display:grid;grid-template-columns:repeat(5,1fr);list-style:none;margin:0;padding:24px 24px 0}.bookly-steps .step{position:relative;background:transparent;border:0;color:var(--sings-copy);font-size:14px;font-weight:700;text-align:left;padding:0 0 22px 4px;height:42px}.bookly-steps .step:first-child{padding-left:0}.bookly-steps .step::after{content:"";position:absolute;left:0;right:4px;bottom:0;height:15px;background:#bfc4c8;border-radius:3px}.bookly-steps .step.active{background:transparent;color:var(--sings-red)}.bookly-steps .step.active::after{background:var(--sings-red)}.bookly-steps .step span{font-weight:700;margin-right:3px}.bookly-panel{padding:0 24px}.bookly-panel.hidden{display:none}.section-title{font-size:14px;font-weight:700;margin:16px 0 16px;color:var(--sings-copy)}.bookly-form-grid{display:grid;grid-template-columns:repeat(4,269px);grid-template-rows:22px 28px;gap:5px 14px;align-items:start}.bookly-form-grid label{grid-row:1;color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px}.bookly-form-grid select{grid-row:2}select,input,textarea{font-family:inherit;font-size:14px;color:var(--sings-copy);border:1px solid var(--sings-border);border-radius:4px;background:#fff;height:28px;padding:5px 6px 4px;box-shadow:none}textarea{height:auto;min-height:58px;resize:vertical}.outline-button{margin:20px 0 0 0;width:306px;height:35px;background:var(--sings-red);border:0;border-radius:4px;color:#fff;font-size:18px;font-weight:700;line-height:17px;padding:9px 18px;text-align:center;cursor:pointer}.primary-button{background:var(--sings-red);color:#fff;border:0;border-radius:4px;height:35px;font-size:18px;font-weight:700;line-height:17px;padding:9px 18px;cursor:pointer;text-transform:uppercase;float:right;margin-top:20px}.primary-button:hover,.outline-button:hover{background:var(--sings-red)}.text-button{background:transparent;border:0;color:var(--sings-muted);text-decoration:underline;cursor:pointer;margin-top:24px}.time-table{border:0;padding:20px 0 0;margin:0;display:grid;grid-template-columns:589px 1fr}.date-row{display:grid;grid-template-columns:231px repeat(6,23px);grid-template-rows:22px 30px;gap:4px 12px;align-items:start}.date-row label{grid-column:1;color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px}.date-row input{grid-column:1;grid-row:2;width:231px;height:30px;background:#fff;color:var(--sings-muted);padding:6px 7px 5px}.weekday-row{display:contents}.weekday-row label{display:grid;grid-row:1 / span 2;grid-template-rows:22px 30px;justify-items:center;align-items:start;color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px}.weekday-row label:nth-child(1){grid-column:2}.weekday-row label:nth-child(2){grid-column:3}.weekday-row label:nth-child(3){grid-column:4}.weekday-row label:nth-child(4){grid-column:5}.weekday-row label:nth-child(5){grid-column:6}.weekday-row label:nth-child(6){grid-column:7}.weekday-row input{appearance:none;-webkit-appearance:none;grid-row:2;width:23px;height:23px;min-height:0;border:0;border-radius:50%;background:var(--sings-red);position:relative;margin-top:3px}.weekday-row input::after{content:"✓";position:absolute;left:5px;top:0;color:#fff;font-size:15px;font-weight:700;line-height:23px}.from-to-row{display:grid;grid-template-columns:32px 53px 26px 53px;grid-template-rows:22px 28px;gap:5px 8px;align-items:start;margin:0;justify-content:start}.from-to-row label{color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px}.from-to-row label[for="fromTime"]{grid-column:1}.from-to-row label[for="toTime"]{grid-column:3}.from-to-row select{width:60px;height:28px}.slot-results{clear:both;margin-top:20px;border:0;background:transparent;padding:0;min-height:0;color:var(--sings-muted)}.slot-results .muted{font-size:14px;margin:0;color:var(--sings-muted)}.slot-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}.slot-card{border:1px solid var(--sings-border);background:#fff;padding:8px;cursor:pointer;border-radius:4px;font-size:14px}.slot-card.selected{outline:2px solid var(--sings-red);border-color:var(--sings-red)}.muted{color:var(--sings-muted)}.booking-summary{background:#fff;border:1px solid #ddd;border-radius:4px;padding:14px;margin-top:18px;line-height:1.7}.confirm-line{display:block;margin-top:18px;color:var(--sings-copy)}.confirm-line input{width:auto;height:auto}.result-box{padding:18px;border-radius:4px;background:#fff;border:1px solid #ddd}.ok{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:14px}.err{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:14px}.bookly-panel[data-panel="time"]{border-bottom:1px solid #ccc;margin:0 24px 0;padding:0 0 20px}.bookly-panel[data-panel="time"] .primary-button{margin-right:0}.site-footer{margin:0;padding:0;background:transparent;color:#fff}.footer-main{background:var(--sings-dark);min-height:360px;padding:34px 0 42px}.footer-grid{display:grid;grid-template-columns:1.45fr .75fr .85fr;gap:55px}.site-footer h2{margin:0 0 18px;color:var(--sings-red);font-size:28px;line-height:1.25;font-weight:700}.site-footer p,.site-footer li,.site-footer a{color:#fff;font-size:17px;font-weight:400;line-height:1.7;text-decoration:none}.site-footer ul{margin:0;padding-left:20px}.staff-login ul{padding-left:0;list-style:none}.staff-login li:first-child{margin-bottom:8px}.footer-linkbar{height:96px;background:var(--sings-bluebar);display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}.footer-linkbar a{color:#fff;font-size:17px;padding:5px 10px}.copyright{height:110px;margin:0;background:#232323;color:#bfccd8;display:flex;align-items:center;justify-content:center;text-align:center;font-size:15px}.copyright u{color:#bfccd8}.small-note{font-size:12px;color:#777}@media(max-width:900px){.header-inner{grid-template-columns:170px 1fr;grid-template-rows:80px auto;height:auto}.site-header{height:auto}.brand{height:80px}.brand-logo{width:130px;height:auto}.primary-nav{height:auto;justify-content:flex-start;flex-wrap:wrap;grid-column:1/3;padding-bottom:12px}.appointment-cta{position:absolute;right:0;top:0;height:80px;width:170px}.booking-page{padding:30px 12px}.bookly-steps{grid-template-columns:1fr}.bookly-form-grid{grid-template-columns:1fr;grid-template-rows:auto}.bookly-form-grid label,.bookly-form-grid select{grid-row:auto}.time-table{grid-template-columns:1fr}.date-row{grid-template-columns:231px repeat(3,23px)}.from-to-row{margin-top:12px}.footer-grid{grid-template-columns:1fr}.footer-main{padding:30px 0}.primary-button{float:none}}
.slot-results:not(.has-content){display:none}.outline-button,.primary-button{white-space:nowrap;overflow:hidden}.footer-main{min-height:360px;padding:34px 0 22px}.site-footer p,.site-footer li,.site-footer a{line-height:1.55}.site-footer{min-height:572px}
/* Jeroen QA fixes: keep beschikbare periode, weekdays, Van/Tot on one Bookly-like line. */
.time-table{display:grid;grid-template-columns:260px repeat(6,23px) 190px;grid-template-rows:22px 30px;column-gap:4px;row-gap:4px;align-items:start;padding:20px 0 0;margin:0;border:0;width:max-content;max-width:100%}
.date-row,.weekday-row{display:contents}
.date-row label{grid-column:1;grid-row:1;color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px}
.date-row input{grid-column:1;grid-row:2;width:231px;height:30px;background:#fff;color:var(--sings-muted);padding:6px 7px 5px}
.weekday-row label{display:grid;grid-row:1 / span 2;grid-template-rows:22px 30px;justify-items:center;align-items:start;color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px;cursor:pointer;width:23px}
.weekday-row label:nth-child(1){grid-column:2}.weekday-row label:nth-child(2){grid-column:3}.weekday-row label:nth-child(3){grid-column:4}.weekday-row label:nth-child(4){grid-column:5}.weekday-row label:nth-child(5){grid-column:6}.weekday-row label:nth-child(6){grid-column:7}
.weekday-row input{appearance:none;-webkit-appearance:none;grid-row:2;width:23px;height:23px;min-height:0;border:1px solid #c9c9c9;border-radius:50%;background:#fff;position:relative;margin:3px 0 0;padding:0;cursor:pointer}
.weekday-row input:checked{border-color:var(--sings-red);background:var(--sings-red)}
.weekday-row input::after{content:"";position:absolute;left:5px;top:0;color:#fff;font-size:15px;font-weight:700;line-height:21px}
.weekday-row input:checked::after{content:"✓"}
.from-to-row{grid-column:8;grid-row:1 / span 2;display:grid;grid-template-columns:28px 60px 22px 60px;grid-template-rows:22px 28px;gap:5px 8px;align-items:start;margin:0;justify-content:start;width:190px}
.from-to-row label{color:var(--sings-red);font-size:14px;font-weight:700;line-height:22px}.from-to-row label[for="fromTime"]{grid-column:1;grid-row:1}.from-to-row label[for="toTime"]{grid-column:3;grid-row:1}.from-to-row select{width:60px;height:28px}.from-to-row #fromTime{grid-column:2;grid-row:2}.from-to-row #toTime{grid-column:4;grid-row:2}
@media (max-width:720px){.time-table{width:100%;grid-template-columns:260px repeat(6,23px);overflow-x:auto}.from-to-row{grid-column:1 / -1;grid-row:3;margin-top:10px}}

/* Existing admin/simulator compatibility */header:not(.site-header){background:#111827;color:white;padding:28px 40px}main:not(.booking-page){max-width:1100px;margin:24px auto;padding:0 20px}.card{background:white;border-radius:18px;padding:22px;margin:16px 0;box-shadow:0 8px 30px #0001}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.pill{display:inline-block;background:#e0f2fe;color:#075985;padding:4px 8px;border-radius:999px;margin:2px}table{width:100%;border-collapse:collapse;background:white}td,th{padding:9px;border-bottom:1px solid #eee;text-align:left}.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:20px}.nav a{color:white;margin-right:14px}.transcript{background:#111827;color:#d1fae5;border-radius:12px;padding:14px;min-height:160px;white-space:pre-wrap}.stat{font-size:30px;font-weight:900}
