/* ===== Plans — layout + neon cards + big overlay ===== */

/* Section */
.plans{padding:56px 0}
.plans h2{font-weight:800;margin-bottom:6px}
.plans .sub{color:var(--muted);margin-bottom:22px}

/* Grid */
.plans-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  align-items:stretch;
  overflow:visible;
}
@media (max-width:1100px){.plans-row{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){ .plans-row{grid-template-columns:1fr}}

/* Base card (glass + subtle neon) */
.plan-card{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  padding:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.03));
  box-shadow:inset 0 0 0 1px rgba(0,212,255,.10), 0 18px 50px rgba(0,212,255,.12);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

/* Level colors (custom props per level) */
.plan-card[data-level="green"] { --plan-tint: rgba(0,246,164,.45); --plan-glow: rgba(0,238,171,.85); }
.plan-card[data-level="blue"]  { --plan-tint: rgba(0,191,255,.48); --plan-glow: rgba(0,191,255,.85); }
.plan-card[data-level="bronze"]{ --plan-tint: rgba(255,153,51,.42); --plan-glow: rgba(255,153,51,.72); }
.plan-card[data-level="silver"]{ --plan-tint: rgba(210,226,255,.42); --plan-glow: rgba(210,226,255,.70); }
.plan-card[data-level="gold"]  { --plan-tint: rgba(255,215,64,.52);  --plan-glow: rgba(255,196,0,.85);  }

/* Aura + inner tint */
.plan-card::before{
  content:"";
  position:absolute; inset:-8px; border-radius:22px; z-index:-1;
  filter:blur(24px); opacity:.55; pointer-events:none;
  background:radial-gradient(900px 280px at 50% -12%, var(--plan-glow, transparent), transparent 65%);
}
.plan-card::after{
  content:"";
  position:absolute; inset:0; border-radius:18px; z-index:-1;
  opacity:.18; pointer-events:none;
  background:radial-gradient(120% 80% at 30% -10%, var(--plan-tint, transparent), transparent 60%);
}

/* Hover */
.plan-card:hover{
  transform:translateY(-2px);
  filter:saturate(1.08);
  box-shadow:0 22px 66px rgba(0,0,0,.35), 0 20px 60px var(--plan-glow, transparent);
}

/* Face (title/price/CTA) */
.plan-face{display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center;min-height:240px}
.plan-title{font-weight:900;letter-spacing:.2px;font-size:22px}
.plan-price{font-weight:900;font-size:40px;line-height:1}
.plan-price i{font-style:normal;font-size:14px;color:var(--muted);margin-left:6px}

/* Chips */
.plan-chip,.plan-info{
  position:absolute;top:10px;
  font-size:12px;font-weight:800;padding:6px 10px;border-radius:9999px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#dbe7ff
}
.plan-chip{right:10px}
.plan-info{left:10px;cursor:pointer}

/* Gold wide card */
.plan-card--gold{grid-column:1 / -1;text-align:left}
.plan-card--gold .plan-face{min-height:240px;align-items:flex-start;gap:16px;padding-bottom:12px}

.plan-overlay{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%) scale(.98);

  /* Responsive width, groeit mee */
  width:min(520px, calc(100vw - 32px));
  max-width:calc(100vw - 32px);

  /* BELANGRIJK: geen vaste hoogte / geen scrollbar */
  height:auto;
  max-height:none;
  overflow:visible;

  border-radius:18px;
  padding:28px 28px 24px;

  box-shadow:
    0 30px 90px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,255,255,.12) inset;

  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
}

/* Open state (hover of click) */
.plan-card:hover .plan-overlay,
.plan-card.is-open .plan-overlay{
  opacity:1;
  pointer-events:auto;
  transform:translate(-50%,-50%) scale(1);
}

/* Zorg dat header + lijst altijd mooi onder elkaar vallen */
.plan-overlay .overlay-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}

.plan-overlay .overlay-title{
  font-weight:800;
  line-height:1.15;
  font-size:22px;
}

.plan-overlay .plan-features{
  margin:0;
  padding-left:20px;
}

.plan-overlay .plan-features li{
  line-height:1.6;
  margin:8px 0;
}
@media (max-height: 700px){
  .plan-overlay{
    top:56px;
    transform:translateX(-50%) scale(1);
  }
}

