/* CourtKings brand variables */
:root{
  --blue-light:#24D7FF; /* primary highlight */
  --blue:#2496FF;       /* secondary */
  --violet:#6A49FF;     /* CTA */
  --orange:#FF6B42;     /* alerts */
  --lime:#CFF75E;       /* success */
  --bg:#071016;
  --surface:#0E1418;
  --text:#EAF2F7;
  --muted:#9AA7B2;
  --border:#161B20;
  --focus:rgba(36,215,255,.45);
  --glass: rgba(255,255,255,0.02);
}

/* Reset & base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:linear-gradient(180deg,var(--bg),#061217 140%); color:var(--text);
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-size:16px; line-height:1.65; text-rendering:optimizeLegibility;
}

/* Containers */
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.site-main{padding-bottom:64px}

/* Header & nav */
.site-header{
  position:sticky; top:0; z-index:100;
  backdrop-filter:saturate(140%) blur(8px);
  background:rgba(18,22,28,0.85);
  border-bottom:1px solid var(--border);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
  gap: 12px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--text);
}

.logo {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.6);
}

.brand-name {
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: 1.05rem;
}

.main-nav .nav-toggle {
  display: none;
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border);
  padding: 8px 12px;
  border-radius: 8px;
}

.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 2px;
  align-items: center;
}

.nav-item > a {
  color: var(--text);
  text-decoration: none;
  padding: 12px 14px;
  border-radius: 10px;
  display: block;
  font-size: 0.98rem;
  font-weight: 600;
  transition: transform .15s ease, background .15s ease, color .15s ease;
  position: relative;
  white-space: nowrap;
}

.nav-item > a:hover {
  background: linear-gradient(90deg, rgba(36,215,255,0.06), rgba(106,73,255,0.06));
  color: var(--blue-light);
  transform: translateY(-3px) scale(1.01);
}

.nav-item > a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 14px;
  right: 14px;
  height: 2px;
  background: var(--blue);
  border-radius: 1px;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.nav-item > a:hover::after {
  opacity: 1;
}

.nav-item:last-child > a::after {
  display: none;
}

.nav-separator {
  margin-left: 12px;
  padding-left: 12px;
  border-left: 1px solid var(--border);
}

.has-sub {
  position: relative;
}

.has-sub .subnav {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 220px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 8px;
  display: none;
  margin-top: 0px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}

.has-sub:hover .subnav {
  display: block;
  animation: slideDown 0.2s ease;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.subnav li {
  list-style: none;
}

.subnav a {
  display: block;
  color: var(--text);
  text-decoration: none;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 0.9rem;
  transition: all 0.2s ease;
}

.subnav a:hover {
  background: rgba(76,36,255,0.20);
  color: var(--violet);
  padding-left: 16px;
}

/* Footer */
.site-footer{border-top:1px solid var(--border);background:var(--surface);margin-top:64px}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:32px 0}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links a{color:var(--text);text-decoration:none}
.footer-links a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid var(--border);padding:16px 0;text-align:center}

/* Hero */
.hero{padding:48px 0;background:linear-gradient(90deg, rgba(36,215,255,0.10), rgba(76,36,255,0.10))}
.hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:24px;align-items:center}
.hero-content h1{margin:0 0 8px}
.hero-img{width:100%;border-radius:16px;border:1px solid var(--border)}
.hero-actions{display:flex;gap:12px;margin-top:12px}

/* Cards & sections */
.features .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:32px 0}
.cards .card{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), var(--surface));
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: 14px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
  justify-content: flex-start;
  box-shadow: 0 10px 30px rgba(0,0,0,0.45);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  cursor: pointer;
  text-decoration: none;
  color: var(--text);
}
.cards .card h3{margin:0;font-size:1.12rem;color:var(--blue-light)}
.cards .card p{margin:0;color:var(--muted)}
.cards .card .card-cta{
  margin-top:12px;font-weight:700;color:var(--text);background:linear-gradient(90deg,var(--blue-light),var(--violet));padding:8px 12px;border-radius:10px;color:#031018;display:inline-block;margin-left:auto
}
.cards .card:hover{transform:translateY(-8px);box-shadow:0 26px 60px rgba(0,0,0,0.6);background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01))}
.cta-banner{padding:24px 0;background:linear-gradient(90deg, rgba(36,150,255,0.15), rgba(255,76,36,0.15))}
.cta-inner{display:flex;align-items:center;justify-content:space-between}

