Buchungskalender eingefügt

This commit is contained in:
2026-05-05 19:18:05 +02:00
parent 4a4517c514
commit c1f07343e3
21 changed files with 931 additions and 187 deletions
+347 -4
View File
@@ -175,6 +175,125 @@ textarea {
transform: translateY(-1px);
}
.public-header-shell {
display: flex;
align-items: center;
gap: 1rem;
margin-left: auto;
}
.public-header-controls {
display: flex;
align-items: center;
gap: 1.25rem;
}
.site-nav-public {
gap: 1.2rem;
}
.site-nav-public a {
position: relative;
padding: 0.35rem 0;
border-radius: 0;
background: transparent;
color: var(--text-soft);
font-weight: 500;
}
.site-nav-public a::after {
content: "";
position: absolute;
left: 0;
right: 0;
bottom: -0.35rem;
height: 2px;
border-radius: 999px;
background: linear-gradient(90deg, var(--accent) 0%, #d4a081 100%);
opacity: 0;
transform: scaleX(0.55);
transition: opacity 0.2s ease, transform 0.2s ease;
}
.site-nav-public a:hover,
.site-nav-public a:focus-visible,
.site-nav-public a.is-active {
background: transparent;
color: var(--text);
transform: none;
}
.site-nav-public a:hover::after,
.site-nav-public a:focus-visible::after,
.site-nav-public a.is-active::after {
opacity: 1;
transform: scaleX(1);
}
.header-actions-public {
gap: 0.8rem;
}
.menu-meta {
display: none;
gap: 0.35rem;
color: var(--text-soft);
font-size: 0.92rem;
}
.menu-meta a {
color: var(--accent-strong);
text-decoration: none;
}
.contact-chip {
display: inline-grid;
gap: 0.1rem;
padding: 0.75rem 1rem;
border-radius: 999px;
border: 1px solid var(--line);
background: rgba(255, 255, 255, 0.74);
text-decoration: none;
line-height: 1.25;
}
.contact-chip span {
font-size: 0.72rem;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--text-soft);
}
.contact-chip strong {
font-size: 0.95rem;
color: var(--text);
}
.nav-toggle {
display: none;
align-items: center;
gap: 0.75rem;
padding: 0.85rem 1rem;
border-radius: 999px;
border: 1px solid var(--line);
background: rgba(255, 255, 255, 0.76);
color: var(--text);
cursor: pointer;
}
.nav-toggle-box {
display: inline-grid;
gap: 0.24rem;
}
.nav-toggle-box span {
display: block;
width: 1rem;
height: 2px;
border-radius: 999px;
background: currentColor;
}
.header-actions {
display: flex;
align-items: center;
@@ -618,6 +737,136 @@ p {
gap: 0.9rem;
}
.calendar-legend,
.public-calendar-grid,
.calendar-weekdays,
.calendar-days,
.calendar-entry-list {
display: grid;
}
.calendar-legend {
grid-auto-flow: column;
justify-content: start;
gap: 0.75rem;
margin-bottom: 1rem;
}
.public-calendar-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1rem;
}
.calendar-month-card {
padding: 1.35rem;
border-radius: var(--radius-xl);
border: 1px solid var(--line);
background: rgba(255, 255, 255, 0.78);
box-shadow: var(--shadow-card);
}
.calendar-month-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
margin-bottom: 1rem;
}
.calendar-month-header h2 {
margin: 0;
font-size: 1.45rem;
}
.calendar-month-header span,
.calendar-weekdays span,
.calendar-day-state {
color: var(--text-soft);
font-size: 0.88rem;
}
.calendar-weekdays,
.calendar-days {
grid-template-columns: repeat(7, minmax(0, 1fr));
gap: 0.45rem;
}
.calendar-weekdays {
margin-bottom: 0.45rem;
text-align: center;
}
.calendar-day {
min-height: 4.6rem;
padding: 0.55rem 0.45rem;
border-radius: var(--radius-sm);
border: 1px solid var(--line);
background: rgba(247, 243, 236, 0.9);
display: flex;
flex-direction: column;
justify-content: space-between;
gap: 0.35rem;
}
.calendar-day-empty {
border-style: dashed;
background: rgba(255, 255, 255, 0.34);
}
.calendar-day.is-today {
border-color: rgba(183, 106, 71, 0.42);
box-shadow: inset 0 0 0 1px rgba(183, 106, 71, 0.18);
}
.calendar-day.is-booked {
color: var(--text);
}
.calendar-day-requested {
background: rgba(183, 106, 71, 0.14);
border-color: rgba(183, 106, 71, 0.24);
}
.calendar-day-reserved {
background: rgba(102, 87, 74, 0.14);
border-color: rgba(102, 87, 74, 0.22);
}
.calendar-day-confirmed {
background: rgba(77, 105, 91, 0.14);
border-color: rgba(77, 105, 91, 0.22);
}
.calendar-day-number {
font-weight: 700;
font-size: 1rem;
}
.calendar-entry-list {
gap: 0.75rem;
margin-top: 1rem;
}
.calendar-entry {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.9rem;
padding: 0.85rem 0.95rem;
border-radius: var(--radius-md);
border: 1px solid var(--line);
background: rgba(255, 255, 255, 0.58);
}
.calendar-entry strong {
display: block;
}
.calendar-entry span {
color: var(--text-soft);
font-size: 0.92rem;
}
.availability-card,
.stack-item {
display: flex;
@@ -1064,21 +1313,90 @@ tbody tr:last-child td {
@media (max-width: 900px) {
.header-inner {
gap: 0.85rem;
}
.site-header-admin .header-inner {
flex-direction: column;
align-items: stretch;
}
.site-nav,
.header-actions {
.site-header-admin .site-nav,
.site-header-admin .header-actions {
justify-content: center;
}
.public-header-shell {
position: relative;
margin-left: 0;
}
.nav-toggle {
display: inline-flex;
}
.public-header-controls {
position: absolute;
top: calc(100% + 0.85rem);
right: 0;
width: min(24rem, calc(100vw - 2rem));
padding: 1rem;
border-radius: var(--radius-lg);
border: 1px solid var(--line);
background: rgba(255, 251, 246, 0.98);
box-shadow: var(--shadow-soft);
display: none;
flex-direction: column;
align-items: stretch;
gap: 1rem;
}
.public-header-controls.is-open {
display: flex;
}
.site-nav-public,
.menu-meta,
.header-actions-public {
width: 100%;
align-items: stretch;
}
.site-nav-public {
display: flex;
flex-direction: column;
gap: 0;
}
.menu-meta {
display: grid;
padding-top: 0.15rem;
}
.header-actions-public {
flex-direction: column;
}
.site-nav-public a {
padding: 0.95rem 0;
border-bottom: 1px solid var(--line);
}
.site-nav-public a::after {
display: none;
}
.site-nav-public a:last-child {
border-bottom: 0;
}
.faq-grid,
.legal-section,
.trust-grid,
.form-grid,
.form-grid-two,
.calendar-grid {
.calendar-grid,
.public-calendar-grid {
grid-template-columns: 1fr;
}
@@ -1123,9 +1441,14 @@ tbody tr:last-child td {
flex-direction: column;
}
.topbar {
display: none;
}
.button-primary,
.button-secondary,
.ghost-button {
.ghost-button,
.contact-chip {
width: 100%;
}
@@ -1144,10 +1467,30 @@ tbody tr:last-child td {
.availability-card,
.stack-item,
.calendar-entry,
.form-section-header,
.hero-panel-top,
.hero-panel-bottom {
flex-direction: column;
align-items: flex-start;
}
.calendar-weekdays,
.calendar-days {
gap: 0.3rem;
}
.calendar-day {
min-height: 4rem;
padding: 0.45rem 0.35rem;
}
.calendar-legend {
grid-auto-flow: row;
}
.public-header-shell {
width: 100%;
justify-content: flex-end;
}
}