:root {
    --bg: #120707;
    --bg2: #26100b;
    --cream: #fff3d6;
    --cream-light: #fff8e7;
    --gold: #ffcc00;
    --orange: #ff9f1c;
    --red: #ff3b1f;
    --blue: #00b7ff;
    --green: #18a94d;
    --dark: #1b0b08;
    --brown: #6d3a24;
    --disabled: #d8c4a1;
    --line: 4px solid var(--dark);
    --shadow: 5px 5px 0 var(--dark)
}

* {
    box-sizing: border-box
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: "Arial Black", Impact, Arial, sans-serif;
    color: var(--dark);
    background: radial-gradient(circle at 12% 10%, rgba(255, 204, 0, .22) 0 10%, transparent 11%), radial-gradient(circle at 88% 8%, rgba(255, 59, 31, .20) 0 8%, transparent 9%), linear-gradient(135deg, var(--bg), var(--bg2))
}

body:before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    opacity: .18;
    background-image: radial-gradient(var(--cream) 1px, transparent 1px);
    background-size: 12px 12px
}

.site-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 10px 24px;
    color: var(--dark);
    border-bottom: 5px solid var(--dark);
    background: linear-gradient(120deg, var(--gold) 0%, var(--orange) 45%, var(--red) 100%);
    box-shadow: 0 8px 0 rgba(0, 0, 0, .35)
}

.eyebrow {
    margin: 0 0 6px;
    font-size: 13px;
    letter-spacing: 2px;
    text-transform: uppercase
}

.site-header h1 {
    margin: 0 0 8px;
    font-size: clamp(28px, 4vw, 48px);
    letter-spacing: -1px;
    text-transform: uppercase
}

.site-header p {
    margin: 0;
    color: #3a160c;
    font-family: Arial, sans-serif;
    font-weight: 800
}

.top-actions,
.filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px
}

.layout {
    max-width: 1240px;
    margin: 28px auto;
    padding: 0 16px 40px
}

.narrow {
    max-width: 650px
}

.zone {
    padding: 18px;
    margin-bottom: 22px;
    border: var(--line);
    border-radius: 18px;
    background: linear-gradient(180deg, var(--cream), #ffe6a6);
    box-shadow: var(--shadow)
}

.narrow-zone {
    max-width: 650px;
    margin-left: auto;
    margin-right: auto
}

.zone-title {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 16px;
    border-bottom: 3px solid var(--dark);
    padding-bottom: 14px;
    margin-bottom: 18px
}

h2,
h3 {
    margin-top: 0;
    letter-spacing: -.5px;
    text-transform: uppercase
}

a,
button {
    padding: 10px 13px;
    cursor: pointer;
    color: var(--dark);
    font-weight: 900;
    text-transform: uppercase;
    text-decoration: none;
    border: 3px solid var(--dark);
    border-radius: 12px;
    background: var(--cream);
    box-shadow: 3px 3px 0 var(--dark);
    transition: transform .12s ease, box-shadow .12s ease, background .12s ease
}

a:hover,
button:hover {
    transform: translate(1px, 1px);
    box-shadow: 2px 2px 0 var(--dark)
}

button:disabled {
    cursor: not-allowed;
    opacity: .45;
    transform: none
}

button.primary,
.primary {
    background: var(--gold)
}

button.ok {
    color: #fff;
    background: var(--green)
}

button.bad {
    color: #fff;
    background: var(--red)
}

button.active {
    background: var(--blue)
}

.full {
    width: 100%;
    margin-top: 14px
}

.hidden {
    display: none!important
}

.toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px
}

.calendar {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 9px
}

.day-name {
    padding: 8px 0;
    color: var(--cream);
    font-weight: 900;
    text-align: center;
    border: 2px solid var(--dark);
    border-radius: 10px;
    background: var(--dark)
}

.day {
    position: relative;
    min-height: 96px;
    padding: 8px;
    cursor: pointer;
    border: 3px solid var(--dark);
    border-radius: 14px;
    background: var(--cream-light);
    box-shadow: 3px 3px 0 var(--dark)
}