/* Two column grid */
.grid-two .two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:24px 0}
.map-embed{border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.map-embed iframe{width:100%;height:280px;border:0}

/* Page header */
.page-header{padding:28px 0;border-bottom:1px solid var(--border);background:linear-gradient(90deg, rgba(36,215,255,0.08), rgba(76,36,255,0.08))}
.page-header h1{margin:0}

/* Forms */
.form{display:grid;gap:12px}
.form-row{display:grid;gap:6px}
label{font-weight:500}
input,select,textarea{
  background:#0D1117; border:1px solid var(--border); color:var(--text);
  padding:10px; border-radius:10px; outline:none; transition:border-color .15s ease;
}
input:focus,select:focus,textarea:focus{border-color:var(--blue)}
.form-actions{display:flex;gap:12px;align-items:center}
.form-note{color:var(--muted);font-size:.9rem}
.alert{margin-top:8px;padding:10px;border-radius:10px;border:1px solid var(--border);background:#0D1117}
.alert.success{border-color:#7CA514;color:var(--lime);background:rgba(215,255,36,0.08)}
.alert.error{border-color:#7A2418;color:var(--orange);background:rgba(255,76,36,0.08)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;text-decoration:none;border:1px solid var(--border);color:var(--text);cursor:pointer;font-weight:600}
.btn-primary{background:linear-gradient(90deg,var(--blue-light),var(--violet));border-color:transparent;color:#031018;box-shadow:0 12px 36px rgba(36,215,255,0.12);transition:transform .12s ease,box-shadow .12s ease}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 48px rgba(36,215,255,0.16)}
.btn-outline{background:transparent;border-color:rgba(36,150,255,0.12);color:var(--blue)}
.btn-outline:hover{background:rgba(36,150,255,0.06);transform:translateY(-2px)}
.btn-accent{background:linear-gradient(90deg,var(--violet),var(--orange));color:#051217;border:none}
.btn-link{background:transparent;border-color:transparent;color:var(--blue);padding:0}

/* Badges & lists */
.muted{color:var(--muted)}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#0D1117;border:1px solid var(--border)}
.badge-success{background:rgba(215,255,36,0.15);border-color:#94B31D;color:var(--lime)}
.news-list{list-style:none;margin:0;padding:0}
.news-list li{margin-bottom:8px}

/* Nieuws Grid & Cards */
.news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.news-card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: 14px;
  text-decoration: none;
  color: var(--text);
  transition: transform .25s ease, box-shadow .2s ease;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.news-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
  transition: left 0.5s ease;
}

.news-card:hover {
  border-color: rgba(36,215,255,0.25);
  transform: translateY(-8px);
  box-shadow: 0 18px 40px rgba(6,18,30,0.7);
}

.news-card:hover::before {
  left: 100%;
}

.news-icon {
  font-size: 2.5rem;
  line-height: 1;
}

.news-card h4 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--blue-light);
}

.news-card p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.4;
}
.reservations{list-style:none;margin:0;padding:0}
.reservations li{display:flex;gap:12px;justify-content:space-between;background:#0D1117;border:1px solid var(--border);border-radius:10px;padding:8px;margin-bottom:8px}

/* Booking */
.booking-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;padding:24px 0}
.slot-list{display:grid;gap:8px}
.slot{display:flex;justify-content:space-between;align-items:center;background:#0D1117;border:1px solid var(--border);border-radius:10px;padding:10px}
.slot .avail{color:var(--lime);font-weight:600}
.slot .full{color:var(--orange);font-weight:600}

/* Shop */
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.link-card{display:block;text-decoration:none;color:var(--text)}
.link-card:hover{border-color:var(--blue)}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:24px 0}
.product-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.01), var(--surface));
  border:1px solid rgba(255,255,255,0.02);
  border-radius:14px;
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:12px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.45);
}
.product-card h4{margin:0; font-size:1.05rem; color:var(--blue-light)}
.product-card p{color:var(--muted); margin:0}
.product-card .price{color:var(--lime);font-weight:700}
.product-card .buy{display:flex;gap:8px}
.product-img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  margin-bottom: 8px;
}


