@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=DM+Sans:wght@300;400;500&display=swap');

.tw-oeffnung-outer {
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 20px 16px;
  box-sizing: border-box;
}

.tw-oeffnung {
  background: linear-gradient(145deg, #2a1a0a 0%, #1e1208 50%, #2e1c0c 100%);
  border: 1px solid rgba(180, 110, 40, 0.3);
  border-radius: 20px;
  padding: 36px 32px;
  max-width: 480px;
  width: 100%;
  position: relative;
  box-shadow:
    0 0 0 1px rgba(180,110,40,0.1),
    0 20px 50px rgba(0,0,0,0.18),
    inset 0 1px 0 rgba(255,200,100,0.08);
  font-family: 'DM Sans', sans-serif;
  box-sizing: border-box;
}

.tw-oeffnung::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 200px; height: 120px;
  background: radial-gradient(ellipse, rgba(200,130,40,0.15) 0%, transparent 70%);
  pointer-events: none;
  border-radius: 20px;
}

.tw-header { text-align: center; margin-bottom: 28px; }

.tw-icon {
  font-size: 26px;
  margin-bottom: 10px;
  display: block;

}

  50%       { opacity: 0.75; transform: scale(0.95); }
}

.tw-oeffnung .tw-header h2 {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  color: #f0d090 !important;
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin: 0 0 6px !important;
}

.tw-oeffnung .tw-header p {
  font-size: 0.75rem !important;
  color: rgba(200,160,80,0.55) !important;
  margin: 0 !important;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
}

.tw-divider {
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(180,110,40,0.5), transparent);
  margin: 0 0 22px;
}

.tw-rows { display: flex; flex-direction: column; gap: 4px; }

.tw-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0;
  padding: 10px 14px;
  border-radius: 9px;
  transition: background 0.2s;
  position: relative;

.tw-row:hover { background: rgba(180,110,40,0.07); }

.tw-row.today {
  background: rgba(180,110,40,0.14);
  border: 1px solid rgba(180,110,40,0.24);
}

.tw-row.today::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(to bottom, #e8a030, #c07020);
  border-radius: 3px 0 0 3px;
}

.tw-day {
  font-size: 0.85rem !important;
  font-weight: 400 !important;
  color: rgba(220,190,130,0.75) !important;
  letter-spacing: 0.02em;
  width: 120px;
  flex-shrink: 0;
}

.tw-row.today .tw-day {
  color: #f0d090 !important;
  font-weight: 500 !important;
}

.tw-badge {
  display: inline-block;
  background: rgba(200,130,40,0.2);
  color: #e8a030;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 20px;
  margin-left: 6px;
  border: 1px solid rgba(200,130,40,0.3);
  vertical-align: middle;
}

.tw-time {
  font-size: 0.84rem !important;
  font-weight: 500 !important;
  color: #d4a855 !important;
  text-align: left;
  letter-spacing: 0.01em;
  flex-shrink: 0;
  min-width: 210px;
}

.tw-time.closed {
  color: rgba(160,100,60,0.55) !important;
  font-weight: 300 !important;
  font-style: italic;
}

.tw-time.jetzt-geschlossen {
  color: #e07030 !important;
  font-weight: 600 !important;
  font-style: italic;
}

.tw-row.today .tw-time { color: #f0c060 !important; }

.tw-sep {
  height: 1px;
  background: rgba(180,110,40,0.10);
  margin: 2px 0;
}

.tw-footer {
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid rgba(180,110,40,0.14);
  text-align: center;
}

.tw-oeffnung .tw-footer p {
  font-size: 0.74rem !important;
  color: rgba(180,140,70,0.45) !important;
  line-height: 1.5;
  margin: 0 0 8px !important;
}

.tw-phone {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.88rem;
  font-weight: 500;
  color: #c8903a !important;
  text-decoration: none;
  transition: color 0.2s;
}
.tw-phone:hover { color: #f0c060 !important; }

@media (max-width: 520px) {
  .tw-oeffnung { padding: 24px 14px; border-radius: 14px; }
  .tw-oeffnung .tw-header h2 { font-size: 1.35rem !important; }
  .tw-day  { font-size: 0.78rem !important; width: 100px; }
  .tw-time { font-size: 0.76rem !important; min-width: 160px; }
  .tw-row  { padding: 9px 10px; }
}
