
/* Eventplaner – mobile-first, passend zum Projekt/Beetplaner */
.ep-shell { margin-top: 10px; }

.ep-toolbar { border-radius: 16px; }
.ep-toolbar-row{
  display:flex;
  align-items:flex-start;
  gap:12px;
  justify-content:space-between;
  flex-wrap:wrap;
}
.ep-actions{ display:flex; gap:8px; flex-wrap:wrap; }

.ep-list{
  margin-top: 12px;
  display: grid;
  gap: 12px;
}

.ep-card{
  overflow:hidden;
  border-radius: 18px;
}
.ep-card-inner{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  align-items: stretch;
}
@media (max-width: 520px){
  .ep-card-inner{ grid-template-columns: 1fr; }
}

.ep-thumb{
  width:100%;
  height:120px;
  border-radius: 14px;
  overflow:hidden;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
}
.ep-thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.ep-body{ padding: 2px 2px 2px 2px; }
.ep-title-row{
  display:flex;
  gap:10px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
}
.ep-title{
  font-weight: 950;
  letter-spacing: .01em;
  font-size: 1.05rem;
}
.ep-badges{ display:flex; gap:6px; flex-wrap:wrap; margin-top: 6px; }
.ep-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 12px;
  background: rgba(0,0,0,0.32);
  border: 1px solid rgba(255,255,255,0.10);
}
.ep-desc{
  margin-top: 10px;
  color: rgba(255,255,255,0.85);
  font-size: 14px;
  line-height: 1.35;
  white-space: pre-wrap;
}

.ep-footer{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.ep-by{ font-size: 12px; color: rgba(255,255,255,0.65); }

.ep-empty{
  padding: 16px;
  text-align:center;
}

/* Dialog – übernimmt Beetplaner Look */
#ep-dialog{
  border: none;
  padding: 0;
  border-radius: 18px;
  max-width: 620px;
  width: min(92vw, 620px);
  background: transparent;
}
#ep-dialog::backdrop{
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
}
.ep-dialog{
  padding: 14px;
  border-radius: 18px;
  background: rgba(0,0,0,0.42);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 18px 60px rgba(0,0,0,0.55);
}
.ep-dialog-grid{
  margin-top: 10px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.ep-span2{ grid-column: 1 / -1; }
@media (max-width: 520px){
  .ep-dialog-grid{ grid-template-columns: 1fr; }
  .ep-span2{ grid-column: 1 / -1; }
}
.ep-dialog-actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
  margin-top: 12px;
}

/* Toast */
.ep-toast{
  position: fixed;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  z-index: 9999;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,0.75);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 13px;
  max-width: min(92vw, 560px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.45);
}

/* Print */
@media print{
  .ep-actions, .no-print { display:none !important; }
  .ep-card{ break-inside: avoid; }
  .ep-thumb{ height: 140px; }
  .ep-badge{ border-color: #000; }
}
