/* ================================================================
   Event Calendar Pro v2.2 – Frontend CSS
   All design values injected as CSS custom properties.
================================================================ */

/* ---- Reset ---- */
.ecp-app *, .ecp-mini-wrap *, .ecp-modal *, .ecp-hp * { box-sizing: border-box; }

/* ================================================================
   NAVBAR
================================================================ */
.ecp-navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 16px;
  background: var(--ecp-nav-bg);
  border: var(--ecp-nav-border);
  border-radius: var(--ecp-nav-radius);
  flex-wrap: wrap;
  font-family: var(--ecp-font);
  margin-bottom: 2px;
}

.ecp-navbar-left,
.ecp-navbar-right  { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ecp-navbar-center { display: flex; align-items: center; gap: 10px; }

/* Search */
.ecp-search-wrap   { position: relative; }
.ecp-search {
  height: 34px; padding: 0 12px;
  border: 1.5px solid rgba(255,255,255,.25); border-radius: 8px;
  background: rgba(255,255,255,.12); color: var(--ecp-nav-text);
  font-size: .82rem; font-family: var(--ecp-font); width: 160px;
  outline: none; transition: border-color .15s, width .2s;
}
.ecp-search::placeholder { color: rgba(255,255,255,.6); }
.ecp-search:focus  { border-color: rgba(255,255,255,.6); width: 200px; }

/* Search results dropdown */
.ecp-search-results {
  position: absolute; top: 38px; left: 0; z-index: 9999;
  background: #fff; border: 1px solid #e0e0e0; border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,.14); min-width: 240px; overflow: hidden;
}
.ecp-sr-item {
  display: flex; align-items: center; gap: 9px;
  padding: 9px 14px; cursor: pointer; transition: background .12s;
  font-family: var(--ecp-font); font-size: .82rem; color: #1f2937;
}
.ecp-sr-item:hover { background: #f0f6ff; }
.ecp-sr-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.ecp-sr-title { flex: 1; font-weight: 600; }
.ecp-sr-date  { font-size: .72rem; color: #6b7280; }
.ecp-sr-empty { padding: 12px 16px; color: #9ca3af; font-size: .82rem; font-family: var(--ecp-font); }

/* Today button / date picker trigger */
.ecp-today-btn {
  height: 34px; padding: 0 12px;
  border: 1.5px solid rgba(255,255,255,.25); border-radius: 8px;
  background: rgba(255,255,255,.12); color: var(--ecp-nav-text);
  font-size: .78rem; font-weight: 600; font-family: var(--ecp-font);
  cursor: pointer; transition: background .15s; white-space: nowrap;
}
.ecp-today-btn:hover { background: rgba(255,255,255,.22); }

/* Mini date-picker popup */
.ecp-mini-picker {
  position: absolute; z-index: 99999;
  background: #fff; border: 1px solid #e0e0e0; border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.16); padding: 12px;
  width: 260px; margin-top: 4px;
}
/* Mobile date picker: JS-positioned via #ecp-today-btn click handler */
.ecp-dp-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 2px; margin-top: 8px; }
.ecp-dp-cell {
  aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
  border-radius: 6px; font-size: .75rem; cursor: pointer; transition: background .12s;
  font-family: var(--ecp-font); color: #374151;
}
.ecp-dp-cell:hover  { background: #eff6ff; color: #1d4ed8; }
.ecp-dp-cell.today  { background: var(--ecp-nav-today-bg, var(--ecp-nav-bg)); color: #fff; font-weight: 700; }
.ecp-dp-cell.wday   { font-weight: 700; font-size: .65rem; color: #9ca3af; cursor: default; }
.ecp-dp-cell.wday:hover { background: none; }
.ecp-dp-cell.empty  { cursor: default; }
.ecp-dp-nav { display: flex; align-items: center; justify-content: space-between; }
.ecp-dp-nav button {
  background: none; border: none; cursor: pointer; font-size: 1.1rem;
  color: #374151; padding: 4px 8px; border-radius: 6px; transition: background .12s;
}
.ecp-dp-nav button:hover { background: #f3f4f6; }
.ecp-dp-title { font-weight: 700; font-size: .88rem; color: #111827; font-family: var(--ecp-font); }

/* Month label (center) */
.ecp-month-label {
  font-size: var(--ecp-nav-title-size); font-weight: var(--ecp-nav-title-weight);
  font-style: var(--ecp-nav-title-style); text-decoration: var(--ecp-nav-title-decor);
  color: var(--ecp-nav-text); white-space: nowrap; letter-spacing: .01em;
}

/* Arrows */
.ecp-arrow {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 8px;
  background: var(--ecp-arrow-bg); color: var(--ecp-arrow-color);
  font-size: 1.4rem; line-height: 1; text-decoration: none;
  transition: background .15s; user-select: none;
}
.ecp-arrow:hover  { background: var(--ecp-arrow-hover-bg); color: var(--ecp-arrow-hover-color, var(--ecp-arrow-color)); }
.ecp-arrow:focus  { outline: none; background: var(--ecp-arrow-hover-bg); color: var(--ecp-arrow-hover-color, var(--ecp-arrow-color)); }
.ecp-arrow:active { outline: none; background: var(--ecp-arrow-hover-bg); color: var(--ecp-arrow-hover-color, var(--ecp-arrow-color)); }

/* Category filter */
.ecp-cat-filter {
  height: 34px; padding: 0 10px;
  border: 1.5px solid rgba(255,255,255,.25); border-radius: 8px;
  background: rgba(255,255,255,.12); color: var(--ecp-nav-text);
  font-size: .8rem; font-family: var(--ecp-font); cursor: pointer;
}
.ecp-cat-filter option { color: #1f2937; background: #fff; }

/* View buttons */
.ecp-view-btns { display: flex; border: 1.5px solid rgba(255,255,255,.25); border-radius: 8px; overflow: hidden; }
.ecp-vbtn {
  display: flex; align-items: center; gap: 5px;
  padding: 7px 12px; background: rgba(255,255,255,.1);
  border: none; border-right: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.75); font-size: .78rem; font-weight: 600;
  font-family: var(--ecp-font); cursor: pointer; transition: background .15s, color .15s;
}
.ecp-vbtn:last-child { border-right: none; }
.ecp-vbtn:hover      { background: rgba(255,255,255,.2); color: #fff; }
.ecp-vbtn.active     { background: rgba(255,255,255,.28); color: #fff; }
.ecp-vbtn svg        { flex-shrink: 0; }
@media (max-width: 600px) { .ecp-vbtn span { display: none; } }

/* iCal link */
.ecp-ical-link {
  display: inline-flex; align-items: center; gap: 5px; height: 34px; padding: 0 12px;
  border: 1.5px solid rgba(255,255,255,.3); border-radius: 8px;
  color: rgba(255,255,255,.85); font-size: .78rem; font-weight: 600;
  text-decoration: none; font-family: var(--ecp-font);
  transition: background .15s, color .15s;
}
.ecp-ical-link:hover { background: rgba(255,255,255,.15); color: #fff; }

/* ================================================================
   VIEWS CONTAINER
================================================================ */
.ecp-views { position: relative; }

.ecp-view { display: none; }
.ecp-view.active { display: block; }

/* ================================================================
   MONTH GRID
================================================================ */
.ecp-view-month {
  font-family: var(--ecp-font);
  font-size: var(--ecp-grid-font-size);
  background: var(--ecp-grid-bg);
}

.ecp-grid-wrap { overflow: hidden; border: calc(var(--ecp-grid-line-width)) solid var(--ecp-grid-line); border-radius: 0 0 10px 10px; }

.ecp-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  background: var(--ecp-grid-line);
  gap: var(--ecp-grid-line-width);
}

.ecp-wday {
  background: color-mix(in srgb, var(--ecp-grid-bg) 95%, #000 5%);
  text-align: center; font-weight: 700; font-size: .67rem;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--ecp-grid-text-color); opacity: .55;
  padding: 9px 4px;
}
.ecp-wend-h { opacity: .38; }

.ecp-day {
  min-height: 100px; padding: 6px 4px 4px;
  background: var(--ecp-grid-bg);
  font-size: var(--ecp-grid-font-size);
  font-weight: var(--ecp-grid-font-weight);
  font-style: var(--ecp-grid-font-style);
  text-decoration: var(--ecp-grid-font-decor);
  color: var(--ecp-grid-text-color);
  transition: background .12s; overflow: hidden;
}
.ecp-empty { min-height: 100px; background: color-mix(in srgb, var(--ecp-grid-bg) 70%, #ddd 30%); }
.ecp-day.ecp-wend  { background: var(--ecp-weekend-bg); }
.ecp-day.ecp-today { background: var(--ecp-today-bg); }
.ecp-day:has(.ecp-pill):hover { background: var(--ecp-cell-hover-bg); cursor: pointer; }

.ecp-dn {
  display: inline-block; font-size: var(--ecp-grid-daynum-size);
  font-weight: var(--ecp-grid-daynum-weight); color: var(--ecp-grid-daynum-color);
  margin-bottom: 3px; line-height: 1; width: 22px; text-align: center;
}
.ecp-today .ecp-dn {
  background: var(--ecp-nav-bg); color: #fff; border-radius: 50%;
  width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center;
}

/* Pills */
.ecp-pill {
  display: flex; align-items: center; gap: 4px;
  border-radius: var(--ecp-pill-radius);
  padding: 2px 7px; margin-bottom: 2px;
  color: var(--ecp-pill-text);
  font-size: var(--ecp-pill-font-size);
  font-weight: var(--ecp-pill-font-weight);
  line-height: 1.35; overflow: hidden; cursor: pointer;
  transition: opacity .15s, transform .1s;
}
.ecp-pill:hover { opacity: .82; transform: translateX(2px); }
.ecp-pill.ecp-span { border-radius: 0; margin-left: -4px; margin-right: -4px; padding-left: 8px; padding-right: 8px; }
.ecp-pt    { flex: 1; word-break: break-word; min-width: 0; }
.ecp-ptime { opacity: .8; font-size: .65rem; flex-shrink: 0; }

/* ================================================================
   HOVER PREVIEW POPUP
================================================================ */
.ecp-hp {
  position: fixed; z-index: 999990;
  background: var(--ecp-hp-bg);
  border: var(--ecp-hp-border);
  border-radius: var(--ecp-hp-radius);
  box-shadow: var(--ecp-hp-shadow);
  width: 320px; max-width: 90vw;
  overflow: hidden;
  pointer-events: none; /* becomes true when hovered */
  animation: ecpHpIn .1s ease;
}
@keyframes ecpHpIn { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:none} }

.ecp-hp-inner {
  display: flex; cursor: pointer; pointer-events: all;
}
.ecp-hp-img-col {
  width: 120px; max-width: 40%; flex-shrink: 0;
  padding: 8px 0 0 8px;   /* small gap from top and left edges */
}
.ecp-hp-img {
  width: 100%; height: auto; display: block;
  border-radius: 6px;
  object-fit: contain; object-position: top left;
}
.ecp-hp-body {
  flex: 1; padding: 11px 13px 11px 10px; display: flex; flex-direction: column; gap: 4px;
  overflow: hidden;
}
.ecp-hp-top  { display: flex; flex-direction: column; gap: 2px; }
.ecp-hp-date, .ecp-hp-time {
  font-size: var(--ecp-hp-body-size); font-weight: var(--ecp-hp-body-weight);
  font-style: var(--ecp-hp-body-style); color: var(--ecp-hp-text);
  display: flex; align-items: center; gap: 4px;
}
.ecp-hp-lbl { font-weight: 600; }
.ecp-hp-divider { border: none; border-top: 1px solid color-mix(in srgb, var(--ecp-hp-text) 15%, transparent 85%); margin: 3px 0; }
.ecp-hp-title {
  font-size: var(--ecp-hp-title-size); font-weight: var(--ecp-hp-title-weight);
  font-style: var(--ecp-hp-title-style); text-decoration: var(--ecp-hp-title-decor);
  color: var(--ecp-hp-text); line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.ecp-hp-excerpt {
  font-size: var(--ecp-hp-body-size); color: var(--ecp-hp-text); opacity: .72;
  line-height: 1.45; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.ecp-hp-cat {
  display: inline-block; color: #fff; border-radius: 100px;
  padding: 2px 9px; font-size: .68rem; font-weight: 700; margin-top: 2px; align-self: flex-start;
}

/* ================================================================
   LIST VIEW
================================================================ */
.ecp-view-list { font-family: var(--ecp-font); }

.ecp-list-day  { display: flex; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--ecp-grid-line); }
.ecp-list-day:last-child { border-bottom: none; }

.ecp-list-date {
  display: flex; flex-direction: column; align-items: center; min-width: 56px;
  padding: 8px; border-radius: 10px;
  background: color-mix(in srgb, var(--ecp-nav-bg) 12%, transparent 88%);
  text-align: center;
}
.ecp-ld-dname { font-size: .63rem; font-weight: 700; text-transform: uppercase; color: var(--ecp-nav-bg); letter-spacing: .05em; }
.ecp-ld-num   { font-size: 1.5rem; font-weight: 800; color: var(--ecp-grid-daynum-color); line-height: 1.1; }
.ecp-ld-mo    { font-size: .68rem; color: var(--ecp-grid-text-color); opacity: .65; }

.ecp-list-evs { flex: 1; display: flex; flex-direction: column; gap: 8px; }

.ecp-list-ev {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px; border-left: 4px solid transparent;
  border-radius: 0 10px 10px 0; cursor: pointer;
  background: color-mix(in srgb, var(--ecp-grid-bg) 97%, #000 3%);
  transition: background .15s, transform .12s;
}
.ecp-list-ev:hover { background: color-mix(in srgb, var(--ecp-nav-bg) 10%, white 90%); transform: translateX(3px); }

.ecp-list-ev-body { flex: 1; min-width: 0; }
.ecp-lev-title {
  font-size: var(--ecp-grid-font-size); font-weight: 700;
  color: var(--ecp-grid-daynum-color); margin-bottom: 4px;
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.ecp-lev-meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: .75rem; color: var(--ecp-grid-text-color); opacity: .7; align-items: center; }
.ecp-list-tag { color: #fff; border-radius: 100px; padding: 2px 9px; font-size: .68rem; font-weight: 700; }
.ecp-list-btn { flex-shrink: 0; padding: 5px 13px; border: 1.5px solid var(--ecp-nav-bg); border-radius: 8px; font-size: .75rem; font-weight: 600; color: var(--ecp-nav-bg); transition: background .15s,color .15s; white-space: nowrap; }
.ecp-list-ev:hover .ecp-list-btn { background: var(--ecp-nav-bg); color: #fff; }

/* ================================================================
   BOARD VIEW (Pinnwand)
================================================================ */
.ecp-view-board { background: var(--ecp-board-bg); padding: 16px 0; font-family: var(--ecp-font); -webkit-transform: translateZ(0); transform: translateZ(0); }

.ecp-board {
  display: grid;
  grid-template-columns: repeat(var(--ecp-board-grid-cols,4), 1fr);
  gap: 20px;
  align-items: stretch; /* Karten auf gleiche Zeilenhöhe dehnen */
}
/* Masonry layout using CSS columns */
.ecp-board.ecp-board-masonry {
  display: block;
  column-count: var(--ecp-board-masonry-cols,4);
  column-gap: 20px;
}
.ecp-board.ecp-board-masonry .ecp-card {
  break-inside: avoid;
  margin-bottom: 20px;
  display: inline-flex;
  width: 100%;
  align-self: flex-start; /* Masonry: Inhaltshöhe, kein Stretch */
  /* Safari column-count + transform Bug: isolation deaktivieren */
  isolation: auto;
}
/* Masonry Hover: kein transform (Safari column-count Bug) – nur Shadow + margin */
.ecp-board.ecp-board-masonry .ecp-card:hover {
  transform: translateY(1);
  margin-top: -4px;
  margin-bottom: 20px;
  box-shadow: 0 8px 8px rgba(0,0,.60,.14);
}
/* Responsive breakpoints — override desktop var with fixed values */
/* Tablet portrait + Mobile landscape → 2 cols */
@media (max-width: 900px) and (orientation:portrait),
       (max-width: 767px) and (orientation:landscape) {
  .ecp-board                       { grid-template-columns: repeat(2,1fr) !important; }
  .ecp-board.ecp-board-masonry     { column-count: 2 !important; }
}
/* Tablet landscape → 3 cols */
@media (min-width: 768px) and (max-width: 1100px) and (orientation:landscape) {
  .ecp-board                       { grid-template-columns: repeat(3,1fr) !important; }
  .ecp-board.ecp-board-masonry     { column-count: 3 !important; }
}
/* Mobile portrait → 1 col */
@media (max-width: 600px) and (orientation:portrait) {
  .ecp-board                       { grid-template-columns: 1fr !important; }
  .ecp-board.ecp-board-masonry     { column-count: 1 !important; }
}

.ecp-card {
  background: var(--ecp-card-bg); border: var(--ecp-card-border); border-radius: var(--ecp-card-radius);
  overflow: hidden; cursor: pointer; display: flex; flex-direction: column;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease;
  /* Safari: isolation verhindert Compositing-Konflikte ohne GPU-Layer-Explosion */
  isolation: isolate;
}
.ecp-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 36px rgba(0,0,0,.12);
}

.ecp-card-bar  { height: 4px; flex-shrink: 0; }
.ecp-card-img  { overflow: hidden; }
.ecp-card-img img { width: 100%; height: auto; display: block; }

.ecp-card-body { padding: 16px; flex: 1; }
/* .ecp-card-cat moved to card-foot section — uses CSS vars now */
.ecp-card-meta {
  display: flex; flex-direction: column; gap: 3px; margin-bottom: 10px;
}
.ecp-card-meta-date {
  font-size: var(--ecp-card-date-size, 12px);
  font-weight: var(--ecp-card-date-wt, 400);
  font-style: var(--ecp-card-date-st, normal);
  text-decoration: var(--ecp-card-date-dc, none);
  color: var(--ecp-card-date-color, #6b7280);
}
.ecp-card-meta-time,
.ecp-card-meta-loc {
  font-size: var(--ecp-card-oc-size, 12px);
  font-weight: var(--ecp-card-oc-wt, 400);
  font-style: var(--ecp-card-oc-st, normal);
  text-decoration: var(--ecp-card-oc-dc, none);
  color: var(--ecp-card-oc-color, #6b7280);
}
.ecp-card-title {
  font-size: var(--ecp-card-title-size); font-weight: var(--ecp-card-title-wt);
  font-style: var(--ecp-card-title-st); text-decoration: var(--ecp-card-title-dc);
  color: var(--ecp-card-title-color, var(--ecp-card-text)); line-height: 1.3; margin: 0 0 8px;
}
.ecp-card-excerpt {
  font-size: var(--ecp-card-body-size);
  font-weight: var(--ecp-card-body-wt, 400);
  font-style: var(--ecp-card-body-st, normal);
  text-decoration: var(--ecp-card-body-dc, none);
  color: var(--ecp-card-body-color, var(--ecp-card-text));
  line-height: 1.5; margin: 0;
}
.ecp-card-foot {
  padding: 10px 16px;
  border-top: 1px solid color-mix(in srgb, var(--ecp-card-bg) 80%, #000 20%);
  display: flex; align-items: center;
}
.ecp-card-cat, .ecp-modal-tag, .ecp-hp-cat, .ecp-list-tag {
  display: inline-block;
  color: var(--ecp-cat-tag-color);
  /* background set inline per category */
  border-radius: var(--ecp-cat-tag-radius);
  border: var(--ecp-cat-tag-border);
  padding: 3px 12px;
  font-size: var(--ecp-cat-tag-size);
  font-weight: 700;
  transition: color .14s, opacity .14s, border-color .14s;
}

.ecp-card-loc-link {
  color: var(--ecp-card-oc-color, var(--ecp-card-meta-color)); text-decoration: underline dotted;
}
.ecp-card-loc-link:hover { color: var(--ecp-card-loc-hover, var(--ecp-nav-bg)); }

/* ================================================================
   MODAL / POPUP  (with visible X button)
================================================================ */
.ecp-modal {
  position: fixed; inset: 0; z-index: 999999;
  display: flex; align-items: center; justify-content: center;
  padding: 20px; font-family: var(--ecp-font);
}
.ecp-modal-bd {
  position: absolute; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(4px);
  cursor: pointer;
}
.ecp-modal-box {
  position: relative; background: var(--ecp-modal-bg); color: var(--ecp-modal-text);
  border: var(--ecp-modal-border); border-radius: var(--ecp-modal-radius);
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
  max-width: 720px; width: 100%; max-height: 92vh;
  display: flex; flex-direction: column; overflow: hidden;
  animation: ecpPopIn .2s cubic-bezier(.34,1.56,.64,1);
}
/* Scrollbarer Inhaltsbereich – Button bleibt oben rechts stehen */
.ecp-modal-scroll {
  overflow-y: auto; flex: 1;
}
@keyframes ecpPopIn { from{opacity:0;transform:scale(.93)translateY(14px)} to{opacity:1;transform:none} }

/* CLOSE BUTTON – absolut in der oberen rechten Ecke (wie Mini-Detail) */
.ecp-modal-x {
  position: absolute;
  top: 12px; right: 12px;
  z-index: 10;
  padding: var(--ecp-modal-close-padding, 9px);
  width: auto; height: auto; /* Größe folgt Icon + Padding */
  border-radius: var(--ecp-modal-close-radius, 50%);
  background: var(--ecp-modal-close-bg, rgba(0,0,0,.08));
  border: var(--ecp-modal-close-border, none);
  color: var(--ecp-modal-close-color, var(--ecp-modal-text));
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .15s;
}
.ecp-modal-x:hover {
  background: var(--ecp-modal-close-hbg, rgba(0,0,0,.18));
}
.ecp-modal-x svg   {
  pointer-events: none; display: block;
  width:  var(--ecp-modal-close-icon-size, 18px);
  height: var(--ecp-modal-close-icon-size, 18px);
  color: inherit; stroke: currentColor;
  transition: color .15s;
}
.ecp-modal-x:hover svg { color: var(--ecp-modal-close-hcolor, var(--ecp-modal-close-color, var(--ecp-modal-text))); }

/* Loader */
.ecp-loader { display: flex; align-items: center; justify-content: center; padding: 60px; }
.ecp-spin {
  width: 34px; height: 34px;
  border: 3px solid color-mix(in srgb, var(--ecp-nav-bg) 20%, transparent 80%);
  border-top-color: var(--ecp-nav-bg); border-radius: 50%;
  animation: ecpSpin .7s linear infinite;
}
@keyframes ecpSpin { to{transform:rotate(360deg)} }

/* Event detail layout */
.ecp-modal-img-wrap { width: 100%; overflow: hidden; border-radius: var(--ecp-modal-radius) var(--ecp-modal-radius) 0 0; }
.ecp-modal-img      { width: 100%; max-height: 300px; object-fit: cover; display: block; }
.ecp-modal-body     { padding: 24px 28px 28px; }

.ecp-modal-title {
  font-size: var(--ecp-modal-title-size); font-weight: var(--ecp-modal-title-wt);
  font-style: var(--ecp-modal-title-st); text-decoration: var(--ecp-modal-title-dc);
  color: var(--ecp-modal-text); margin: 0 0 16px; line-height: 1.25;
}

/* Two-column layout: meta left, description right */
.ecp-modal-layout {
  display: grid; grid-template-columns: 220px 1fr; gap: 24px; margin-bottom: 20px;
}
@media (max-width: 580px) { .ecp-modal-layout { grid-template-columns: 1fr; } }

.ecp-modal-meta {
  background: var(--ecp-modal-meta-bg, color-mix(in srgb, var(--ecp-modal-bg) 94%, #000 6%));
  border-radius: var(--ecp-modal-meta-radius, 10px);
  border: var(--ecp-modal-meta-border, none);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 10px; align-self: flex-start;
}
.ecp-meta-row {
  display: flex; flex-direction: column; gap: 2px;
  font-size: var(--ecp-modal-meta-size);
  font-weight: var(--ecp-modal-meta-wt, 400);
  font-style: var(--ecp-modal-meta-st, normal);
  text-decoration: var(--ecp-modal-meta-dc, none);
}
.ecp-meta-lbl     { font-weight: 700; color: var(--ecp-modal-text); opacity: .55; font-size: .8em; }
.ecp-meta-loc     { }
.ecp-maps-btn {
  display: inline-flex; align-items: center;
  padding: 3px 10px;
  background: var(--ecp-maps-bg); color: var(--ecp-maps-color);
  border-radius: var(--ecp-maps-radius); border: var(--ecp-maps-border);
  font-size: var(--ecp-maps-size); font-weight: 700; text-decoration: none;
  white-space: nowrap; transition: opacity .15s;
}
.ecp-maps-btn:hover { opacity: .82; text-decoration: none; }

.ecp-modal-tags   { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.ecp-modal-tag {
  display: inline-block; color: var(--ecp-cat-tag-color);
  border-radius: var(--ecp-cat-tag-radius); border: var(--ecp-cat-tag-border);
  padding: 3px 11px; font-size: var(--ecp-cat-tag-size); font-weight: 700;
}

.ecp-modal-content {
  font-size: var(--ecp-modal-body-size);
  font-weight: var(--ecp-modal-body-wt);
  font-style: var(--ecp-modal-body-st, normal);
  line-height: 1.65; color: var(--ecp-modal-text);
}
.ecp-modal-content p { margin: 0 0 10px; }
.ecp-modal-content a, .ecp-mcd-content a {
  color: var(--ecp-nav-bg); text-decoration: underline;
}
.ecp-modal-content a:hover, .ecp-mcd-content a:hover {
  opacity: .8; text-decoration: underline;
}

.ecp-modal-footer {
  margin-top: 20px; padding-top: 16px;
  border-top: 1px solid color-mix(in srgb, var(--ecp-modal-bg) 80%, #000 20%);
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
}
.ecp-btn-outline {
  display: inline-flex; align-items: center; gap: 6px; padding: 7px 16px;
  border: 1.5px solid var(--ecp-nav-bg); border-radius: 8px;
  color: var(--ecp-nav-bg); font-size: .8rem; font-weight: 600;
  text-decoration: none; transition: background .15s, color .15s;
  font-family: var(--ecp-font);
}
.ecp-btn-outline:hover { background: var(--ecp-nav-bg); color: #fff; }

/* ================================================================
   MINI CALENDAR
================================================================ */
.ecp-mini-wrap { font-family: var(--ecp-font); color: var(--ecp-mini-text); }

.ecp-mini-cal {
  border: var(--ecp-mini-border); border-radius: var(--ecp-mini-radius);
  overflow: hidden; background: var(--ecp-mini-bg);
}

.ecp-mini-hdr {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--ecp-mini-header-bg); padding: 10px 14px;
}
.ecp-mini-title { font-size: .9rem; font-weight: 700; color: var(--ecp-mini-header-text); }
.ecp-mini-nav {
  background: rgba(255,255,255,.15); border: none; color: var(--ecp-mini-header-text);
  width: 26px; height: 26px; border-radius: 6px; font-size: 1.1rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.ecp-mini-nav:hover { background: rgba(255,255,255,.28); }

.ecp-mini-grid { display: grid; grid-template-columns: repeat(7,1fr); background: var(--ecp-mini-grid-line); gap: 1px; }

.ecp-mc {
  aspect-ratio: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  background: var(--ecp-mini-bg); position: relative;
  font-size: var(--ecp-mini-font-size);
}
.ecp-mc-wday  { font-weight: 700; font-size: .6rem; text-transform: uppercase; color: var(--ecp-mini-text); opacity: .5; cursor: default; }
.ecp-mc-empty { background: color-mix(in srgb, var(--ecp-mini-bg) 80%, #ddd 20%); }
.ecp-mc-today { background: var(--ecp-mini-today-bg); }
.ecp-mc-today .ecp-mc-num { background: var(--ecp-mini-header-bg); color: #fff; border-radius: 50%; width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; }
.ecp-mc-has { cursor: pointer; }
.ecp-mc-has:hover { background: color-mix(in srgb, var(--ecp-mini-header-bg) 12%, var(--ecp-mini-bg) 88%); }
.ecp-mc-num { font-size: .72rem; font-weight: 600; color: var(--ecp-mini-text); line-height: 1; }
.ecp-mc-dots { display: flex; gap: 2px; flex-wrap: wrap; justify-content: center; position: absolute; bottom: 2px; }
.ecp-mc-dot  { width: 5px; height: 5px; border-radius: 50%; cursor: pointer; }

/* Mini list */
.ecp-mini-list { margin-top: 10px; }
.ecp-mini-li {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 7px 0; border-bottom: 1px solid var(--ecp-mini-grid-line);
  cursor: pointer;
}
.ecp-mini-li:last-child { border-bottom: none; }
.ecp-mini-li:hover .ecp-mini-li-title { color: var(--ecp-mini-header-bg); }
.ecp-mini-dot2     { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.ecp-mini-li-info  { display: flex; flex-direction: column; gap: 1px; }
.ecp-mini-li-title { font-size: var(--ecp-mini-title-size); font-weight: var(--ecp-mini-title-wt); color: var(--ecp-mini-text); transition: color .15s; }
.ecp-mini-li-date  { font-size: .72rem; color: var(--ecp-mini-text); opacity: .6; }

/* Mini inline detail */
.ecp-mini-detail {
  margin-top: 12px; border: var(--ecp-mini-border); border-radius: var(--ecp-mini-radius);
  background: var(--ecp-modal-bg); padding: 16px; position: relative;
  animation: ecpFade .2s ease;
}
.ecp-mini-detail-x {
  position: absolute; top: 10px; right: 10px; background: rgba(0,0,0,.08);
  border: none; width: 28px; height: 28px; border-radius: 50%;
  cursor: pointer; font-size: 1rem; display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.ecp-mini-detail-x:hover { background: rgba(0,0,0,.16); }

@keyframes ecpFade { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:none} }

/* ================================================================
   SHARED
================================================================ */
.ecp-empty-msg {
  text-align: center; padding: 48px 20px;
  color: var(--ecp-grid-text-color); opacity: .4; font-style: italic;
  font-family: var(--ecp-font);
}

/* Body scroll lock */
body.ecp-lock { overflow: hidden !important; }

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width: 768px) {
  .ecp-navbar      { gap: 8px; }
  .ecp-navbar-left { order: 1; width: 100%; justify-content: space-between; }
  .ecp-navbar-center { order: 0; width: 100%; justify-content: center; }
  .ecp-navbar-right { order: 2; width: 100%; justify-content: flex-end; }
  .ecp-day { min-height: 64px; }
  .ecp-ptime { display: none; }
  .ecp-list-day { flex-direction: column; gap: 8px; }
  .ecp-list-date { flex-direction: row; align-items: center; gap: 8px; width: 100%; }
  .ecp-modal-body { padding: 18px 18px 22px; }
  .ecp-search { width: 130px; }
  .ecp-search:focus { width: 160px; }
}

@media (max-width: 480px) {
  .ecp-day { min-height: 46px; padding: 2px 2px; }
  .ecp-pill { padding: 1px 5px; font-size: .62rem; }
  .ecp-pt   { max-width: 70px; }
  .ecp-hp   { display: none !important; } /* no hover preview on touch */
}

/* ================================================================
/* ================================================================
/* ================================================================
/* ================================================================
   v2.2.1 ADDITIONS
================================================================ */

/* ---- Navbar elements ---- */
.ecp-search, .ecp-today-btn, .ecp-cat-filter {
  font-size: var(--ecp-nel-size) !important; font-weight: var(--ecp-nel-weight) !important;
  color: var(--ecp-nel-color) !important; background: var(--ecp-nel-bg) !important;
  border: var(--ecp-nel-border) !important; border-radius: var(--ecp-nel-radius) !important;
}
.ecp-vbtn {
  font-size: var(--ecp-nel-size) !important; font-weight: var(--ecp-nel-weight) !important;
  color: var(--ecp-nel-color) !important; background: var(--ecp-nel-bg) !important;
}
.ecp-vbtn.active { background: var(--ecp-nel-active-bg) !important; color: var(--ecp-nel-active-color) !important; }
.ecp-view-btns   { border: var(--ecp-nel-border); border-radius: var(--ecp-nel-radius); }
.ecp-search::placeholder { color: var(--ecp-nel-color); opacity: .6; }
.ecp-cat-filter option   { color: #1f2937; background: #fff; }

/* ---- Hover Preview ---- */
.ecp-hp { font-family: var(--ecp-font); }
.ecp-hp-loc { font-size: var(--ecp-hp-body-size); color: var(--ecp-hp-text); opacity: .65; margin: 0; }
.ecp-pill   { flex-wrap: wrap; gap: 2px; }
.ecp-ptime  { font-size: .62rem; opacity: .82; flex-shrink: 0; }

/* ================================================================
   SHARE BUTTONS v2.2.2.2
   Pure icon, no background, no border — black, hover = brand color
================================================================ */
.ecp-share-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  cursor: pointer;
  text-decoration: none;
  color: #111 !important;
  padding: 0;
  border-radius: 0 !important;
  transition: color .17s ease, transform .12s ease;
  flex-shrink: 0;
}
.ecp-share-icon svg { display: block; pointer-events: none; }
.ecp-share-icon:hover { transform: translateY(-2px); text-decoration: none; }

/* Brand colors on hover */
.ecp-share-icon.ecp-share-cal:hover  { color: #1a73e8 !important; }
.ecp-share-icon.ecp-share-copy:hover { color: #374151 !important; }
.ecp-share-icon.ecp-share-mail:hover { color: #ea4335 !important; }
.ecp-share-icon.ecp-share-fb:hover   { color: #1877f2 !important; }
.ecp-share-icon.ecp-share-x:hover    { color: #000    !important; }
.ecp-share-icon.ecp-share-ext:hover  { color: var(--ecp-nav-bg) !important; }

/* Modal footer share row */
.ecp-modal-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  align-items: center;
  margin-top: 20px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,.09);
}

/* Toast */
.ecp-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: #1f2937; color: #fff; border-radius: 10px; padding: 10px 22px;
  font-size: .85rem; font-weight: 600; z-index: 9999999; pointer-events: none;
  animation: ecpToastIn .2s ease;
}
@keyframes ecpToastIn { from{opacity:0;transform:translateX(-50%) translateY(10px)} to{opacity:1;transform:translateX(-50%)} }

/* ================================================================
   CALENDAR PICKER POPUP
================================================================ */
.ecp-cal-picker { position: fixed; inset: 0; z-index: 9999998; display: flex; align-items: center; justify-content: center; }
.ecp-cal-picker-bd { position: absolute; inset: 0; background: rgba(0,0,0,.45); backdrop-filter: blur(3px); }
.ecp-cal-picker-box {
  position: relative; z-index: 1; background: #fff; border-radius: 16px;
  box-shadow: 0 24px 80px rgba(0,0,0,.22); padding: 28px 24px 20px;
  min-width: 280px; max-width: 340px; width: 90vw;
  animation: ecpPickerIn .22s cubic-bezier(.34,1.56,.64,1);
}
@keyframes ecpPickerIn { from{opacity:0;transform:scale(.88)} to{opacity:1;transform:scale(1)} }
.ecp-cal-picker-title { font-size: 1rem; font-weight: 700; color: #111; margin: 0 0 18px; text-align: center; }
.ecp-cal-picker-list  { display: flex; flex-direction: column; gap: 10px; }
.ecp-cal-picker-opt {
  display: flex; align-items: center; gap: 14px; padding: 12px 16px; border-radius: 10px;
  cursor: pointer; border: 1.5px solid #e5e7eb; text-decoration: none;
  color: #1f2937; font-size: .92rem; font-weight: 500; transition: border-color .14s, background .14s;
}
.ecp-cal-picker-opt:hover { border-color: var(--ecp-nav-bg); background: #f0f6ff; color: #111; }
.ecp-cal-picker-opt-icon { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 18px; }
.ecp-cal-picker-opt-label strong { display: block; }
.ecp-cal-picker-opt-label small  { color: #6b7280; font-size: .78rem; }
.ecp-cal-picker-cancel { display: block; width: 100%; margin-top: 14px; padding: 9px; background: none; border: none; cursor: pointer; font-size: .85rem; color: #6b7280; text-align: center; }
.ecp-cal-picker-cancel:hover { color: #111; }

/* ================================================================
   DATE PICKER
================================================================ */
#ecp-mini-picker {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 99999;
  background: #fff; border: 1px solid #e0e0e0; border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.16); padding: 12px; width: 264px;
}
.ecp-date-pick-wrap { position: relative; }
/* mobile: same design, JS-positioned to stay within viewport */
/* Mobil (schmal) + Landscape (niedrig): Picker per JS fixed positioniert */
@media (max-width: 640px), (max-height: 500px) {
  #ecp-mini-picker {
    position: fixed !important;
    width: min(264px, 94vw);
    max-width: min(264px, 94vw) !important;
    /* top/left werden per JS gesetzt */
  }
}
.ecp-dp-cell.selected { background: rgba(0,0,0,.07); font-weight: 700; outline: 2px solid var(--ecp-nav-bg); border-radius: 4px; }
.ecp-dp-today-link { display: block; text-align: center; margin-top: 8px; padding: 6px; font-size: .78rem; font-weight: 700; color: var(--ecp-nav-bg); border-top: 1px solid #f0f0f0; cursor: pointer; border-radius: 6px; transition: background .12s; }
.ecp-dp-today-link:hover { background: #f0f6ff; }

/* ================================================================
   MINI COMPACT DETAIL — all driven by CSS vars (v2.2.2.2)
   Layout matches sketch: Title → Date/Time → Category → Location
   → [Image LEFT, Text wraps right then below] → Share Buttons
================================================================ */
.ecp-mini-compact-detail {
  font-family: var(--ecp-font);
  background: var(--ecp-mcd-bg);
  color: var(--ecp-mcd-color);
  border: var(--ecp-mcd-border);
  border-radius: var(--ecp-mcd-radius);
  padding: 16px 16px 12px;
  margin-top: 10px;
  line-height: 1.5;
}

/* 1 — Eventtitel */
.ecp-mcd-title {
  font-size:       var(--ecp-mcd-title-size);
  font-weight:     var(--ecp-mcd-title-wt);
  font-style:      var(--ecp-mcd-title-st);
  text-decoration: var(--ecp-mcd-title-dc);
  color:           var(--ecp-mcd-color);
  margin: 0 0 5px;
  line-height: 1.25;
}

/* 2 — Datum · Zeit (gleiche Zeile, Trenner) */
.ecp-mcd-datetime {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 4px;
  margin-bottom: 5px;
}
.ecp-mcd-date, .ecp-mcd-time {
  font-size:       var(--ecp-mcd-time-size);
  font-weight:     var(--ecp-mcd-time-wt);
  font-style:      var(--ecp-mcd-time-st);
  text-decoration: var(--ecp-mcd-time-dc);
  color:           var(--ecp-mcd-color);
}
.ecp-mcd-time   { opacity: .72; }
.ecp-mcd-sep    { opacity: .4; font-size: var(--ecp-mcd-time-size); color: var(--ecp-mcd-color); }

/* 3 — Kategorien */
.ecp-mcd-cats { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 5px; }

/* 4 — Ort */
.ecp-mcd-loc {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 12px;
  font-size:       var(--ecp-mcd-loc-size);
  font-weight:     var(--ecp-mcd-loc-wt);
  font-style:      var(--ecp-mcd-loc-st);
  text-decoration: var(--ecp-mcd-loc-dc);
  color:           var(--ecp-mcd-color);
  opacity: .82;
}
.ecp-mcd-loc .ecp-maps-btn { flex-shrink: 0; margin-top: 0; opacity: 1; }

/* 5 — Bild + Beschreibung
   Bild: float left ~55% Breite, Beschreibungstext fließt rechts herum
   dann unterhalb des Bildes über volle Breite                          */
.ecp-mcd-body {
  overflow: hidden;   /* clearfix */
  margin-bottom: 12px;
}
.ecp-mcd-img {
  float: left;
  width: 55%;
  max-width: 260px;
  height: auto;
  border-radius: 6px;
  margin: 0 14px 10px 0;
  display: block;
}
.ecp-mcd-content {
  /* text naturally wraps around the float, then continues full-width below */
  font-size:       var(--ecp-mcd-desc-size);
  font-weight:     var(--ecp-mcd-desc-wt);
  font-style:      var(--ecp-mcd-desc-st);
  text-decoration: var(--ecp-mcd-desc-dc);
  color:           var(--ecp-mcd-color);
  line-height: 1.58;
}
.ecp-mcd-content p { margin: 0 0 8px; }
.ecp-mcd-content p:last-child { margin-bottom: 0; }

/* 6 — Share Buttons */
.ecp-mcd-share {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  align-items: center;
  padding-top: 10px;
  border-top: 1px solid rgba(0,0,0,.07);
}
.ecp-mcd-share .ecp-share-icon {
  width: 28px;
  height: 28px;
}

/* ---- Mini widget list: location line ---- */
.ecp-mini-li-loc { font-size: .7rem; color: var(--ecp-mini-text); opacity: .6; display: block; margin-top: 1px; }

/* ---- Full modal image: full-width top, no float ---- */
#ecp-modal .ecp-modal-img-wrap { float: none; width: 100%; margin: 0; border-radius: var(--ecp-modal-radius) var(--ecp-modal-radius) 0 0; }
#ecp-modal .ecp-modal-img { max-height: 300px; width: 100%; object-fit: cover; }

/* ================================================================
   ADMIN — rgba color field swatch (v2.2.2.2)
================================================================ */
.ecp-rgba-wrap    { display: flex; align-items: center; gap: 8px; }
.ecp-rgba-swatch  { width: 26px; height: 26px; border-radius: 4px; flex-shrink: 0; border: 1px solid rgba(0,0,0,.15); }
.ecp-rgba-hint    { font-size: 11px; color: #888; margin: 2px 0 0; }

/* ================================================================
   MINI CALENDAR "WEITERE TERMINE" BUTTON
================================================================ */
.ecp-mini-more-btn {
  display: block; width: 100%; margin-top: 6px; padding: 7px 12px;
  background: var(--ecp-mini-more-bg);
  border: var(--ecp-mini-more-border);
  border-radius: var(--ecp-mini-more-radius);
  cursor: pointer; font-family: var(--ecp-font);
  font-size: var(--ecp-mini-more-size);
  font-weight: var(--ecp-mini-more-weight);
  color: var(--ecp-mini-more-color);
  text-align: center; transition: opacity .15s;
}
.ecp-mini-more-btn:hover { opacity: .75; }