/* open state */
.plan-card:hover .plan-overlay,
.plan-card.is-open .plan-overlay{opacity:1;pointer-events:auto;transform:translate(-50%,0) scale(1)}

/* overlay content */
.overlay-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.overlay-title{font-weight:900;font-size:24px}
.overlay-close{
  appearance:none;border:0;cursor:pointer;
  padding:6px 10px;border-radius:9999px;
  font-weight:800;font-size:12px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);color:#dbe7ff
}
.plan-features{margin:8px 0 10px;padding:0;list-style:none}
.plan-features li{
  position:relative;margin:8px 0;padding-left:22px;
  color:#eaf2ff;font-weight:600;line-height:1.55;font-size:16.5px
}
.plan-features li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:12px;height:12px;border-radius:9999px;
  background:linear-gradient(90deg,var(--cyan),var(--purple));
  box-shadow:0 0 6px rgba(0,212,255,.18)
}
.plan-actions{margin-top:auto;display:flex;gap:10px;align-items:center;justify-content:center}

/* Mobile: real modal */
@media (max-width:720px){
  .plan-card:hover,.plan-card.is-open{z-index:initial}
  .plan-overlay{
    position:fixed;left:50%;top:50%;
    width:min(92vw,560px);max-height:82vh;
    transform:translate(-50%,-50%) scale(1)
  }
}

/* Extra polish for Silver & Gold shine */
.plan-card[data-level="silver"]::after{
  background:
    radial-gradient(120% 80% at 30% -10%, var(--plan-tint), transparent 60%),
    conic-gradient(from 210deg,
      rgba(255,255,255,.10) 0 12%,
      transparent 12% 28%,
      rgba(255,255,255,.06) 28% 40%,
      transparent 40% 70%,
      rgba(255,255,255,.08) 70% 85%,
      transparent 85% 100%);
  mix-blend-mode:screen;opacity:.32
}
.plan-card[data-level="gold"]::before{
  background:radial-gradient(1050px 360px at 50% -12%, rgba(255,205,80,.85), transparent 65%)
}
.plan-card[data-level="gold"]::after{
  background:
    radial-gradient(120% 80% at 30% -10%, var(--plan-tint), transparent 60%),
    conic-gradient(from 240deg,
      rgba(255,240,200,.16) 0 10%,
      transparent 10% 22%,
      rgba(255,220,140,.12) 22% 36%,
      transparent 36% 64%,
      rgba(255,230,160,.14) 64% 78%,
      transparent 78% 100%);
  opacity:.40;mix-blend-mode:screen
}

/* === GOLD card enhancements === */
.gold-face{gap:16px;min-height:240px}
.gold-stats{
  width:100%;display:flex;justify-content:space-between;align-items:flex-end;gap:12px
}
.gold-price .val{font-weight:900;font-size:42px;color:var(--gold);line-height:1}
.gold-price .lbl{display:block;font-size:12px;color:var(--muted);font-weight:700}
.gold-slots #slot-count{font-weight:900;font-size:42px;line-height:1;color:#fff}
.gold-slots .lbl{display:block;font-size:12px;color:var(--muted);font-weight:700;text-align:right}

/* center de CTA binnen de brede Gold-kaart */
.plan-card--gold .plan-actions{width:100%;justify-content:center}

/* Respect user pref: reduce motion */
@media (prefers-reduced-motion: reduce){
  .plan-card,.plan-overlay{transition:none}
}
/* ====== PATCH: maak de bovenste 4 exact even hoog ====== */

/* iets robuuster kolombreedtes */
.plans-row{
  grid-template-columns: repeat(4, minmax(260px, 1fr));
  align-items: stretch; /* al aanwezig, laten staan */
}

