/* TEC Events Shortcode – erweitertes Styling */
.tesc{
  --tesc-border:rgba(0,0,0,.08);
  --tesc-primary:#007aff;
  --tesc-fg:#0a0a0a;
  --tesc-muted:#555;
  --tesc-bg:#f7f9ff;
  --tesc-hover-rgb:143,175,76; /* per Settings/Shortcode konfigurierbar */
  --tesc-shine-o:.65;          /* per shine/hover_strength */
  --tesc-date-weight:800;
}
.tesc{background:none;border:0;box-shadow:none;padding:0}

/* Shine intensity classes (fallback if no hover_strength numeric) */
.tesc--shine-off { --tesc-shine-o: 0; }
.tesc--shine-soft { --tesc-shine-o: .35; }
.tesc--shine-medium { --tesc-shine-o: .65; }
.tesc--shine-strong { --tesc-shine-o: .9; }

/* Wrapper-Schalter */
.tesc--bg .tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}

/* Liste & Grid */
.tesc__list{list-style:none;margin:0;padding:0;display:grid;gap:var(--tesc-gap,1rem)}
.tesc--view-grid .tesc__list{list-style:none;margin:0;padding:0;display:grid;gap:var(--tesc-gap,1rem)}

/* Radius-Logiken */
.tesc--view-list .tesc__item{ border-radius:0 !important }
.tesc--radius-none .tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}
.tesc--radius-grid-none.tesc--view-grid .tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}
.tesc--radius-hover .tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}
.tesc--radius-hover .tesc__item:hover, .tesc--radius-hover .tesc__item:focus-visible{ border-radius:16px }

/* Kachel ist ein Link */
.tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}

/* Green-Glow Hover (ohne !important); !important-Version wird via .tesc--hi ergänzt */
.tesc__item:hover,
.tesc__item:focus-visible{
  background: rgba(var(--tesc-hover-rgb),.5);
  border-color: rgba(var(--tesc-hover-rgb),.8);
  box-shadow: 0 0 15px rgba(var(--tesc-hover-rgb),.4),
               0 0 5px  rgba(var(--tesc-hover-rgb),.5) inset,
               var(--rg-menu-shadow, 0 0 0 rgba(0,0,0,0));
  transform: translateY(-1px);
  outline: none;
  color: var(--tesc-hover-text,#000);
}
/* Optional: spezieller Titel-Hover, wenn gesetzt */
.tesc__item:hover .tesc__title,
.tesc__item:focus-visible .tesc__title{ color: var(--tesc-title-color-hover, var(--tesc-title-color, inherit)); }
/* Optional: wichtigere Variante per Container-Klasse */
.tesc--hi .tesc__item:hover,
.tesc--hi .tesc__item:focus-visible{
  background: rgba(var(--tesc-hover-rgb),.5) !important;
  border-color: rgba(var(--tesc-hover-rgb),.8) !important;
  color: var(--tesc-hover-text,#000) !important;
}
/* Wichtige Variante für Titel-Hover, wenn .tesc--hi aktiv ist */
.tesc--hi .tesc__item:hover .tesc__title,
.tesc--hi .tesc__item:focus-visible .tesc__title{ color: var(--tesc-title-color-hover, var(--tesc-title-color, inherit)) !important; }

/* Glanz-Schimmer */
.tesc__item::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.4),rgba(255,255,255,.08));
  opacity:0;transition:opacity .14s ease;pointer-events:none
}
.tesc__item:hover::before, .tesc__item:focus-visible::before{opacity:var(--tesc-shine-o,.65)}

/* Media-Block */
.tesc__media{position:relative;width:120px;aspect-ratio:var(--tesc-ratio, 1 / 1);border-radius:12px;overflow:hidden;border:1px solid var(--tesc-border)}
.tesc__media--image .tesc__thumb img{width:100%;height:100%;object-fit:cover;display:block}
.tesc__thumb{margin:0;width:100%;height:100%}
.tesc__thumb-bg{position:absolute;inset:0;background-size:cover;background-position:center}

/* Date cards */
.tesc__datecard,.tesc__dateglass{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:.5rem .6rem;height:100%;width:100%}
.tesc__datecard{background:linear-gradient(180deg,#f7f9ff 0%,#eef3ff 100%)}
.tesc__dateglass{background:rgba(255,255,255,.35);-webkit-backdrop-filter:blur(8px) saturate(160%);backdrop-filter:blur(8px) saturate(160%); border:1px solid rgba(255,255,255,.5)}
.tesc__date-top{font-size:.85rem;font-weight:800;letter-spacing:.02em;align-self:flex-start;color:#0b1a3a;text-shadow:0 1px 2px rgba(255,255,255,.6)}
.tesc__date-month{font-size:1.15rem;font-weight:var(--tesc-date-weight);letter-spacing:.08em;text-align:center;color:#0b1a3a;text-shadow:0 1px 2px rgba(255,255,255,.7)}
.tesc--date-upper .tesc__date-month{ text-transform: uppercase; }

/* Grid-Variante */
.tesc--view-grid .tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}
.tesc--view-grid .tesc__media{width:100%}

/* Content */
.tesc__content{min-width:0}
.tesc__title{margin:0;font-size:var(--tesc-title-size,1.05rem);line-height:1.3;color:var(--tesc-title-color,inherit)}
.tesc__meta{font-size:var(--tesc-meta-size,.9rem);color:var(--tesc-muted);display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline}
.tesc__venue{font-style:italic}
.tesc__excerpt{margin:.35rem 0 0;color:var(--tesc-fg)}
.tesc--excerpt-clamp .tesc__excerpt{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;-webkit-line-clamp:var(--tesc-excerpt-lines, 0)}

.tesc__group-title{margin:.5rem 0 .25rem;font-size:.95rem;color:var(--tesc-muted)}
.tesc__empty{margin:0;padding:.5rem;color:var(--tesc-muted)}
.tesc__more{text-align:center;margin-top:.75rem}
.tesc__more-link{display:inline-block;padding:.5rem .9rem;border-radius:999px;border:1px solid var(--tesc-primary);color:#fff;background:var(--tesc-primary);text-decoration:none}
.tesc__more-link:hover,.tesc__more-link:focus-visible{filter:brightness(.95)}

/* Fokus-Ring Varianten */
.tesc--focus-green .tesc__item:focus-visible{ box-shadow:0 0 0 var(--tesc-focus-w,3px) rgba(143,175,76,.45), 0 12px 24px rgba(0,0,0,.12) }
.tesc--focus-blue  .tesc__item:focus-visible{ box-shadow:0 0 0 var(--tesc-focus-w,3px) rgba(0,122,255,.35), 0 12px 24px rgba(0,0,0,.12) }
.tesc--focus-none  .tesc__item:focus-visible{ box-shadow:none }

@media (prefers-reduced-motion:reduce){
  .tesc__item{
  position:relative;display:grid;grid-template-columns:120px 1fr;gap:.8rem;align-items:start;
  border-radius:16px;padding:var(--tesc-pad,.6rem);text-decoration:none;color:inherit;
  border:var(--tesc-border-w,1px) solid var(--tesc-border, rgba(0,0,0,.08));
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease,border-color .14s ease, background-color .14s ease;
}
}

/* Force per-item background when background=1 */
.tesc__item--bg{ background: var(--tesc-bg) }