/* About */
.two-col .locations{list-style:disc;padding-left:18px}

/* Accordion */
.accordion details{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:12px}
.accordion summary{cursor:pointer}

/* Auth */
.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:24px 0}

/* Responsive */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .features .cards{grid-template-columns:1fr}
  .grid-two .two-col{grid-template-columns:1fr}
  .booking-grid{grid-template-columns:1fr}
  .auth-grid{grid-template-columns:1fr}
  .three-col,.product-grid{grid-template-columns:1fr 1fr}
  .nav-list{gap: 0;}
}
@media (max-width:640px){
  .three-col,.product-grid{grid-template-columns:1fr}
  .nav-list{display:none}
  .main-nav .nav-toggle{display:block}
  .main-nav[data-open="true"] .nav-list{
    display:flex;flex-direction:column;background:var(--surface);position:absolute;left:0;right:0;top:64px;padding:12px;border-bottom:1px solid var(--border);gap: 0;
  }
  .main-nav[data-open="true"] .nav-item > a {
    padding: 12px 14px;
    border-radius: 8px;
  }
  .main-nav[data-open="true"] .nav-item > a::after {
    display: none;
  }
}

/* Focus states */
a:focus,button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--focus);outline-offset:2px}

/* Utility (extendable) */
.hide{display:none !important}
.center{display:grid;place-items:center}
.mt-0{margin-top:0}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.p-16{padding:16px}

/* Cart (winkelmandje) */
.cart-section {
  margin: 2rem auto;
  padding: 1.5rem;
  max-width: 600px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
}

.cart-section h2 {
  margin-bottom: 1rem;
  font-size: 1.6rem;
  color: var(--text);
  border-bottom: 2px solid var(--border);
  padding-bottom: .5rem;
}

#cart {
  list-style: none;
  padding: 0;
  margin: 0;
}

#cart li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .75rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 1rem;
  color: var(--text);
}

#cart li:last-child {
  border-bottom: none;
}

#cart li span.price {
  font-weight: bold;
  color: var(--blue-light);
}

.cart-section p {
  text-align: right;
  font-size: 1.2rem;
  font-weight: bold;
  margin-top: 1rem;
  color: var(--lime);
}

.remove-btn {
  background: none;
  border: none;
  color: var(--orange);
  font-size: .9rem;
  cursor: pointer;
  transition: color .2s ease;
}

.remove-btn:hover {
  color: #ff3333;
}

/* Cart icon in header */
.cart-icon {
  position: relative;
  display: inline-block;
  margin-left: 1rem;
}

.cart-icon img {
  width: 28px;
  height: 28px;
}

.cart-count {
  position: absolute;
  top: -6px;
  right: -10px;
  background: var(--orange);
  color: #051217;
  font-size: .75rem;
  font-weight: 800;
  padding: 3px 7px;
  border-radius: 999px;
  min-width: 20px;
  text-align: center;
  box-shadow: 0 6px 18px rgba(0,0,0,0.5);
}

/* Cart Nav Item - alleen icoontje in menubalk */
.cart-nav-item {
  position: relative;
  margin-left: 12px;
  padding-left: 12px;
  border-left: 1px solid var(--border);
}

.cart-nav-item .cart-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  padding: 8px 12px;
  text-decoration: none;
  color: var(--text);
}

.cart-nav-item .cart-link:hover {
  background: rgba(36, 150, 255, 0.15);
  border-radius: 8px;
}