/* cards en content rekken mee */
.plan-card{
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* de “face” vult de resterende ruimte, knoppen blijven onderaan */
.plan-face{
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* alleen de top-4 (niet de brede Gold) een consistente minimale hoogte */
.plan-card:not(.plan-card--gold){
  min-height: 300px;  /* pas 290–320 aan naar smaak */
}

/* knoppen altijd onderaan */
.plan-actions{ margin-top: auto; }

/* responsive blijft hetzelfde */
@media (max-width:1100px){
  .plans-row{ grid-template-columns: repeat(2, minmax(260px, 1fr)); }
}
@media (max-width:640px){
  .plans-row{ grid-template-columns: 1fr; }
}
/* ===== HOTFIX: 4 gelijke kolommen + gelijke kaart-hoogte ===== */
.plans.container .plans-row{
  display:grid;
  grid-template-columns: repeat(4, 1fr) !important;
  align-items: stretch;
}

.plans.container .plan-card{
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
}

.plans.container .plan-face{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.plans.container .plan-card:not(.plan-card--gold){
  min-height:300px;
}

.plans.container .plan-actions{ margin-top:auto; }

@media (max-width:1100px){
  .plans.container .plans-row{ grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width:640px){
  .plans.container .plans-row{ grid-template-columns: 1fr !important; }
}
/* --- Restore hover overlay for wide Gold card --- */
.plan-card--gold{ 
  overflow: visible;           /* overlay mag buiten de kaart vallen */
  position: relative; 
  z-index: 1;
}

/* generieke hover-open staat er al, maar we forceren 'm voor zekerheid */
.plan-card--gold:hover .plan-overlay{
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%,0) scale(1);
}

/* zorg dat de overlay boven alle glows komt */
.plan-card--gold .plan-overlay{
  z-index: 60;
}

/* === GOLD CARD – VISIBLE RULES === */
.plan-card--gold .gold-visible-rules{
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
  font-size: 13px;
  line-height: 1.45;
  color: rgba(200,230,255,0.9);
}
.plan-card--gold .gold-visible-rules li{
  padding-left: 16px;
  position: relative;
}
.plan-card--gold .gold-visible-rules li:before{
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: rgba(0,212,255,0.9);
}

/* === DISABLE GOLD OVERLAY ONLY === */
.plan-card--gold .plan-overlay{
  display:none !important;
}
.plan-card--gold .plan-info{
  display:none !important; /* Info knop weg bij Gold */
}
.plan-card--gold.is-open{
  /* als er ooit is-open wordt gezet, forceren we dicht */
  --noop: 1;
}

/* === OVERLAY FIX - PROPER CENTERING === */
.plan-overlay {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) scale(0.96) !important;
  
  width: min(580px, calc(100vw - 40px)) !important;
  max-height: calc(100vh - 100px) !important;
  
  padding: 26px 28px !important;
  border-radius: 18px !important;
  
  background: linear-gradient(135deg, rgba(10, 20, 45, 0.97), rgba(5, 15, 35, 0.97)) !important;
  backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(0, 212, 255, 0.2) !important;
  
  box-shadow: 
    0 40px 100px rgba(0, 0, 0, 0.7),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset !important;
  
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  
  overflow-y: auto !important;
  overflow-x: hidden !important;
  
  z-index: 999999 !important;
  
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0.25s !important;
}

/* Open state */
.plan-card:hover .plan-overlay,
.plan-card.is-open .plan-overlay {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translate(-50%, -50%) scale(1) !important;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0s !important;
}

/* Gold card: NO hover overlay, only click */
.plan-card--gold:hover .plan-overlay {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Overlay backdrop (achtergrond dimmen) */
.plan-card:hover::before,
.plan-card.is-open::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  z-index: 999998;
  animation: fadeIn 0.25s ease;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Overlay content styling */
.plan-overlay .overlay-head {
  margin-bottom: 18px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid rgba(0, 212, 255, 0.15) !important;
}

.plan-overlay .overlay-title {
  font-size: 24px !important;
  font-weight: 900 !important;
  color: rgba(0, 212, 255, 1) !important;
}

.plan-overlay .plan-features {
  margin: 16px 0 20px !important;
  padding-left: 0 !important;
}

.plan-overlay .plan-features li {
  font-size: 15px !important;
  line-height: 1.6 !important;
  margin: 10px 0 !important;
}

.plan-overlay .plan-actions {
  margin-top: 20px !important;
  padding-top: 16px !important;
  border-top: 1px solid rgba(0, 212, 255, 0.1) !important;
}
/* === CENTER OVERLAY TITLE (Blue / all plans) === */
.plan-overlay .overlay-head{
  position: relative;
}

.plan-overlay .overlay-title{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  width: 100%;
  pointer-events: none; /* voorkomt overlap met close */
}

/* Close button blijft rechts */
.plan-overlay .overlay-close{
  position: relative;
  z-index: 2;
}

