:root{font-family:Arial,Helvetica,sans-serif;color:#172033;background:#f4f6f8}body{margin:0}header{background:#17324d;color:white;padding:16px 22px}h1{margin:0 0 10px}nav{display:flex;gap:10px;flex-wrap:wrap}nav a,.button{color:white;background:#2d5d88;text-decoration:none;padding:9px 12px;border-radius:8px;display:inline-block}.secondary{background:#6b7280}.card{background:white;margin:18px auto;padding:18px;border-radius:14px;max-width:1200px;box-shadow:0 2px 10px #0001}.filters{display:flex;gap:10px;flex-wrap:wrap}.filters input{min-width:240px}input,select,textarea,button{font:inherit;padding:10px;border:1px solid #ccd3dd;border-radius:8px}button{background:#1f6feb;color:white;border:0;cursor:pointer}.danger{background:#c73737;padding:6px 8px}.grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:14px}.grid label{display:flex;flex-direction:column;gap:6px}.wide{grid-column:1/-1}textarea{min-height:90px}.table{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid #e4e7eb;padding:10px;text-align:left;vertical-align:top}.actions{display:flex;gap:8px;flex-wrap:wrap}.actions form{display:inline}.status{background:#eef4ff;border-radius:999px;padding:4px 8px}.flash{background:#e6ffed;border:1px solid #b8ebc6;padding:10px;border-radius:8px;margin-bottom:12px}.muted{opacity:.45}.ride{border:1px solid #dce3ea;border-radius:14px;padding:14px;margin:12px 0;background:#fbfcff}.ride h3{margin-top:0}@media(max-width:700px){header{padding:12px}.card{margin:10px;padding:12px;border-radius:10px}.grid{grid-template-columns:1fr}.filters input,.filters select,.filters button{width:100%;min-width:0}table,thead,tbody,tr,td,th{display:block}thead{display:none}td{border-bottom:0;padding:6px 0}.actions{margin-top:10px}nav a{flex:1;text-align:center}}

.calendar{max-width:1400px;margin:18px auto;display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.daycol{background:white;border-radius:14px;padding:12px;box-shadow:0 2px 10px #0001;min-height:420px}.daytitle{font-weight:bold;background:#17324d;color:white;border-radius:10px;padding:10px;margin-bottom:10px}.daytitle small{font-weight:normal;opacity:.9}.appt{border-left:5px solid #2d5d88;background:#f7fbff;border-radius:10px;padding:10px;margin:10px 0}.appt .time{font-weight:bold;color:#17324d}.appt.geannuleerd{opacity:.55}.note{background:#fff7db;border-radius:8px;padding:7px;margin-top:7px}.empty{color:#6b7280;padding:18px 8px;border:1px dashed #ccd3dd;border-radius:10px;text-align:center}.weeknav{display:flex;gap:10px;flex-wrap:wrap}.addlink{display:block;text-align:center;margin-top:12px;text-decoration:none;background:#eef4ff;color:#17324d;padding:9px;border-radius:8px}@media(max-width:1000px){.calendar{grid-template-columns:1fr}.daycol{min-height:0}}
.status.status-aangevraagd,.appt.aangevraagd,.ride.status-aangevraagd{background:#fff3d6;border-color:#f59e0b}.status.status-bevestigd,.appt.bevestigd,.ride.status-bevestigd{background:#e7f8ed;border-color:#22a35a}.status.status-geannuleerd,.appt.geannuleerd,.ride.status-geannuleerd{background:#ffe4e6;border-color:#dc2626;color:#7f1d1d;opacity:1}.status.status-afgerond,.appt.afgerond,.ride.status-afgerond{background:#eef2f7;border-color:#64748b}.live-indicator{display:inline-flex;align-items:center;padding:10px 12px;border-radius:999px;background:#e7f8ed;color:#166534;font-weight:bold}.ride{border-left:6px solid #2d5d88}.appt{border-left-width:6px}.status{display:inline-block}.status-aangevraagd{color:#92400e}.status-bevestigd{color:#166534}.status-geannuleerd{color:#991b1b}.status-afgerond{color:#334155}

.return-box{border:1px solid #d7dee8;border-radius:12px;padding:14px;background:#f8fafc}.check{display:flex;gap:10px;align-items:center}.nested{margin-top:12px}.appt .time small{font-weight:400}.status-retour{background:#dbeafe;color:#1e3a8a}

.button.small{font-size:.9em;padding:6px 8px;margin:2px 0}

.appt.combo,.mobile-trip.combo{border-left:6px solid #f59e0b;background:#fff7ed}
.status-combo{background:#f59e0b;color:#111827}
.passenger-box{border:1px solid #ddd;border-radius:12px;padding:12px;background:#fafafa;margin:8px 0}
.nav-combo,.combo-button,.combo-add{background:#f59e0b!important;color:#111827!important;font-weight:bold}.quick-actions{display:flex;gap:10px;flex-wrap:wrap}.hint{color:#475569}.row-combo{background:#fff7ed}.combo-add{margin-top:6px}.appt.blocked{border-left-color:#6b7280;background:#f3f4f6}
.combo-group{border-left:6px solid #f59e0b;background:#fff7ed}
.combo-list{margin:.5rem 0;padding-left:1.2rem}
.combo-list li{margin:.35rem 0;padding:.35rem;background:rgba(255,255,255,.65);border-radius:.4rem}
.seat-info{display:inline-block;margin:.25rem 0;padding:.15rem .45rem;border-radius:999px;background:#ffedd5;color:#9a3412;font-weight:700}
.button.small{display:inline-block;padding:.35rem .55rem;font-size:.9rem;margin-top:.35rem}
.timeline-calendar .daycol{min-width:260px}
.time-row{display:grid;grid-template-columns:48px 1fr;gap:8px;border-bottom:1px solid #e6e6e6;min-height:34px;padding:4px 0}
.slot-label{font-size:12px;color:#666;padding-top:4px;text-align:right}
.slot-content{min-width:0}
.slot-free{display:block;border:1px dashed #cfd8dc;border-radius:8px;padding:5px 8px;color:#668;text-decoration:none;background:#fafafa;font-size:12px}
.slot-free:hover{background:#eef7ff}
.busy-mini,.blocked-mini{font-size:12px;border-radius:8px;padding:5px 8px;color:#666;background:#f7f7f7}
.blocked-mini{background:#ffe5e5;color:#8a1f1f}
.inline-form{display:inline;margin-left:6px}.small{font-size:12px;padding:4px 8px}.danger{background:#b3261e!important;color:white!important;border:0;border-radius:8px;padding:7px 10px}.delete-cancelled{margin-top:14px}
select option:disabled{color:#aaa;background:#f3f3f3}
.autocomplete-wrap{position:relative;display:block}
.autocomplete-wrap input{width:100%;box-sizing:border-box}
.autocomplete-box{position:absolute;left:0;right:0;top:100%;z-index:50;background:white;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 10px 25px rgba(15,23,42,.16);max-height:260px;overflow:auto;margin-top:4px}
.autocomplete-item{display:block;width:100%;text-align:left;background:white;color:#172033;border:0;border-bottom:1px solid #eef2f7;border-radius:0;padding:10px;cursor:pointer}
.autocomplete-item:hover{background:#eef6ff}.autocomplete-item.muted{color:#64748b;cursor:default}

/* Bevestigde vaste ritreeksen blauw tonen */
.appt.series-confirmed,
tr.row-series-confirmed,
.mobile-trip.series-confirmed{
  background:#e8f1ff!important;
  border-left-color:#2563eb!important;
}
tr.row-series-confirmed td{background:#e8f1ff!important}
.series-label{display:inline-block;background:#2563eb;color:white;border-radius:999px;padding:2px 7px;font-size:12px;margin-left:4px}
a.danger{background:#b3261e!important;color:white!important}
.userbar{font-size:14px;margin:6px 0 10px 0;opacity:.9}.login-card{max-width:520px;margin:30px auto}.check{display:block;margin:6px 0}fieldset{border:1px solid #ddd;border-radius:10px;padding:12px;margin-top:10px}button.small,.button.small{font-size:12px;padding:5px 8px}.danger{background:#c62828;color:white;border-color:#c62828}

/* Login layout fix */
.login-page{
  min-height:calc(100vh - 120px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.login-panel{
  width:100%;
  max-width:430px;
  background:#fff;
  border-radius:18px;
  padding:28px;
  box-shadow:0 18px 50px rgba(15,23,42,.12);
  border:1px solid #e5e7eb;
}
.login-logo{
  display:inline-block;
  background:#17324d;
  color:#fff;
  border-radius:999px;
  padding:8px 14px;
  font-weight:700;
  margin-bottom:12px;
}
.login-panel h2{margin:0 0 6px 0}
.login-form{display:grid;gap:14px;margin-top:18px}
.login-form label{display:grid;gap:6px;font-weight:700}
.login-form input{width:100%;box-sizing:border-box}
.login-button{width:100%;padding:12px;margin-top:4px;font-weight:700}
.login-help{margin:16px 0 0 0;color:#475569;font-size:14px}

/* Dorpsauto flyer stijl: turquoise/oranje/wit */
:root{--dorps-turquoise:#04abc7;--dorps-teal:#007889;--dorps-orange:#ee7416;--dorps-dark:#073b4a;--dorps-light:#e9f7fa}
header{background:linear-gradient(135deg,var(--dorps-turquoise),var(--dorps-teal));border-bottom:8px solid var(--dorps-orange)}
.brandline{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:10px}.brandline h1{letter-spacing:1px;font-size:36px;margin:0;color:white}.brandline span{text-transform:uppercase;font-weight:700;color:white;opacity:.95;margin-bottom:7px}.userbar{color:white}.userbar a{color:white}nav a,.button,button{background:var(--dorps-teal)}.nav-combo,.combo-button,.combo-add{background:var(--dorps-orange)!important;color:white!important}.daytitle{background:var(--dorps-teal)}.login-logo{background:var(--dorps-turquoise)}.card{border-top:4px solid var(--dorps-turquoise)}.mobile-only h2{color:var(--dorps-teal)}.live-indicator{background:var(--dorps-light);color:var(--dorps-teal)}
body.chauffeur-view nav{display:none}.mobile-only{max-width:900px}.mobile-only .filters{align-items:center}.mobile-only select,.mobile-only input{min-width:220px}.ride{border-left-color:var(--dorps-teal)}
.badge{display:inline-block;background:var(--dorps-orange);color:white;border-radius:999px;min-width:20px;padding:2px 6px;text-align:center;font-size:12px;font-weight:700}.notification-row.open td{background:#fff7ed}.notification-row.done{opacity:.65}.button.active{outline:3px solid rgba(238,116,22,.25)}
.table-wrap{overflow:auto}.nowrap{white-space:nowrap}.pill{display:inline-block;background:var(--dorps-light);color:var(--dorps-teal);border-radius:999px;padding:3px 8px;font-weight:700;font-size:12px}details pre{white-space:pre-wrap;max-width:460px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:8px;font-size:12px}.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:end}.grid-form .actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.page-head{margin-bottom:14px}.page-head h2{margin-bottom:4px}.page-head p{color:#475569;margin-top:0}
.choice-panel{max-width:720px}.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:18px}.choice-button{display:grid;gap:6px;text-align:left;border-radius:16px;padding:20px;min-height:120px;background:var(--dorps-teal);color:white;border:0}.choice-button strong{font-size:20px}.choice-button span{opacity:.9}.secondary-choice{background:var(--dorps-orange)!important}.required{color:#b3261e;font-weight:700}

/* Overzichtelijk hoofdmenu: neutraal, kleur pas bij hover/actief */
.main-nav{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:8px}
.main-nav a,.main-nav button{font:inherit}
.nav-item,.nav-dropdown-menu a{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.14)!important;color:white!important;
  border:1px solid rgba(255,255,255,.18);border-radius:10px;
  padding:9px 12px;text-decoration:none;line-height:1.15;cursor:pointer;
  transition:background .18s ease,color .18s ease,transform .18s ease,border-color .18s ease;
}
.nav-icon{filter:grayscale(1);opacity:.9;transition:filter .18s ease,transform .18s ease,opacity .18s ease}
.nav-item:hover,.nav-dropdown-menu a:hover,.nav-dropdown:focus-within>.nav-dropbtn{
  background:white!important;color:var(--dorps-teal)!important;border-color:white;transform:translateY(-1px);
}
.nav-item:hover .nav-icon,.nav-dropdown-menu a:hover .nav-icon,.nav-dropdown:focus-within>.nav-dropbtn .nav-icon{
  filter:none;opacity:1;transform:scale(1.08);
}
.nav-dropdown{position:relative;display:inline-flex}
.nav-dropbtn{border:0}
.chevron{font-size:12px;opacity:.8;margin-left:2px}
.nav-dropdown-menu{
  display:none;position:absolute;top:calc(100% + 8px);left:0;z-index:1000;
  min-width:230px;background:white;border:1px solid #dbe3ec;border-radius:14px;
  box-shadow:0 16px 38px rgba(15,23,42,.2);padding:8px;
}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{display:grid;gap:6px}
.nav-dropdown-menu a{color:#17324d!important;background:white!important;border-color:transparent;justify-content:flex-start;width:100%;box-sizing:border-box}
.nav-dropdown-menu a:hover{background:var(--dorps-light)!important;color:var(--dorps-teal)!important;border-color:#bfeef5;transform:none}
/* Combinatierit niet standaard oranje; alleen hover/actief krijgt kleur */
.nav-combo{background:rgba(255,255,255,.14)!important;color:white!important;font-weight:inherit!important}
.nav-combo:hover{background:white!important;color:var(--dorps-teal)!important}
.combo-button,.combo-add{background:var(--dorps-teal)!important;color:white!important}
.combo-button:hover,.combo-add:hover{background:var(--dorps-orange)!important;color:white!important}
@media(max-width:800px){
  .main-nav{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .nav-dropdown{display:block;position:relative}
  .nav-item,.nav-dropbtn{width:100%;justify-content:center;box-sizing:border-box}
  .nav-dropdown-menu{position:static;margin-top:6px;box-shadow:none;border-color:rgba(255,255,255,.25)}
  .nav-dropdown-menu a{justify-content:flex-start;text-align:left}
}


/* Definitieve menu-opbouw: logisch, rustig, hover opent direct */
.clean-nav{gap:10px;align-items:center}
.clean-nav .nav-home{background:white!important;color:var(--dorps-teal)!important;font-weight:800;border-color:white}
.clean-nav .nav-driver{margin-left:auto;background:rgba(255,255,255,.10)!important}
.nav-dropdown{position:relative;padding-bottom:10px;margin-bottom:-10px}
.nav-dropdown::after{content:"";position:absolute;left:0;right:0;top:100%;height:12px}
.nav-dropdown-menu{top:calc(100% + 2px);min-width:285px;grid-template-columns:1fr;gap:5px}
.nav-dropdown-menu.align-right{right:0;left:auto}
.nav-dropdown-menu a span:last-child{display:grid;gap:2px}
.nav-dropdown-menu a small{font-size:12px;color:#64748b;font-weight:400;line-height:1.2}
.nav-dropdown-menu a:hover small{color:var(--dorps-teal)}
.nav-item,.nav-dropdown-menu a{box-shadow:none}
.nav-item:focus-visible,.nav-dropdown-menu a:focus-visible{outline:3px solid rgba(255,255,255,.55);outline-offset:2px}
.nav-dropdown-menu a:focus-visible{outline-color:rgba(4,171,199,.35)}
.nav-dropbtn .badge{margin-left:2px}

.agenda-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:12px}
.action-menu{position:relative;display:inline-block;padding-bottom:10px;margin-bottom:-10px}
.action-menu::after{content:"";position:absolute;left:0;right:0;top:100%;height:12px}
.action-menu .action-menu-list{display:none;position:absolute;right:0;top:calc(100% + 2px);z-index:900;background:white;border:1px solid #dbe3ec;border-radius:14px;box-shadow:0 16px 38px rgba(15,23,42,.2);padding:8px;min-width:260px}
.action-menu:hover .action-menu-list,.action-menu:focus-within .action-menu-list{display:grid;gap:6px}
.action-menu-list a{display:grid;grid-template-columns:28px 1fr;gap:8px;align-items:center;text-decoration:none;color:#17324d;background:white;border-radius:10px;padding:10px}
.action-menu-list a:hover{background:var(--dorps-light);color:var(--dorps-teal)}
.action-menu-list small{display:block;color:#64748b;font-size:12px;margin-top:2px}

@media(max-width:800px){
  .clean-nav .nav-driver{margin-left:0}
  .nav-dropdown{padding-bottom:0;margin-bottom:0}
  .nav-dropdown::after{display:none}
  .nav-dropdown-menu{min-width:0}
  .action-menu,.action-menu .button{width:100%}
  .action-menu .action-menu-list{position:static;margin-top:6px;box-shadow:none;min-width:0}
}
