/* Corlaer Evenementen – Frontend v1.2 */
.ca-wrap * { box-sizing: border-box; }
.ca-wrap { font-family: 'Segoe UI', Arial, sans-serif; }

/* Tabs */
.ca-tabs { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.ca-tab { background:#1a1a1a; border:1px solid #2a2a2a; color:#aaa; font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:1px; padding:8px 18px; border-radius:4px; cursor:pointer; transition:all .15s; }
.ca-tab:hover { border-color:#FD5904; color:#FD5904; }
.ca-tab.ca-actief { background:#FD5904; border-color:#FD5904; color:#fff; }

/* Grid */
.ca-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:16px; align-items:start; }

/* Kaart */
.ca-kaart { background:#1a1a1a; border:1px solid #2a2a2a; border-radius:10px; overflow:hidden; display:flex; flex-direction:column; transition:border-color .15s, transform .15s; }
.ca-kaart:hover { border-color:#FD5904; transform:translateY(-2px); }

/* Uitgelicht: zelfde zwart, dikke oranje rand, volle breedte */
.ca-featured { border:2px solid #FD5904 !important; grid-column:1 / -1; }
@media (max-width:600px) { .ca-featured { grid-column:1; } }

/* Gekleurde topbalk */
.ca-balk { height:5px; background:#FD5904; }
.ca-sport-tv .ca-balk { background:#1976d2; }
.ca-thema    .ca-balk { background:#9c27b0; }

/* Body */
.ca-body { padding:22px 20px; flex:1; display:flex; flex-direction:column; }

/* Datum + ster */
.ca-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; min-height:22px; }
.ca-datum { display:inline-block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; padding:3px 10px; border-radius:3px; line-height:1.4; }
.ca-d-sport    { background:#FD5904; color:#111; }
.ca-d-sport-tv { background:#1976d2; color:#fff; }
.ca-d-thema    { background:#9c27b0; color:#fff; }
.ca-ster { font-size:11px; font-weight:700; color:#FD5904; background:rgba(253,89,4,.15); padding:2px 8px; border-radius:3px; white-space:nowrap; }

/* Icoon */
.ca-icon { font-size:28px; margin-bottom:10px; line-height:1; display:block; }

/* Titel — helder wit */
.ca-kaart h3 {
  font-size:18px !important; font-weight:900 !important;
  text-transform:uppercase !important; color:#ffffff !important;
  margin:0 0 10px !important; line-height:1.2 !important;
  padding:0 !important; border:none !important; background:none !important;
  text-shadow: 0 0 1px #fff, 0 1px 3px rgba(0,0,0,.8) !important;
  -webkit-font-smoothing: antialiased !important;
  letter-spacing: 0.5px !important;
}

/* Beschrijving — lichtgrijs, goed leesbaar */
.ca-kaart p {
  font-size:14px !important; color:#cccccc !important;
  line-height:1.65 !important; margin:0 0 16px !important;
  flex:1; padding:0 !important; background:none !important;
}

/* Meta */
.ca-meta { display:flex; flex-direction:column; gap:5px; border-top:1px solid #2a2a2a; padding-top:14px; margin-bottom:16px; }
.ca-meta span { font-size:13px; color:#aaaaaa; display:flex; align-items:center; gap:6px; line-height:1.4; }

/* Aanmelden knop */
.ca-btn { display:block; width:100%; text-align:center; background:#FD5904; color:#fff !important; font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; padding:11px 16px; border-radius:4px; border:none; cursor:pointer; margin-top:auto; transition:background .15s; text-decoration:none !important; }
.ca-btn:hover { background:#e04d00; color:#fff !important; }
.ca-sport-tv .ca-btn { background:#1976d2; }
.ca-sport-tv .ca-btn:hover { background:#1565c0; }
.ca-thema    .ca-btn { background:#9c27b0; }
.ca-thema    .ca-btn:hover { background:#7b1fa2; }

/* Vol */
.ca-vol { display:inline-block; background:rgba(198,40,40,.2); color:#ef9a9a; font-size:12px; font-weight:700; padding:4px 12px; border-radius:3px; text-align:center; margin-top:auto; border:1px solid rgba(198,40,40,.3); }
.ca-leeg { color:#777; padding:20px 0; font-size:14px; }

/* Overlay */
.ca-overlay { position:fixed; inset:0; background:rgba(0,0,0,.8); display:flex; align-items:center; justify-content:center; z-index:99999; padding:20px; }
.ca-box { background:#1a1a1a; border:1px solid #2a2a2a; border-radius:10px; width:100%; max-width:480px; max-height:90vh; overflow-y:auto; box-shadow:0 20px 60px rgba(0,0,0,.6); }
.ca-box-top { padding:18px 22px 16px; border-bottom:1px solid #2a2a2a; display:flex; align-items:center; justify-content:space-between; background:#FD5904; border-radius:10px 10px 0 0; }
.ca-box-top h3 { font-size:16px !important; font-weight:800 !important; text-transform:uppercase !important; color:#fff !important; margin:0 !important; }
.ca-sluit { background:none; border:none; color:rgba(255,255,255,.8); font-size:20px; cursor:pointer; line-height:1; }
.ca-sluit:hover { color:#fff; }
.ca-box-body { padding:22px; }
.ca-veld { margin-bottom:14px; }
.ca-veld label { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:#777; margin-bottom:5px; }
.ca-veld input, .ca-veld select, .ca-veld textarea { width:100%; padding:10px 13px; background:#111; border:1px solid #2a2a2a; border-radius:5px; font-size:14px; font-family:inherit; color:#eee; outline:none; box-sizing:border-box; transition:border-color .15s; }
.ca-veld input:focus, .ca-veld select:focus, .ca-veld textarea:focus { border-color:#FD5904; }
.ca-veld input::placeholder, .ca-veld textarea::placeholder { color:#444; }
.ca-veld select option { background:#1a1a1a; }
.ca-veld textarea { resize:vertical; min-height:80px; }
.ca-check { display:flex; align-items:flex-start; gap:8px; }
.ca-check input { width:auto !important; margin-top:3px; flex-shrink:0; accent-color:#FD5904; }
.ca-check label { font-size:13px !important; text-transform:none !important; letter-spacing:0 !important; color:#888 !important; line-height:1.5; }
.ca-submit { width:100%; background:#FD5904; color:#fff; font-size:15px; font-weight:700; text-transform:uppercase; letter-spacing:1px; padding:13px; border:none; border-radius:4px; cursor:pointer; margin-top:4px; transition:background .15s; }
.ca-submit:hover { background:#e04d00; }
.ca-submit:disabled { opacity:.4; cursor:not-allowed; }
