/* === Termin Node – Full View ========================================== */
.termin-node{
  --rail-w: clamp(56px, 8vw, 96px);
  --rail-r: 20px;
  --rail-grad: linear-gradient(180deg,#FFE08A 0%,#E9C25D 52%,#D4AF37 100%);

  /* exakt wie im Block (ms-events.css) */
  --brand:#b88b3b;
  --brand-ink:#7a5c26;
  --line:rgba(0,0,0,.12);

  display:grid;
  grid-template-columns: var(--rail-w) 1fr;
  gap: clamp(14px,1.2vw,18px);
}

/* Gold-Rail */
.termin-node .tn-rail{
  align-self: stretch;
  background: var(--rail-grad);
  border-radius: var(--rail-r);
  box-shadow: 0 10px 26px rgba(212,175,55,.28), inset 0 0 0 1px rgba(255,255,255,.35);
  display:flex; align-items:center; justify-content:center;
  padding: clamp(6px, 0.9vw, 10px);
  min-height: clamp(140px, 12vw, 260px);
}
.tn-rail__text{
  color:#fff;
  font-weight:1000;
  font-size: clamp(1.2rem, calc(var(--rail-w) * 0.38), 2.4rem);
  line-height:1;
  white-space: nowrap;
  transform: rotate(-90deg);
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
  letter-spacing:.02em;
}

/* Rahmen der Node-Seite neutralisieren */
.page-node-type-termine .content-panel{
  border:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  padding:0;
}

/* ==== Layout ========================================================== */
.termin-node .tn-main{
  display:grid;
  gap: clamp(16px, 1.8vw, 28px);
  align-items:start;
}
@media (min-width: 860px){
  .termin-node .tn-main.has-poster{
    grid-template-columns: minmax(0,1fr) clamp(200px, 24vw, 320px);
  }
  .termin-node .tn-main.no-poster{ grid-template-columns: 1fr; }
}
.termin-node .tn-info{ min-width:0; }

/* Headline & Orga */
.tn-title{
  margin:0 0 .3rem;
  font-weight:800;
  font-size: clamp(1.6rem, 1.05rem + 1.8vw, 2.1rem);
  line-height:1.1;
}
.tn-org{ margin-top:.45rem; font-size:1rem; }
.tn-org .label{ font-weight:800; margin-right:.35rem; color:#2A2D33; }
.tn-org .val{ font-weight:700; }

/* Beschreibung */
.tn-desc{
  margin-top:.65rem;
  color:#1f2937;
  line-height:1.55;
}

/* Pills */
.tn-meta{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.25rem; }
.tn-meta .chip{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.4rem .65rem; border-radius:999px;
  font-weight:700; font-size:.95rem; line-height:1;
  border:1px solid transparent;
}
.chip--date{ background:#EEF6FF; border-color:#DBEAFE; }
.chip--time{ background:#F5F3FF; border-color:#E9E5FF; }
.chip--loc { background:#F2FBF3; border-color:#DDF3E0; }

/* Poster */
.termin-node .tn-media{ justify-self:start; }
.termin-node .tn-poster{ margin:.5rem 0 0; }
.termin-node .tn-poster img{
  display:block; width:auto; max-width:100%; height:auto;
  border-radius:14px; box-shadow:0 8px 24px rgba(0,0,0,.10);
}
.termin-node .tn-poster a{ display:inline-block; outline:0; }
.termin-node .tn-poster a:focus-visible{
  box-shadow:0 0 0 3px rgba(212,175,55,.55);
  border-radius:16px;
}

/* Rest-Felder */
.tn-body{ margin-top: clamp(14px, 1.2vw, 18px); }

/* ==== Aktionen / Button – exakt wie im Block ========================== */
.tn-actions{
  margin-top: clamp(16px, 2vw, 28px);
  display:flex;
  justify-content:flex-start;    /* LINKS bündig */
}

/* Basis */
.tn-btn{
  display:inline-flex; align-items:center; gap:.55rem;
  padding:calc(.55rem + 1px) calc(.95rem + 2px);
  border-radius:999px; font-weight:700; line-height:1; text-decoration:none;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
}

/* Stil identisch zu .ms-events .view-footer-link .btn-more */
.tn-btn--more{
  color:var(--brand-ink);
  background:color-mix(in srgb, var(--brand) 12%, white);
  border:1px solid color-mix(in srgb, var(--brand) 25%, transparent);
  box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9), inset 0 -1px 0 rgba(0,0,0,.05);
}
.tn-btn--more:hover,
.tn-btn--more:focus{
  background:color-mix(in srgb, var(--brand) 20%, white);
  border-color:color-mix(in srgb, var(--brand) 40%, transparent);
  box-shadow:0 6px 16px rgba(0,0,0,.10);
  transform:translateY(-1px);
  color:var(--brand-ink);
  outline:0;
}

/* Pfeil links (Zurück) – gleiche Icon-Optik wie im Block, nur gespiegelt */
.tn-btn--back{
  position:relative;
  padding-left: calc(.95rem + 2px);
}
.tn-btn--back::before{
  content:"";
  width:1em; height:1em; background:currentColor; display:inline-block; transform:scaleX(-1) translateY(1px);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M4 3l9 5-9 5z'/></svg>") center/100% 100% no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M4 3l9 5-9 5z'/></svg>") center/100% 100% no-repeat;
  margin-right:.55rem;
}

/* === Fix: Button-Textfarbe & keine Unterstreichung ==================== */
.tn-actions .tn-btn,
.tn-actions .tn-btn:link,
.tn-actions .tn-btn:visited{
  color: var(--brand-ink) !important;     /* #7a5c26 wie im Block */
  text-decoration: none !important;
}
.tn-actions .tn-btn .label{
  text-decoration: none !important;
  border: 0 !important;
}
.tn-actions .tn-btn:hover,
.tn-actions .tn-btn:focus-visible{
  color: var(--brand-ink) !important;
  text-decoration: none !important;
}