.cart-nav-item .cart-count {
  position: absolute;
  top: -2px;
  right: 0;
  background: var(--orange);
  color: white;
  font-size: 0.7rem;
  font-weight: bold;
  padding: 1px 4px;
  border-radius: 50%;
  min-width: 18px;
  text-align: center;
}
.cart-actions {
  display: flex;
  gap: 6px;
}

.cart-actions .btn {
  font-size: 0.8rem;
  padding: 4px 8px;
}

#cartClear {
  margin-top: 1rem;
  display: inline-block;
}

/* Checkout Section */
#cart-section .container {
  max-width: 900px;
}

.cart-container {
  padding: 2rem 0;
}

.cart-display {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 2rem;
}

.cart-display h2 {
  margin-top: 0;
  margin-bottom: 1.5rem;
  border-bottom: 2px solid var(--border);
  padding-bottom: 1rem;
}

.cart-buttons {
  display: flex;
  gap: 1rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}

.cart-buttons .btn {
  flex: 1;
  min-width: 150px;
  justify-content: center;
}

.cart-total {
  font-size: 1.3rem;
  text-align: right;
  color: var(--lime);
  margin: 1.5rem 0;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}

/* Modal Styles */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal.hide {
  display: none;
}

.modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
}

.modal-content {
  position: relative;
  z-index: 1001;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), var(--surface));
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: 18px;
  padding: 2rem;
  max-width: 920px;
  max-height: 86vh;
  overflow-y: auto;
  width: 92%;
  box-shadow: 0 30px 80px rgba(2,8,20,0.8);
}

.modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: 1.8rem;
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-close:hover {
  color: var(--orange);
}

.modal-content h2 {
  margin-top: 0;
  margin-bottom: 2rem;
  color: var(--text);
}

.modal-content h3 {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
  color: var(--blue-light);
}

/* Checkout Grid */
.checkout-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.order-summary {
  background: rgba(36, 215, 255, 0.05);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1.5rem;
  height: fit-content;
}

.order-summary h3 {
  margin-top: 0;
}

.checkout-items {
  border-bottom: 1px solid var(--border);
  padding-bottom: 1rem;
  margin-bottom: 1rem;
}

.checkout-item {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  font-size: 0.95rem;
}

.checkout-item-name {
  flex: 1;
}

.checkout-item-price {
  color: var(--blue-light);
  font-weight: bold;
}

.checkout-summary p {
  display: flex;
  justify-content: space-between;
  margin: 0.5rem 0;
  font-size: 0.95rem;
}

.checkout-total {
  margin-top: 1rem !important;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
  font-size: 1.2rem !important;
  color: var(--lime) !important;
}

/* Checkout Form */
.checkout-form {
  display: grid;
  gap: 1rem;
}

.checkout-form .form-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.checkout-form label {
  font-weight: 500;
  color: var(--text);
}

.checkout-form input[type="text"],
.checkout-form input[type="email"],
.checkout-form input[type="tel"] {
  background: rgba(13, 17, 23, 0.5);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 0.75rem;
  border-radius: 8px;
  font-size: 1rem;
  transition: border-color 0.2s ease;
}

.checkout-form input:focus {
  border-color: var(--blue);
  outline: none;
}

.checkout-form input[type="radio"] {
  margin-right: 0.5rem;
  cursor: pointer;
}

.checkout-form .form-row > label {
  display: flex;
  align-items: center;
  font-weight: normal;
  margin-bottom: 0.5rem;
  cursor: pointer;
}

#checkoutAlert {
  margin: 1rem 0;
}

.full-width {
  width: 100%;
  justify-content: center;
  margin-top: 1rem;
}

/* Responsive Checkout */
@media (max-width: 768px) {
  .checkout-grid {
    grid-template-columns: 1fr;
  }

  .modal-content {
    width: 95%;
    padding: 1.5rem;
  }

  .cart-buttons {
    flex-direction: column;
  }

  .cart-buttons .btn {
    min-width: unset;
  }
}

