/* Basisstijl + kleurstelling aangepast naar equitruck look & feel */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&family=Playfair+Display:wght@400;700&display=swap');

:root{
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  --brand: #0e2b4a;
  --accent: #2c67b3;
  --muted: #6b7280;
  --bg: #ffffff;
  --card-shadow: 0 8px 24px rgba(14,43,74,0.06);
}

*{box-sizing:border-box}
body{font-family:var(--font-sans);margin:0;background:#f6f7fb;color:#0b1730;line-height:1.45}
.container{max-width:1100px;margin:24px auto;padding:0 16px}
.card{background:var(--bg);padding:18px;border-radius:10px;box-shadow:var(--card-shadow);overflow:hidden}
.site-header{background:#fff;border-bottom:1px solid #eef2f6}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.logo{height:44px}
.brand{display:flex;align-items:center;text-decoration:none}
.main-nav a{margin-left:16px;color:var(--brand);text-decoration:none;font-weight:600}
.hero{display:flex;align-items:center;padding:20px}
.hero-inner{display:flex;gap:18px}
.hero-left{flex:1}
.hero-right{flex:1;display:flex;flex-direction:column;gap:18px}
.lead{font-size:1.05rem;color:var(--muted)}
.btn{display:inline-block;padding:8px 12px;background:var(--accent);color:#fff;border-radius:8px;text-decoration:none;font-weight:600;border:none;cursor:pointer}
.btn-submit{font-size:1.05rem}
.btn.ghost{background:transparent;border:1px solid rgba(44,103,179,0.12);color:var(--accent)}
.small{font-size:.85rem;color:#425066}
.flex{display:flex;gap:8px;align-items:center}

/* Carousel - Thumbnails */
.photo-carousel{width:100%;border-radius:8px;background:#f6f7fb;padding:12px}
.carousel-thumbnails{display:grid;grid-template-columns:repeat(auto-fill, minmax(100px, 1fr));gap:8px}
.carousel-thumbnail{width:100%;height:80px;object-fit:cover;border-radius:6px;cursor:pointer;transition:transform .2s, box-shadow .2s}
.carousel-thumbnail:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(14,43,74,0.15)}
.carousel-placeholder{display:flex;align-items:center;justify-content:center;height:100px;color:var(--muted)}

/* Lightbox */
.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.9);z-index:1000;display:flex;align-items:center;justify-content:center}
.lightbox-content{position:relative;max-width:90%;max-height:90%;display:flex;align-items:center;justify-content:center}
.lightbox-image{max-width:100%;max-height:90vh;object-fit:contain}
.lightbox-close{position:absolute;top:-40px;right:0;background:transparent;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:0 10px}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.2);border:none;color:#fff;font-size:2rem;cursor:pointer;padding:10px 15px;border-radius:4px}
.lightbox-nav:hover{background:rgba(255,255,255,0.4)}
.lightbox-prev{left:-60px}
.lightbox-next{right:-60px}

/* Vehicle info */
.vehicle-info{background:#f6f7fb;padding:16px;border-radius:8px}
.vehicle-info h2{margin-top:0;font-size:1.3rem;color:var(--brand)}
.vehicle-info h3{margin-top:16px;margin-bottom:8px;font-size:1.1rem;color:var(--brand)}
.vehicle-info p{margin:6px 0;font-size:.95rem;line-height:1.5}

.vehicle-info-left{background:#f6f7fb;padding:16px;border-radius:8px;margin:16px 0}
.vehicle-info-left h2{margin-top:0;font-size:1.2rem;color:var(--brand)}
.vehicle-info-left p{margin:6px 0;font-size:.95rem;line-height:1.5}

/* About grid thumbnails */
.about-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.about-thumb{width:120px;height:80px;overflow:hidden;border-radius:6px;box-shadow:0 6px 14px rgba(10,20,40,0.06)}
.about-thumb img{width:100%;height:100%;object-fit:cover}

/* Footer */
.site-footer{border-top:1px solid #eef2f6;background:#fff;padding:18px}
.footer-inner{display:flex;justify-content:space-between;color:var(--muted);font-size:.95rem}

/* Calendar: compacte versie */
.calendar-controls{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}
.calendar-controls button{padding:8px 12px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;flex-shrink:0}
.calendar-controls .small{flex:1 1 200px;text-align:center;font-size:1rem;font-weight:600;min-width:0}

.calendar-grid.compact{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:16px;width:100%;max-width:100%;overflow-x:auto}
.compact-day{background:#fff;border-radius:8px;padding:8px;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.95rem;min-height:56px;min-width:fit-content;box-shadow:0 8px 20px rgba(10,20,40,0.08)}
.compact-day:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(10,20,40,0.08)}
.compact-day.not-clickable{cursor:not-allowed;opacity:0.7}
.compact-day.not-clickable:hover{transform:none;box-shadow:0 6px 14px rgba(10,20,40,0.03)}
.compact-day .date{font-weight:700;color:var(--muted);font-size:1.05rem;white-space:nowrap}

/* Mobile responsive calendar */
@media (max-width: 768px) {
  .container {
    padding: 0 8px;
  }
  .card {
    padding: 12px;
  }
  .calendar-grid.compact {
    gap:4px;
    grid-template-columns:repeat(7,1fr);
    width:100%;
    max-width:100%;
  }
  .compact-day {
    padding:8px 4px;
    font-size:.85rem;
    min-height:48px;
    gap:0;
    justify-content:center;
    border-radius:8px;
  }
  /* Color code the entire day cell on mobile */
  .compact-day.status-ok {
    background:#e6fbf0;
    border:2px solid #0b7a3a;
  }
  .compact-day.status-partial {
    background:#fff6e7;
    border:2px solid #d4a015;
  }
  .compact-day.status-busy {
    background:#ffecec;
    border:2px solid #d93636;
  }
  .compact-day .date {
    font-size:1.3rem;
    font-weight:700;
  }
  /* Hide availability text on mobile */
  .compact-day .badge {
    display:none;
  }
}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:.8rem;position:relative}
.badge.ok{background:#e6fbf0;color:#0b7a3a}
.badge.partial{background:#fff6e7;color:#7a5a15}
.badge.busy{background:#ffecec;color:#7a2a2a}
.badge.has-tooltip{cursor:help;text-decoration:underline dotted}

/* Custom tooltip for booking times */
.custom-tooltip{
  display:none;
  position:absolute;
  bottom:100%;
  left:50%;
  transform:translateX(-50%);
  margin-bottom:8px;
  background:#0b1730;
  color:#fff;
  padding:12px 16px;
  border-radius:8px;
  box-shadow:0 4px 12px rgba(0,0,0,0.3);
  z-index:1000;
  min-width:200px;
  white-space:nowrap
}
.custom-tooltip::after{
  content:'';
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:#0b1730
}
.badge.has-tooltip:hover .custom-tooltip{display:block}
.tooltip-title{
  font-weight:700;
  margin-bottom:8px;
  font-size:.9rem;
  border-bottom:1px solid rgba(255,255,255,0.2);
  padding-bottom:6px
}
.tooltip-time{font-size:.85rem;margin:4px 0;opacity:0.95}

/* Form styling */
.form-field{margin-bottom:16px}
.form-field label{display:block;margin-bottom:6px;font-weight:600;color:var(--brand)}
.form-field input,
.form-field textarea{width:100%;padding:10px;border:1px solid #e5e7eb;border-radius:6px;font-family:var(--font-sans);font-size:1rem}
.form-field input:focus,
.form-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(44,103,179,0.1)}
.form-field textarea{resize:vertical}

/* Booking confirmation page */
.confirmation-header{text-align:center;padding:24px 0}
.confirmation-icon{width:80px;height:80px;margin:0 auto 16px;background:#e6fbf0;color:#0b7a3a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700}
.confirmation-details{margin-top:32px;background:#f6f7fb;padding:24px;border-radius:8px}
.confirmation-details h2{margin-top:0;font-size:1.2rem;color:var(--brand);margin-bottom:16px}
.detail-row{display:flex;padding:12px 0;border-bottom:1px solid #e5e7eb}
.detail-row:last-child{border-bottom:none}
.detail-label{font-weight:600;color:var(--brand);min-width:120px}
.detail-value{flex:1;color:var(--muted)}

/* table in admin */
table{width:100%;border-collapse:collapse}
th,td{padding:8px;border-bottom:1px solid rgba(14,43,74,0.06);text-align:left}
tr.cancelled{opacity:.6}

/* responsive tweaks */
@media (max-width:720px){
  .hero-inner{flex-direction:column}
  .main-nav{display:none}
  .about-thumb{width:48%;height:100px}
  .carousel-thumbnails{grid-template-columns:repeat(auto-fill, minmax(80px, 1fr))}
  .lightbox-prev{left:-10px}
  .lightbox-next{right:-10px}
}

/* Price VAT tooltip */
.price-excl-vat {
  position: relative;
  cursor: help;
  display: inline-block;
}

.price-excl-vat .price-value {
  border-bottom: 1px dotted var(--brand);
}

.price-tooltip {
  display: none;
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #0b1730;
  color: #fff;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 0.9rem;
  white-space: nowrap;
  margin-bottom: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  z-index: 1000;
}

.price-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: #0b1730;
}

/* Contact section */
.contact-section {
  margin-top: 16px;
}

.contact-section h2 {
  margin-top: 0;
  font-size: 1.3rem;
  color: var(--brand);
  margin-bottom: 16px;
}

.contact-info {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contact-name {
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--brand);
  margin: 0 0 8px 0;
}

.contact-item {
  margin: 0;
  font-size: 0.95rem;
  color: var(--muted);
  line-height: 1.6;
}

.contact-link {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s;
}

.contact-link:hover {
  color: var(--brand);
  text-decoration: underline;
}

/* Photo-block: forceer proportionele schaal en voorkom knippen (override) */
.card.photo-block-card,
.photo-block-card {
  overflow: visible !important;
  max-height: none !important;
}

.photo-block,
.photo-block-card {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.photo-block__img {
  display: block !important;
  width: 100% !important;
  max-width: calc(1100px - 36px - 32px) !important; /* of: max-width:100% als je dat verkiest */
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 22px rgba(0,0,0,0.06) !important;
}
@media (max-width: 768px) {
  .photo-block__img {
    max-width: 100% !important;
    border-radius: 8px !important;
  }
}

/* Mobile responsive admin tables */
@media (max-width: 420px) {
  /* Hide less critical columns on small screens */
  .hide-mobile {
    display: none !important;
  }
  
  /* Reduce table font sizes and padding */
  .admin-table th,
  .admin-table td {
    padding: 6px 4px !important;
    font-size: 0.8rem !important;
  }
  
  /* Make customer info more compact */
  .admin-table .customer-email {
    font-size: 0.7rem !important;
  }
  
  /* Action buttons: show only icons on mobile */
  .mobile-icon-only .btn-text {
    display: none;
  }
  
  .mobile-icon-only .btn-icon {
    display: inline !important;
  }
  
  .mobile-icon-only .btn {
    padding: 10px !important;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
  }
  
  .mobile-icon-only form {
    display: inline-block;
  }
  
  /* Reduce gap between buttons */
  .mobile-icon-only .flex {
    gap: 4px !important;
    flex-wrap: wrap !important;
  }
  
  /* Email management tables - reduce font size */
  .history-table th,
  .history-table td {
    padding: 6px 4px !important;
    font-size: 0.75rem !important;
  }
  
  /* Status badges - smaller on mobile */
  .status-badge {
    font-size: 0.7rem !important;
    padding: 2px 6px !important;
  }
  
  /* Tab navigation - more compact */
  .tab-nav button {
    padding: 8px 12px !important;
    font-size: 0.85rem !important;
  }
  
  /* Form fields in email management - more compact */
  .email-form label {
    font-size: 0.85rem !important;
  }
  
  .email-form input,
  .email-form textarea,
  .email-form select {
    padding: 6px 8px !important;
    font-size: 0.85rem !important;
  }
  
  /* Ensure overflow-x:auto wrapper for tables */
  .table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}