.day:hover {
    outline: 4px solid var(--blue)
}

.day.empty {
    visibility: hidden
}

.day.past {
    color: #806d58;
    cursor: not-allowed;
    background: var(--disabled);
    box-shadow: none
}

.day.selected {
    background: #ffe15a;
    outline: 5px solid var(--red)
}

.num {
    font-size: 20px;
    font-weight: 900
}

.badges {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 8px
}

.badge {
    padding: 4px 7px;
    color: #fff;
    font-family: Arial, sans-serif;
    font-size: 11px;
    font-weight: 900;
    border: 2px solid var(--dark);
    border-radius: 999px
}

.available {
    color: #fff;
    background: var(--blue)
}

.pending {
    color: var(--dark);
    background: var(--orange)
}

.confirmed {
    color: #fff;
    background: var(--green)
}

.refused,
.full {
    color: #fff;
    background: var(--red)
}

.legend {
    /*display:flex;*/
    flex-wrap: wrap;
    gap: 12px;
    margin: 0 0 14px;
    font-family: Arial, sans-serif;
    font-weight: 900
}

.dot {
    display: inline-block;
    width: 14px;
    height: 14px;
    margin-right: 6px;
    vertical-align: -2px;
    border: 2px solid var(--dark);
    border-radius: 50%
}

.dot.past {
    background: var(--disabled)
}

.form-block {
    padding: 16px;
    border: 3px solid var(--dark);
    border-radius: 14px;
    background: rgba(255, 248, 231, .74)
}

label {
    display: block;
    margin: 12px 0 6px;
    font-size: 13px;
    font-weight: 900;
    text-transform: uppercase
}

input,
select,
textarea {
    width: 100%;
    padding: 11px;
    color: var(--dark);
    font: inherit;
    font-family: Arial, sans-serif;
    border: 3px solid var(--dark);
    border-radius: 12px;
    outline: none;
    background: var(--cream-light)
}

textarea {
    min-height: 92px;
    resize: vertical
}

input:focus,
select:focus,
textarea:focus {
    box-shadow: 0 0 0 4px var(--blue)
}

.hint {
    font-family: Arial, sans-serif;
    font-weight: 800;
    color: var(--brown)
}

.small {
    font-size: 13px
}

.reservation-row {
    display: grid;
    grid-template-columns: 1.2fr .8fr .8fr .8fr 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 3px solid rgba(27, 11, 8, .25);
    font-family: Arial, sans-serif;
    font-weight: 800
}

.reservation-row strong,
.reservation-row .name {
    font-family: "Arial Black", Impact, Arial, sans-serif;
    text-transform: uppercase
}

.actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px
}

.status {
    display: inline-block;
    padding: 4px 8px;
    border: 2px solid var(--dark);
    border-radius: 999px;
    font-weight: 900
}

.pendingText {
    background: var(--orange)
}

.confirmedText {
    color: #fff;
    background: var(--green)
}

.refusedText {
    color: #fff;
    background: var(--red)
}

@media(max-width:850px) {
    .site-header,
    .zone-title {
        align-items: start;
        flex-direction: column
    }
    .calendar {
        gap: 5px
    }
    .day {
        min-height: 76px;
        padding: 6px
    }
    .reservation-row {
        grid-template-columns: 1fr
    }
}

.admin-form-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 14px
}

.admin-form-grid .full {
    grid-column: 1/-1
}

.admin-message-field {
    grid-column: 1/-1
}

@media(max-width:850px) {
    .admin-form-grid {
        grid-template-columns: 1fr
    }
}

/* Disponibilités et Nouvelle réservation côte à côte */
.layout {
    display: flex;
    flex-wrap: wrap;
    gap: 22px;
}

.layout > #reservationSection,
.layout > .zone:first-child {
    flex: 1;
    min-width: 450px;
}

#mySection {
    width: 100%;
}

@media (max-width: 900px) {
    .layout {
        flex-direction: column;
    }

    .layout > #reservationSection,
    .layout > .zone:first-child {
        min-width: 100%;
    }
}
