/* SuppKultur Events – Frontend Styles (0.1.1) */

:root{
  --sk-accent:#d97706;
  --sk-accent-2:#b45309;
  --sk-bg:#fff;
  --sk-border:rgba(0,0,0,.12);
  --sk-text:#1f2937;
  --sk-muted:rgba(31,41,55,.72);
  --sk-radius:16px;
  --sk-shadow:0 12px 30px rgba(0,0,0,.10);
}

.sk-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.6rem .9rem;
  border-radius:999px;
  border:1px solid rgba(217,119,6,.35);
  background:rgba(217,119,6,.10);
  color:var(--sk-text);
  font-weight:800;
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.sk-btn:hover{
  transform:translateY(-1px);
  border-color:rgba(217,119,6,.55);
  background:rgba(217,119,6,.14);
  box-shadow:0 10px 24px rgba(0,0,0,.10);
}

/* ===== Event Grid/List ===== */
.sk-events{
  display:grid;
  gap:14px;
}
.sk-events--grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 1024px){
  .sk-events--grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .sk-events--grid{ grid-template-columns: 1fr; }
}
.sk-events--list{
  grid-template-columns: 1fr;
}

.sk-event{
  border:1px solid var(--sk-border);
  border-radius:var(--sk-radius);
  overflow:hidden;
  background:var(--sk-bg);
  box-shadow:var(--sk-shadow);
  display:flex;
  flex-direction:column;
}
.sk-event__media a{ display:block; }
.sk-event__img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.sk-event__body{
  padding:14px 14px 16px 14px;
}
.sk-event__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}
.sk-pill{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.25rem .6rem;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(0,0,0,.03);
  color:var(--sk-muted);
  font-weight:750;
  font-size:.9rem;
}
.sk-event__title{
  margin:0 0 8px 0;
  font-size:1.1rem;
  line-height:1.25;
}
.sk-event__title a{
  color:var(--sk-text);
  text-decoration:none;
  font-weight:900;
  letter-spacing:-.01em;
}
.sk-event__note{
  color:var(--sk-text);
  opacity:.9;
  margin:0 0 10px 0;
}
.sk-event__excerpt{
  color:var(--sk-muted);
  margin:0 0 12px 0;
}
.sk-event__actions{ margin-top:6px; }

.sk-events-empty{
  padding:14px 16px;
  border:1px solid var(--sk-border);
  border-radius:var(--sk-radius);
  background:var(--sk-bg);
}

/* ===== Calendar ===== */
.sk-cal{
  border:1px solid var(--sk-border);
  border-radius:var(--sk-radius);
  background:var(--sk-bg);
  box-shadow:var(--sk-shadow);
  overflow:hidden;
}
.sk-cal__head{
  padding:14px 16px;
  background:rgba(217,119,6,.10);
  border-bottom:1px solid var(--sk-border);
}
.sk-cal__title{
  font-weight:950;
  color:var(--sk-text);
  letter-spacing:-.01em;
}
.sk-cal__grid{
  display:grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}
.sk-cal__grid--labels{
  background:rgba(0,0,0,.03);
  border-bottom:1px solid var(--sk-border);
}
.sk-cal__cell{
  min-height:120px;
  border-right:1px solid var(--sk-border);
  border-bottom:1px solid var(--sk-border);
  padding:10px;
  position:relative;
  background:var(--sk-bg);
}
.sk-cal__cell:nth-child(7n){ border-right:0; }
.sk-cal__cell--label{
  min-height:auto;
  padding:10px;
  font-weight:900;
  color:var(--sk-muted);
  text-align:center;
}
.sk-cal__cell--empty{ background:rgba(0,0,0,.015); }
.sk-cal__cell--today{
  background:rgba(217,119,6,.07);
  box-shadow: inset 0 0 0 2px rgba(217,119,6,.30);
}
.sk-cal__day{
  font-weight:950;
  color:var(--sk-text);
  display:inline-flex;
  padding:2px 8px;
  border-radius:999px;
  background:rgba(0,0,0,.04);
  border:1px solid transparent;
}
.sk-cal__cell--today .sk-cal__day{
  background:rgba(217,119,6,.12);
  border-color:rgba(217,119,6,.25);
}

.sk-cal__events{
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.sk-cal__event{
  display:block;
  text-decoration:none;
  border:1px solid rgba(0,0,0,.10);
  border-radius:12px;
  padding:8px 10px;
  background:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  position:relative;
  color:var(--sk-text);
}
.sk-cal__event:before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  border-radius:12px 0 0 12px;
  background:linear-gradient(180deg, var(--sk-accent), var(--sk-accent-2));
  opacity:.85;
}
.sk-cal__event-time{
  font-weight:900;
  margin-right:.2rem;
}
.sk-cal__event-title{
  font-weight:900;
  letter-spacing:-.01em;
}
.sk-cal__event-loc{
  display:block;
  margin-top:4px;
  color:var(--sk-muted);
  font-weight:750;
  font-size:.92rem;
}
.sk-cal__event:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(0,0,0,.10);
  border-color:rgba(217,119,6,.30);
}

/* Mobile: grid becomes swipeable */
@media (max-width: 767px){
  .sk-cal{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .sk-cal__grid{
    min-width: 860px;
  }
  .sk-cal__cell{ min-height: 110px; }
}


/* ===== Split View (upcoming + past) ===== */
.sk-events-split{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.sk-events-section__title{
  margin: 0 0 10px 0;
  font-weight: 950;
  letter-spacing: -.01em;
  color: var(--sk-text);
}

/* Past events: subtly greyed, ohne Layout-Änderung */
.sk-events--past .sk-event{
  opacity: .78;
  filter: grayscale(.18);
}
.sk-events--past .sk-event:hover{
  opacity: .88;
  filter: grayscale(.10);
}
