.pmr-reservations,
.pmr-admin,
.pmr-login {
    --pmr-red: #e32322;
    --pmr-red-dark: #bd1717;
    --pmr-blue: #002c3e;
    --pmr-teal: #0087a3;
    --pmr-gold: #fbd652;
    --pmr-ink: #333333;
    --pmr-muted: #69717a;
    --pmr-line: #eceff3;
    --pmr-soft: #faf8f5;
    --pmr-white: #ffffff;
    --pmr-green: #1f7a4d;
    --pmr-yellow: #a66b00;
    --pmr-danger: #a52828;
    color: var(--pmr-ink);
    font-family: "Montserrat", Arial, Helvetica, sans-serif;
    font-size: 16px;
    line-height: 1.5;
}

.pmr-reservations *,
.pmr-reservations *::before,
.pmr-reservations *::after,
.pmr-admin *,
.pmr-admin *::before,
.pmr-admin *::after,
.pmr-login *,
.pmr-login *::before,
.pmr-login *::after {
    box-sizing: border-box;
}

.pmr-reservations h1,
.pmr-reservations h2,
.pmr-reservations h3,
.pmr-reservations h4,
.pmr-admin h1,
.pmr-admin h2,
.pmr-login h1,
.pmr-login h2 {
    font-family: "League Spartan", Arial, Helvetica, sans-serif;
}

.pmr-reservations a {
    color: var(--pmr-teal) !important;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.pmr-reservations a:hover,
.pmr-reservations a:focus,
.pmr-reservations a:focus-visible {
    color: var(--pmr-blue) !important;
}

.pmr-reservation-page {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    overflow: hidden;
    background: var(--pmr-soft);
    padding: 56px 0 72px;
}

.pmr-page-pattern {
    position: absolute;
    inset: 0;
    opacity: 0.035;
    background-image: radial-gradient(#000000 1px, transparent 1px);
    background-size: 16px 16px;
    pointer-events: none;
}

.pmr-page-inner {
    position: relative;
    z-index: 1;
    width: min(1200px, calc(100% - 32px));
    margin: 0 auto;
}

.pmr-page-grid {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: 56px;
    align-items: start;
}

.pmr-page-copy {
    padding-top: 16px;
}

.pmr-page-copy h1 {
    margin: 0 0 12px;
    color: var(--pmr-blue);
    font-size: 58px;
    font-weight: 800;
    line-height: 0.96;
}

.pmr-page-subtitle {
    margin: 0 0 30px;
    color: var(--pmr-red);
    font-family: "League Spartan", Arial, Helvetica, sans-serif;
    font-size: 26px;
    font-style: italic;
    line-height: 1.1;
}

.pmr-page-intro {
    margin-bottom: 34px;
}

.pmr-page-intro p {
    margin: 0 0 16px;
    color: #4d5661;
    line-height: 1.75;
}

.pmr-info-card,
.pmr-pickup-card {
    margin-bottom: 24px;
    padding: 24px;
    border: 1px solid var(--pmr-line);
    border-radius: 12px;
    background: var(--pmr-white);
    box-shadow: 0 8px 24px rgba(0, 44, 62, 0.04);
}

.pmr-info-card h3,
.pmr-pickup-card h3 {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 16px;
    color: var(--pmr-blue);
    font-size: 21px;
    font-weight: 800;
    line-height: 1.2;
}

.pmr-icon {
    display: inline-block;
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
    color: currentColor;
}

.pmr-reservations .pmr-lucide-icon {
    position: static !important;
    inset: auto !important;
    display: block !important;
    width: 22px !important;
    min-width: 22px !important;
    max-width: 22px !important;
    height: 22px !important;
    min-height: 22px !important;
    max-height: 22px !important;
    flex: 0 0 22px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    fill: none !important;
    stroke: currentColor !important;
    vertical-align: middle !important;
    transform: none !important;
    pointer-events: none !important;
}

.pmr-icon--red {
    color: var(--pmr-red);
}

.pmr-icon--teal {
    color: var(--pmr-teal);
}

.pmr-icon--gold {
    color: var(--pmr-gold);
}

.pmr-icon--check {
    width: 20px !important;
    min-width: 20px !important;
    max-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
    flex-basis: 20px !important;
    margin-top: 1px !important;
    color: var(--pmr-teal) !important;
}

.pmr-feature-list,
.pmr-steps {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.pmr-feature-list li,
.pmr-steps li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: #4d5661;
    font-size: 14px;
    line-height: 1.45;
}

.pmr-feature-list li > span {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
}

.pmr-feature-list strong,
.pmr-pickup-card strong {
    color: var(--pmr-blue);
}

.pmr-price-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 24px;
    padding: 24px;
    border-radius: 12px;
    background: var(--pmr-blue);
    color: var(--pmr-white);
    box-shadow: 0 8px 24px rgba(0, 44, 62, 0.12);
}

.pmr-price-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
}

.pmr-price-card div:not(.pmr-price-icon) {
    flex: 1 1 auto;
}

.pmr-price-card div:not(.pmr-price-icon) > span {
    display: block;
    padding-bottom: 5px;
    color: rgba(255, 255, 255, 0.62);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.pmr-price-card strong {
    display: block;
    color: var(--pmr-gold);
    font-family: "League Spartan", Arial, Helvetica, sans-serif;
    font-size: 34px;
    line-height: 1;
}

.pmr-price-card p {
    margin: 0;
    color: rgba(255, 255, 255, 0.55);
    font-size: 12px;
    text-align: right;
}

.pmr-steps li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    margin-top: -2px;
    flex: 0 0 24px;
    border-radius: 50%;
    background: var(--pmr-blue);
    color: var(--pmr-white);
    font-size: 12px;
    font-weight: 800;
}

.pmr-pickup-card {
    border-color: rgba(0, 135, 163, 0.2);
    background: rgba(0, 135, 163, 0.08);
}

.pmr-pickup-card p {
    margin: 0;
    color: #4d5661;
    font-size: 14px;
    line-height: 1.7;
}

.pmr-page-image {
    display: block;
    margin: 0 0 24px;
    overflow: hidden;
    padding: 8px;
    border: 1px solid var(--pmr-line);
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 44, 62, 0.04);
    aspect-ratio: 4 / 3;
    background: var(--pmr-white);
    line-height: 0;
}

.pmr-page-image img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: contain;
    border-radius: 8px;
}

.pmr-form-column {
    position: relative;
}

.pmr-form-panel {
    overflow: hidden;
    border: 1px solid var(--pmr-line);
    border-radius: 18px;
    background: var(--pmr-white);
    box-shadow: 0 24px 54px rgba(0, 44, 62, 0.12);
}

.pmr-form-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 30px 32px 18px;
    border-bottom: 1px solid #f2f3f5;
}

.pmr-form-panel__header h2 {
    margin: 0;
    color: var(--pmr-blue);
    font-size: 30px;
    font-weight: 800;
    line-height: 1.1;
}

.pmr-form-panel__header p {
    margin: 6px 0 0;
    color: #8a929b;
    font-size: 14px;
}

.pmr-calendar-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
    border-radius: 50%;
    background: #f7f8fa;
    color: #9aa3ad;
}

.pmr-calendar-badge .pmr-icon {
    width: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    flex-basis: 24px !important;
}

.pmr-card,
.pmr-login__box {
    width: 100%;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-white);
    box-shadow: 0 16px 40px rgba(38, 36, 34, 0.08);
    overflow: hidden;
}

.pmr-header,
.pmr-section,
.pmr-actions {
    padding: 24px;
}

.pmr-header {
    background: linear-gradient(135deg, #ffffff 0%, #f8f5ef 100%);
    border-bottom: 1px solid var(--pmr-line);
}

.pmr-header h2,
.pmr-admin h2,
.pmr-login h2 {
    margin: 0 0 10px;
    color: var(--pmr-ink);
    font-size: 34px;
    line-height: 1.15;
    font-weight: 800;
}

.pmr-header p,
.pmr-admin p,
.pmr-login p {
    margin: 0 0 10px;
    color: var(--pmr-muted);
}

.pmr-price {
    display: inline-flex;
    margin-top: 6px;
    padding: 8px 12px;
    border-radius: 8px;
    background: var(--pmr-red);
    color: var(--pmr-white) !important;
    font-weight: 700;
}

.pmr-reservations .pmr-form {
    padding: 24px;
}

.pmr-reservations .pmr-section {
    padding: 0 0 24px;
}

.pmr-reservations .pmr-section + .pmr-section {
    padding-top: 24px;
    border-top: 1px solid #f0f2f5;
}

.pmr-reservations .pmr-section h3 {
    color: var(--pmr-blue);
    font-size: 23px;
}

.pmr-reservations .pmr-field label {
    color: #263340;
    font-size: 14px;
}

.pmr-reservations .pmr-field input,
.pmr-reservations .pmr-field textarea,
.pmr-reservations .pmr-field select {
    min-height: 48px;
    border-color: #dfe5ea;
    border-radius: 10px;
    background: #ffffff;
    color: #263340;
}

.pmr-reservations .pmr-field textarea {
    min-height: 104px;
}

.pmr-reservations .pmr-field input:focus,
.pmr-reservations .pmr-field textarea:focus,
.pmr-reservations .pmr-field select:focus {
    border-color: var(--pmr-teal);
    outline-color: rgba(0, 135, 163, 0.16);
}

.pmr-reservations .pmr-date-control {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.pmr-reservations .pmr-date-control .pmr-datepicker-display {
    position: relative !important;
    z-index: 1 !important;
    width: 100% !important;
    margin: 0 !important;
    padding-right: 48px !important;
    background: #ffffff !important;
    cursor: pointer !important;
    opacity: 1 !important;
}

.pmr-reservations .pmr-date-control > .pmr-date-control__icon {
    position: absolute !important;
    inset: 50% 14px auto auto !important;
    z-index: 2 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    color: var(--pmr-teal) !important;
    font-size: 0 !important;
    line-height: 0 !important;
    pointer-events: none !important;
    transform: translateY(-50%) !important;
}

.pmr-reservations .pmr-date-control > .pmr-date-control__icon > .pmr-date-control__lucide {
    position: static !important;
    display: block !important;
    width: 20px !important;
    min-width: 20px !important;
    max-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    color: inherit !important;
    vertical-align: middle !important;
    transform: none !important;
}

.pmr-flatpickr-calendar.flatpickr-calendar {
    width: 330px !important;
    max-width: calc(100vw - 24px) !important;
    overflow: hidden !important;
    border: 1px solid #dfe5ea !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    box-shadow: 0 18px 46px rgba(0, 44, 62, 0.18) !important;
    color: #263340 !important;
    font-family: "Montserrat", Arial, Helvetica, sans-serif !important;
}

.pmr-flatpickr-calendar.flatpickr-calendar::before,
.pmr-flatpickr-calendar.flatpickr-calendar::after {
    display: none !important;
}

.pmr-flatpickr-calendar .flatpickr-months {
    min-height: 54px !important;
    padding: 7px 8px !important;
    background: #002c3e !important;
}

.pmr-flatpickr-calendar .flatpickr-months .flatpickr-month {
    height: 40px !important;
    background: transparent !important;
    color: #ffffff !important;
}

.pmr-flatpickr-calendar .flatpickr-current-month {
    top: 6px !important;
    height: 36px !important;
    padding: 6px 0 0 !important;
    color: #ffffff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
}

.pmr-flatpickr-calendar .flatpickr-current-month .cur-month,
.pmr-flatpickr-calendar .flatpickr-current-month input.cur-year {
    color: #ffffff !important;
    font-family: "Montserrat", Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
}

.pmr-flatpickr-calendar .flatpickr-current-month input.cur-year {
    min-height: 28px !important;
    padding: 0 0 0 6px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.pmr-flatpickr-calendar .numInputWrapper:hover,
.pmr-flatpickr-calendar .numInputWrapper span:hover {
    background: rgba(255, 255, 255, 0.1) !important;
}

.pmr-flatpickr-calendar .numInputWrapper span::after {
    border-bottom-color: rgba(255, 255, 255, 0.8) !important;
    border-top-color: rgba(255, 255, 255, 0.8) !important;
}

.pmr-flatpickr-calendar .flatpickr-prev-month,
.pmr-flatpickr-calendar .flatpickr-next-month {
    top: 7px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 6px !important;
    background: transparent !important;
    color: #fbd652 !important;
    font-size: 0 !important;
    line-height: 0 !important;
    transition: background-color 160ms ease !important;
}

.pmr-flatpickr-calendar .flatpickr-prev-month .pmr-flatpickr-chevron,
.pmr-flatpickr-calendar .flatpickr-next-month .pmr-flatpickr-chevron {
    position: static !important;
    display: block !important;
    width: 20px !important;
    min-width: 20px !important;
    max-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    color: inherit !important;
    transform: none !important;
}

.pmr-flatpickr-calendar .flatpickr-prev-month:hover,
.pmr-flatpickr-calendar .flatpickr-next-month:hover,
.pmr-flatpickr-calendar .flatpickr-prev-month:focus,
.pmr-flatpickr-calendar .flatpickr-next-month:focus {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
}

.pmr-flatpickr-calendar .flatpickr-weekdays {
    height: 38px !important;
    background: #f3f8f9 !important;
}

.pmr-flatpickr-calendar span.flatpickr-weekday {
    background: transparent !important;
    color: #64727c !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
}

.pmr-flatpickr-calendar .flatpickr-days,
.pmr-flatpickr-calendar .dayContainer {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
}

.pmr-flatpickr-calendar .dayContainer {
    padding: 8px !important;
}

.pmr-flatpickr-calendar .flatpickr-day {
    max-width: 14.2857% !important;
    height: 40px !important;
    border: 0 !important;
    border-radius: 6px !important;
    color: #263340 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 40px !important;
}

.pmr-flatpickr-calendar .flatpickr-day:hover,
.pmr-flatpickr-calendar .flatpickr-day:focus {
    border-color: transparent !important;
    background: #e5f4f6 !important;
    color: #002c3e !important;
}

.pmr-flatpickr-calendar .flatpickr-day.today {
    box-shadow: inset 0 0 0 2px #0087a3 !important;
    color: #002c3e !important;
}

.pmr-flatpickr-calendar .flatpickr-day.selected,
.pmr-flatpickr-calendar .flatpickr-day.selected:hover,
.pmr-flatpickr-calendar .flatpickr-day.selected:focus {
    background: #fbd652 !important;
    box-shadow: none !important;
    color: #002c3e !important;
    font-weight: 800 !important;
}

.pmr-flatpickr-calendar .flatpickr-day.prevMonthDay,
.pmr-flatpickr-calendar .flatpickr-day.nextMonthDay,
.pmr-flatpickr-calendar .flatpickr-day.flatpickr-disabled,
.pmr-flatpickr-calendar .flatpickr-day.flatpickr-disabled:hover {
    background: transparent !important;
    color: #b8c0c6 !important;
}

.pmr-reservations .pmr-quantity__button {
    border-radius: 10px;
    background: var(--pmr-blue);
}

.pmr-reservations .pmr-submit {
    width: 100%;
    min-height: 52px;
    border-radius: 10px;
    background: var(--pmr-gold);
    color: #121212;
}

.pmr-reservations .pmr-submit:hover,
.pmr-reservations .pmr-submit:focus {
    background: #edc83f;
    color: #121212;
}

.pmr-reservations .pmr-actions {
    padding: 24px 0 0;
    border-top: 1px solid #f0f2f5;
    background: transparent;
}

.pmr-reservations .pmr-checkbox {
    font-size: 13px;
    line-height: 1.5;
}

.pmr-reservations .pmr-legal-text {
    border-color: #edf0f3;
    border-radius: 10px;
    background: #fafbfc;
}

.pmr-reservations .pmr-legal-text h4 {
    color: var(--pmr-blue);
    font-size: 18px;
}

.pmr-reservations .pmr-legal-text p {
    color: #626b74;
    font-size: 13px;
    line-height: 1.6;
}

.pmr-section + .pmr-section {
    border-top: 1px solid var(--pmr-line);
}

.pmr-section h3,
.pmr-legal-text h4 {
    margin: 0 0 16px;
    color: var(--pmr-ink);
    font-size: 20px;
    line-height: 1.25;
    font-weight: 800;
}

.pmr-legal-text h4 {
    font-size: 17px;
}

.pmr-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.pmr-grid .pmr-field:last-child:nth-child(odd) {
    grid-column: span 2;
}

.pmr-field {
    margin-bottom: 18px;
}

.pmr-field:last-child {
    margin-bottom: 0;
}

.pmr-field label {
    display: block;
    margin-bottom: 7px;
    color: var(--pmr-ink);
    font-weight: 700;
}

.pmr-field input,
.pmr-field textarea,
.pmr-field select,
.pmr-login input,
.pmr-admin input,
.pmr-admin select {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-white);
    color: var(--pmr-ink);
    padding: 10px 12px;
    font: inherit;
    box-shadow: none;
}

.pmr-field textarea {
    min-height: 116px;
    resize: vertical;
}

.pmr-field input:focus,
.pmr-field textarea:focus,
.pmr-field select:focus,
.pmr-login input:focus,
.pmr-admin input:focus,
.pmr-admin select:focus {
    border-color: var(--pmr-red);
    outline: 2px solid rgba(196, 22, 28, 0.15);
    outline-offset: 1px;
}

.pmr-quantity {
    display: grid;
    grid-template-columns: 46px minmax(72px, 1fr) 46px;
    gap: 8px;
}

.pmr-quantity input {
    text-align: center;
}

.pmr-quantity__button,
.pmr-submit,
.pmr-secondary-button,
.pmr-admin-action {
    min-height: 44px;
    border: 0;
    border-radius: 8px;
    cursor: pointer;
    font: inherit;
    font-weight: 800;
    transition: background-color 160ms ease, color 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.pmr-quantity__button {
    background: var(--pmr-ink);
    color: var(--pmr-white);
    font-size: 20px;
}

.pmr-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-width: 160px;
    padding: 12px 18px;
    background: var(--pmr-red);
    color: var(--pmr-white);
}

.pmr-submit:hover,
.pmr-submit:focus {
    background: var(--pmr-red-dark);
}

.pmr-secondary-button,
.pmr-admin-action {
    padding: 10px 14px;
    border: 1px solid var(--pmr-line);
    background: var(--pmr-white);
    color: var(--pmr-ink);
}

.pmr-secondary-button:hover,
.pmr-secondary-button:focus,
.pmr-admin-action:hover,
.pmr-admin-action:focus {
    border-color: var(--pmr-red);
    color: var(--pmr-red);
}

.pmr-admin-action--danger {
    border-color: rgba(165, 40, 40, 0.35);
    color: var(--pmr-danger);
}

.pmr-submit:disabled,
.pmr-admin-action:disabled {
    cursor: wait;
    opacity: 0.65;
}

.pmr-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 0 0 14px;
    color: var(--pmr-ink);
}

.pmr-checkbox input {
    width: 18px;
    height: 18px;
    margin-top: 3px;
    accent-color: var(--pmr-red);
    flex: 0 0 auto;
}

.pmr-legal-text {
    margin-top: 18px;
    padding: 18px;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-soft);
}

.pmr-legal-text p {
    margin: 0 0 10px;
    color: var(--pmr-muted);
}

.pmr-legal-text p:last-child {
    margin-bottom: 0;
}

.pmr-reservations a,
.pmr-admin a,
.pmr-login a {
    color: var(--pmr-red);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.pmr-actions {
    border-top: 1px solid var(--pmr-line);
    background: var(--pmr-soft);
}

.pmr-message,
.pmr-admin-message {
    display: none;
    margin-top: 16px;
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid var(--pmr-line);
    background: var(--pmr-white);
    color: var(--pmr-ink);
}

.pmr-message:not(:empty),
.pmr-admin-message:not(:empty) {
    display: block;
}

.pmr-message--success {
    border-color: rgba(31, 122, 77, 0.35);
    background: #effaf4;
    color: var(--pmr-green);
}

.pmr-message--error {
    border-color: rgba(165, 40, 40, 0.35);
    background: #fff2f2;
    color: var(--pmr-danger);
}

.pmr-message--warning {
    border-color: rgba(166, 107, 0, 0.35);
    background: #fff8e8;
    color: var(--pmr-yellow);
}

body.pmr-modal-open {
    overflow: hidden !important;
}

.pmr-reservation-modal,
.pmr-reservation-modal *,
.pmr-reservation-modal *::before,
.pmr-reservation-modal *::after {
    box-sizing: border-box !important;
}

.pmr-reservation-modal {
    --pmr-red: #e32322;
    --pmr-red-dark: #bd1717;
    --pmr-blue: #002c3e;
    --pmr-teal: #0087a3;
    --pmr-gold: #fbd652;
    --pmr-ink: #333333;
    --pmr-muted: #69717a;
    --pmr-line: #eceff3;
    --pmr-soft: #faf8f5;
    --pmr-white: #ffffff;
    --pmr-green: #1f7a4d;
    --pmr-yellow: #a66b00;
    --pmr-danger: #a52828;
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100vw !important;
    height: 100vh !important;
    padding: 18px !important;
    color: var(--pmr-ink) !important;
    font-family: "Montserrat", Arial, Helvetica, sans-serif !important;
}

.pmr-reservation-modal__backdrop {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0, 44, 62, 0.62) !important;
    backdrop-filter: blur(6px) !important;
}

.pmr-reservation-modal__card {
    position: relative !important;
    z-index: 1 !important;
    width: min(520px, 100%) !important;
    max-height: calc(100vh - 36px) !important;
    overflow: auto !important;
    padding: clamp(26px, 4vw, 36px) !important;
    border: 1px solid rgba(0, 135, 163, 0.18) !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    box-shadow: 0 28px 70px rgba(0, 44, 62, 0.34) !important;
    text-align: center !important;
}

.pmr-reservation-modal__close {
    appearance: none !important;
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid #dfe5ea !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    color: var(--pmr-blue) !important;
    font-size: 24px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}

.pmr-reservation-modal__close:hover,
.pmr-reservation-modal__close:focus-visible {
    border-color: var(--pmr-blue) !important;
    background: var(--pmr-soft) !important;
    color: var(--pmr-blue) !important;
    outline: none !important;
}

.pmr-reservation-modal__icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 62px !important;
    height: 62px !important;
    margin: 0 auto 14px !important;
    border-radius: 999px !important;
    background: rgba(0, 135, 163, 0.12) !important;
    color: var(--pmr-teal) !important;
}

.pmr-reservation-modal__icon-svg {
    width: 31px !important;
    height: 31px !important;
}

.pmr-reservation-modal__eyebrow {
    margin: 0 0 8px !important;
    color: var(--pmr-red) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    letter-spacing: 0.09em !important;
    line-height: 1.3 !important;
    text-transform: uppercase !important;
}

.pmr-reservation-modal h2 {
    margin: 0 0 18px !important;
    color: var(--pmr-blue) !important;
    font-family: "League Spartan", Arial, Helvetica, sans-serif !important;
    font-size: clamp(28px, 6vw, 40px) !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
}

.pmr-reservation-modal__primary {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 10px !important;
    margin: 0 auto 18px !important;
}

.pmr-reservation-modal__reference,
.pmr-reservation-modal__price {
    min-width: 0 !important;
    padding: 18px !important;
    border: 1px solid rgba(0, 44, 62, 0.18) !important;
    border-radius: 8px !important;
    background: var(--pmr-blue) !important;
    color: #ffffff !important;
}

.pmr-reservation-modal__reference span,
.pmr-reservation-modal__price span {
    display: block !important;
    margin-bottom: 8px !important;
    color: rgba(255, 255, 255, 0.76) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}

.pmr-reservation-modal__reference strong,
.pmr-reservation-modal__price strong {
    display: block !important;
    color: #ffffff !important;
    font-size: clamp(42px, 11vw, 62px) !important;
    font-weight: 900 !important;
    line-height: 0.92 !important;
    letter-spacing: 0.04em !important;
}

.pmr-reservation-modal__price {
    background: linear-gradient(180deg, #06394d 0%, var(--pmr-blue) 100%) !important;
}

.pmr-reservation-modal__price strong {
    color: var(--pmr-gold) !important;
    letter-spacing: 0 !important;
}

.pmr-reservation-modal__email,
.pmr-reservation-modal__notice {
    margin: 0 auto 18px !important;
    max-width: 410px !important;
    color: var(--pmr-muted) !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
}

.pmr-reservation-modal__summary {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin: 0 auto 18px !important;
    max-width: 100% !important;
}

.pmr-reservation-modal__summary div {
    min-width: 0 !important;
    padding: 16px 14px !important;
    border: 1px solid #e2e8eb !important;
    border-radius: 8px !important;
    background: #f7fafb !important;
}

.pmr-reservation-modal__summary dt {
    margin: 0 0 5px !important;
    color: #71808a !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
    text-transform: uppercase !important;
}

.pmr-reservation-modal__summary dd {
    margin: 0 !important;
    color: var(--pmr-blue) !important;
    font-size: clamp(20px, 4vw, 26px) !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
}

.pmr-reservation-modal__notice {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 16px 18px !important;
    border-left: 4px solid var(--pmr-teal) !important;
    border-radius: 6px !important;
    background: #eaf6f7 !important;
    color: #53636d !important;
    text-align: left !important;
}

.pmr-reservation-modal__button {
    width: 100% !important;
    margin-top: 2px !important;
}

@media (max-width: 520px) {
    .pmr-reservation-modal {
        align-items: flex-start !important;
        padding: 12px !important;
        overflow: auto !important;
    }

    .pmr-reservation-modal__card {
        max-height: none !important;
        padding: 28px 18px 20px !important;
    }

    .pmr-reservation-modal__primary,
    .pmr-reservation-modal__summary {
        grid-template-columns: 1fr !important;
    }

    .pmr-reservation-modal__summary div,
    .pmr-reservation-modal__reference,
    .pmr-reservation-modal__price {
        padding: 12px !important;
    }

    .pmr-reservation-modal__reference strong {
        font-size: clamp(40px, 18vw, 56px) !important;
    }
}

.pmr-honeypot {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.pmr-login {
    max-width: 520px;
}

.pmr-login__box {
    padding: 24px;
}

.pmr-login-form {
    margin-top: 18px;
}

.pmr-admin {
    width: 100%;
}

.pmr-admin__top,
.pmr-admin-filters,
.pmr-admin-summary {
    display: flex;
    gap: 16px;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 18px;
}

.pmr-admin__top {
    align-items: center;
}

.pmr-admin-filters {
    padding: 18px;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-soft);
    flex-wrap: wrap;
}

.pmr-admin-filters .pmr-field {
    min-width: min(260px, 100%);
    margin-bottom: 0;
    flex: 1 1 220px;
}

.pmr-admin-filters__actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.pmr-admin-summary {
    justify-content: flex-start;
    align-items: stretch;
}

.pmr-admin-summary__item {
    min-width: 150px;
    padding: 14px 16px;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-white);
}

.pmr-admin-summary__item span {
    display: block;
    color: var(--pmr-muted);
    font-size: 13px;
    font-weight: 700;
}

.pmr-admin-summary__item strong {
    display: block;
    color: var(--pmr-ink);
    font-size: 28px;
    line-height: 1.1;
}

.pmr-admin-table.is-loading {
    opacity: 0.6;
    pointer-events: none;
}

.pmr-table-wrap {
    width: 100%;
    overflow-x: auto;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-white);
}

.pmr-table {
    width: 100%;
    min-width: 1120px;
    border-collapse: collapse;
    font-size: 14px;
}

.pmr-table th,
.pmr-table td {
    padding: 12px 10px;
    border-bottom: 1px solid var(--pmr-line);
    text-align: left;
    vertical-align: top;
}

.pmr-table th {
    background: var(--pmr-soft);
    color: var(--pmr-ink);
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 800;
}

.pmr-table tbody tr:last-child td {
    border-bottom: 0;
}

.pmr-status {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 4px 9px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 800;
}

.pmr-status--pending {
    background: #fff8e8;
    color: var(--pmr-yellow);
}

.pmr-status--completed {
    background: #effaf4;
    color: var(--pmr-green);
}

.pmr-status--cancelled {
    background: #fff2f2;
    color: var(--pmr-danger);
}

.pmr-row-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    min-width: 220px;
}

.pmr-admin-action {
    min-height: 34px;
    padding: 7px 10px;
    font-size: 12px;
}

.pmr-empty {
    padding: 22px;
    border: 1px solid var(--pmr-line);
    border-radius: 8px;
    background: var(--pmr-soft);
    color: var(--pmr-muted);
}

@media (max-width: 1024px) {
    .pmr-reservation-page {
        padding: 44px 0 56px;
    }

    .pmr-page-grid {
        grid-template-columns: 1fr;
        gap: 34px;
    }

    .pmr-page-copy {
        padding-top: 0;
    }

    .pmr-page-copy h1 {
        font-size: 46px;
    }
}

@media (max-width: 760px) {
    .pmr-reservation-page {
        padding: 32px 0 42px;
    }

    .pmr-page-inner {
        width: min(100% - 24px, 1200px);
    }

    .pmr-page-copy h1 {
        font-size: 38px;
    }

    .pmr-page-subtitle {
        margin-bottom: 24px;
        font-size: 22px;
    }

    .pmr-info-card,
    .pmr-pickup-card,
    .pmr-price-card {
        padding: 20px;
    }

    .pmr-price-card {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .pmr-price-card p {
        width: 100%;
        text-align: left;
    }

    .pmr-form-panel {
        border-radius: 14px;
    }

    .pmr-form-panel__header {
        padding: 22px 20px 16px;
    }

    .pmr-form-panel__header h2 {
        font-size: 25px;
    }

    .pmr-calendar-badge {
        display: none;
    }

    .pmr-reservations .pmr-form {
        padding: 20px;
    }

    .pmr-header,
    .pmr-section,
    .pmr-actions,
    .pmr-login__box {
        padding: 18px;
    }

    .pmr-header h2,
    .pmr-admin h2,
    .pmr-login h2 {
        font-size: 26px;
    }

    .pmr-grid {
        grid-template-columns: 1fr;
    }

    .pmr-grid .pmr-field:last-child:nth-child(odd) {
        grid-column: auto;
    }

    .pmr-reservations .pmr-grid--reservation {
        margin-bottom: 20px !important;
    }

    .pmr-admin__top,
    .pmr-admin-filters,
    .pmr-admin-summary {
        align-items: stretch;
        flex-direction: column;
    }

    .pmr-admin-filters__actions {
        width: 100%;
    }

    .pmr-admin-filters__actions .pmr-submit,
    .pmr-admin-filters__actions .pmr-secondary-button,
    .pmr-admin__top .pmr-secondary-button {
        width: 100%;
    }

    .pmr-table-wrap {
        border: 0;
        background: transparent;
        overflow: visible;
    }

    .pmr-table {
        min-width: 0;
        border-collapse: separate;
        border-spacing: 0 12px;
    }

    .pmr-table thead {
        display: none;
    }

    .pmr-table,
    .pmr-table tbody,
    .pmr-table tr,
    .pmr-table td {
        display: block;
        width: 100%;
    }

    .pmr-table tr {
        border: 1px solid var(--pmr-line);
        border-radius: 8px;
        background: var(--pmr-white);
        overflow: hidden;
    }

    .pmr-table td {
        display: grid;
        grid-template-columns: minmax(116px, 40%) minmax(0, 1fr);
        gap: 10px;
        border-bottom: 1px solid var(--pmr-line);
        overflow-wrap: anywhere;
    }

    .pmr-table td::before {
        content: attr(data-label);
        color: var(--pmr-muted);
        font-weight: 800;
    }

    .pmr-table tr td:last-child {
        border-bottom: 0;
    }

    .pmr-row-actions {
        min-width: 0;
    }
}

/* Public form: required markers and international telephone control. */
.pmr-reservations .pmr-required-marker {
    display: inline !important;
    margin: 0 0 0 2px !important;
    padding: 0 !important;
    color: var(--pmr-red) !important;
    font: inherit !important;
    font-weight: 800 !important;
    line-height: inherit !important;
}

.pmr-reservations .pmr-phone-control,
.pmr-reservations .pmr-phone-control > .iti {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
}

.pmr-reservations .pmr-phone-control .iti__tel-input {
    width: 100% !important;
    min-height: 48px !important;
    margin: 0 !important;
    border: 1px solid #dfe5ea !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    color: #263340 !important;
    box-shadow: none !important;
    font: inherit !important;
}

.pmr-reservations .pmr-phone-control .iti__tel-input:focus {
    border-color: var(--pmr-teal) !important;
    outline: 2px solid rgba(0, 135, 163, 0.16) !important;
    outline-offset: 1px !important;
    box-shadow: none !important;
}

.pmr-reservations .pmr-phone-control .iti__country-container {
    position: absolute !important;
    inset: 0 auto 0 0 !important;
    display: flex !important;
    align-items: stretch !important;
    margin: 0 !important;
    padding: 0 !important;
}

.pmr-reservations .pmr-phone-control .iti__selected-country {
    position: static !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 104px !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 13px !important;
    border: 0 !important;
    border-right: 1px solid #dfe5ea !important;
    border-radius: 10px 0 0 10px !important;
    background: #f3f8f9 !important;
    color: var(--pmr-blue) !important;
    box-shadow: none !important;
    transform: none !important;
}

.pmr-reservations .pmr-phone-control .iti__selected-country-primary {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.pmr-reservations .pmr-phone-control .iti__selected-country-primary .iti__flag {
    flex: 0 0 auto !important;
    margin: 0 !important;
}

.pmr-reservations .pmr-phone-control .iti__selected-country:hover,
.pmr-reservations .pmr-phone-control .iti__selected-country:focus {
    border-color: #dfe5ea !important;
    background: #e8f3f5 !important;
    color: var(--pmr-blue) !important;
    outline: 0 !important;
    box-shadow: none !important;
}

.pmr-reservations .pmr-phone-control .iti__selected-dial-code {
    margin: 0 !important;
    color: var(--pmr-blue) !important;
    font: inherit !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

.pmr-reservations .pmr-phone-control .iti__arrow {
    width: 7px !important;
    height: 7px !important;
    margin: -4px 1px 0 0 !important;
    border: 0 !important;
    border-right: 2px solid var(--pmr-teal) !important;
    border-bottom: 2px solid var(--pmr-teal) !important;
    transform: rotate(45deg) !important;
}

.pmr-reservations .pmr-phone-control .iti__arrow--up {
    margin-top: 4px !important;
    transform: rotate(-135deg) !important;
}

.pmr-reservations .pmr-phone-control .iti__dropdown-content {
    z-index: 99999 !important;
    width: min(360px, calc(100vw - 32px)) !important;
    max-width: calc(100vw - 32px) !important;
    overflow: hidden !important;
    border: 1px solid #dfe5ea !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    box-shadow: 0 18px 46px rgba(0, 44, 62, 0.18) !important;
    color: #263340 !important;
    font-family: "Montserrat", Arial, Helvetica, sans-serif !important;
}

.pmr-reservations .pmr-phone-control .iti__search-input-wrapper {
    padding: 10px !important;
    border-bottom: 1px solid #e4eaed !important;
    background: #f3f8f9 !important;
}

.pmr-reservations .pmr-phone-control .iti__search-icon {
    left: 20px !important;
}

.pmr-reservations .pmr-phone-control .iti__search-input {
    min-height: 40px !important;
    margin: 0 !important;
    padding: 8px 10px 8px 42px !important;
    border: 1px solid #d8e1e5 !important;
    border-radius: 6px !important;
    background: #ffffff !important;
    color: var(--pmr-blue) !important;
    font: inherit !important;
    font-size: 13px !important;
    box-shadow: none !important;
}

.pmr-reservations .pmr-phone-control .iti__country-list {
    max-height: 280px !important;
    padding: 5px !important;
    background: #ffffff !important;
}

.pmr-reservations .pmr-phone-control .iti__country {
    min-height: 42px !important;
    margin: 0 !important;
    padding: 8px 10px !important;
    border-radius: 6px !important;
    color: #3f4d56 !important;
    font-size: 13px !important;
}

.pmr-reservations .pmr-phone-control .iti__country:hover,
.pmr-reservations .pmr-phone-control .iti__country.iti__highlight {
    background: #e8f3f5 !important;
    color: var(--pmr-blue) !important;
}

/* Reservations workspace: clear mobile cards for day-to-day use. */
.pmr-admin-page .pmr-mobile-field-label,
.pmr-admin-page .pmr-card-status {
    display: none;
}

.pmr-admin-page .pmr-contact-list {
    display: grid;
    gap: 4px;
}

.pmr-admin-page .pmr-reservation-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

@media (max-width: 760px) {
    .pmr-admin-page .pmr-table {
        border-spacing: 0 12px !important;
    }

    .pmr-admin-page .pmr-table tr {
        position: relative !important;
        display: block !important;
        padding: 0 !important;
        overflow: hidden !important;
        border: 1px solid #dfe6e9 !important;
        border-radius: 8px !important;
        background: #ffffff !important;
        box-shadow: 0 6px 18px rgba(0, 44, 62, 0.06) !important;
    }

    .pmr-admin-page .pmr-reservation-row--pending {
        border-left: 4px solid #d5a000 !important;
    }

    .pmr-admin-page .pmr-reservation-row--completed {
        border-left: 4px solid var(--pmr-green) !important;
    }

    .pmr-admin-page .pmr-table td {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 12px 14px !important;
        border: 0 !important;
        background: #ffffff !important;
    }

    .pmr-admin-page .pmr-table td + td {
        border-top: 1px solid #edf1f3 !important;
    }

    .pmr-admin-page .pmr-col-reservation {
        padding: 12px 14px 11px !important;
        background: #f4f8f9 !important;
    }

    .pmr-admin-page .pmr-reservation-reference {
        font-size: 18px !important;
        line-height: 1 !important;
    }

    .pmr-admin-page .pmr-card-status {
        display: inline-flex !important;
        align-items: center !important;
        min-height: 25px !important;
        padding: 4px 8px !important;
        border-radius: 5px !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        text-transform: uppercase !important;
    }

    .pmr-admin-page .pmr-card-status--pending {
        background: #fff4c7 !important;
        color: #765600 !important;
    }

    .pmr-admin-page .pmr-card-status--completed {
        background: #e6f5ec !important;
        color: #17653d !important;
    }

    .pmr-admin-page .pmr-table-meta {
        display: block !important;
        margin-top: 6px !important;
        color: #77838b !important;
        font-size: 10px !important;
    }

    .pmr-admin-page .pmr-mobile-field-label {
        display: flex !important;
        align-items: center !important;
        gap: 6px !important;
        margin: 0 0 8px !important;
        color: #6c7982 !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        text-transform: uppercase !important;
    }

    .pmr-admin-page .pmr-mobile-field-label .pmr-admin-icon {
        width: 14px !important;
        height: 14px !important;
        flex-basis: 14px !important;
        color: var(--pmr-teal) !important;
    }

    .pmr-admin-page .pmr-col-pickup {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 4px 10px !important;
    }

    .pmr-admin-page .pmr-col-pickup .pmr-mobile-field-label {
        grid-column: 1 / -1 !important;
    }

    .pmr-admin-page .pmr-pickup-date {
        font-size: 15px !important;
    }

    .pmr-admin-page .pmr-basket-count {
        align-self: center !important;
        margin: 0 !important;
        padding: 6px 8px !important;
        white-space: nowrap !important;
    }

    .pmr-admin-page .pmr-customer-name {
        margin: 0 0 9px !important;
        font-size: 15px !important;
    }

    .pmr-admin-page .pmr-contact-list {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 7px !important;
    }

    .pmr-admin-page .pmr-contact-link,
    .pmr-admin-page .pmr-contact-link--email {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
        min-height: 38px !important;
        margin: 0 !important;
        padding: 8px 10px !important;
        overflow: hidden !important;
        border: 1px solid #dfe8eb !important;
        border-radius: 6px !important;
        background: #f7fafb !important;
        color: var(--pmr-blue) !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        line-height: 1.3 !important;
        text-decoration: none !important;
    }

    .pmr-admin-page .pmr-contact-link .pmr-admin-icon {
        width: 15px !important;
        height: 15px !important;
        flex-basis: 15px !important;
        color: var(--pmr-teal) !important;
    }

    .pmr-admin-page .pmr-contact-link span {
        display: block !important;
        min-width: 0 !important;
        overflow-wrap: anywhere !important;
        word-break: break-word !important;
    }

    .pmr-admin-page .pmr-col-details {
        display: block !important;
        background: #fffdf7 !important;
    }

    .pmr-admin-page .pmr-col-details--empty {
        display: none !important;
    }

    .pmr-admin-page .pmr-observations {
        max-height: none !important;
        padding: 0 !important;
        color: #52606a !important;
        font-size: 12px !important;
        line-height: 1.55 !important;
    }

    .pmr-admin-page .pmr-col-actions {
        padding: 10px !important;
        background: #fbfcfc !important;
    }

    .pmr-admin-page .pmr-col-actions .pmr-admin-action {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        width: 100% !important;
        min-height: 44px !important;
        margin: 0 !important;
        font-size: 12px !important;
    }

    .pmr-admin-page .pmr-col-actions .pmr-admin-icon {
        width: 16px !important;
        height: 16px !important;
        flex-basis: 16px !important;
    }
}

/* Private reservations workspace */
.pmr-admin-page,
.pmr-admin-login-page {
    position: relative;
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    overflow: hidden;
    background: var(--pmr-soft);
}

.pmr-admin-page {
    padding: 32px 0 64px;
}

.pmr-admin-shell {
    position: relative;
    z-index: 1;
    width: min(1440px, calc(100% - 32px));
    margin: 0 auto;
}

.pmr-admin-hero {
    padding: 20px 4px 26px;
    border-bottom: 1px solid #e4e8eb;
}

.pmr-admin-brand,
.pmr-icon-button-text,
.pmr-admin-filter-label,
.pmr-contact-link,
.pmr-basket-count {
    display: inline-flex;
    align-items: center;
}

.pmr-admin-brand {
    gap: 9px;
    margin-bottom: 18px;
    color: var(--pmr-red);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.pmr-admin-brand__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: var(--pmr-blue);
    color: var(--pmr-gold);
}

.pmr-admin-brand__icon .pmr-icon {
    width: 17px;
    height: 17px;
    flex-basis: 17px;
}

.pmr-admin-hero__content {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
}

.pmr-admin .pmr-admin-hero h1 {
    margin: 0;
    color: var(--pmr-blue);
    font-size: 48px;
    font-weight: 800;
    line-height: 1;
}

.pmr-admin .pmr-admin-hero p {
    margin: 8px 0 0;
    color: #65717a;
    font-size: 15px;
}

.pmr-admin-hero__actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.pmr-icon-button-text {
    gap: 8px;
}

.pmr-icon-button-text .pmr-icon {
    width: 18px;
    height: 18px;
    flex-basis: 18px;
}

.pmr-admin-workspace {
    margin-top: 24px;
    overflow: hidden;
    border: 1px solid #e2e7eb;
    border-radius: 8px;
    background: var(--pmr-white);
    box-shadow: 0 16px 40px rgba(0, 44, 62, 0.08);
}

.pmr-admin-toolbar {
    display: grid;
    grid-template-columns: minmax(310px, 1.15fr) minmax(380px, 1.35fr) minmax(250px, 1fr) auto;
    gap: 20px;
    align-items: end;
    padding: 20px;
    border-bottom: 1px solid #e7ebee;
    background: #fbfcfc;
}

.pmr-admin-filter-group {
    min-width: 0;
}

.pmr-admin-filter-label {
    gap: 7px;
    margin-bottom: 8px;
    color: var(--pmr-blue);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.pmr-admin-filter-label .pmr-icon {
    width: 16px;
    height: 16px;
    flex-basis: 16px;
    color: var(--pmr-red);
}

.pmr-admin-presets {
    display: inline-flex;
    max-width: 100%;
    padding: 3px;
    border: 1px solid #dde4e8;
    border-radius: 8px;
    background: var(--pmr-white);
}

.pmr-admin-preset {
    min-height: 36px;
    padding: 7px 11px;
    border: 0 !important;
    border-radius: 6px !important;
    background: transparent !important;
    color: #596771 !important;
    cursor: pointer;
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.pmr-admin-preset:hover,
.pmr-admin-preset:focus-visible {
    color: var(--pmr-blue) !important;
    background: #f0f4f6 !important;
}

.pmr-admin-preset.is-active {
    background: var(--pmr-blue) !important;
    color: var(--pmr-white) !important;
}

.pmr-admin-date-input {
    display: inline-block;
    margin-left: 8px;
    vertical-align: top;
}

.pmr-admin .pmr-admin-date-input input,
.pmr-admin-filter-group--search input {
    width: auto;
    min-height: 44px;
    border-color: #d8e0e5;
    border-radius: 8px;
    background: var(--pmr-white);
    color: var(--pmr-blue);
    font-size: 13px;
}

.pmr-admin-filter-group--search input {
    width: 100%;
}

.pmr-admin-filter-group input[type="hidden"] {
    display: none;
}

.pmr-admin-toolbar__actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

.pmr-admin-toolbar__actions .pmr-submit,
.pmr-admin-toolbar__actions .pmr-secondary-button {
    min-width: 0;
    min-height: 44px;
    padding: 10px 13px;
}

.pmr-admin-toolbar__actions .pmr-submit {
    background: var(--pmr-blue);
}

.pmr-admin-toolbar__actions .pmr-submit:hover,
.pmr-admin-toolbar__actions .pmr-submit:focus {
    background: #00435c;
}

.pmr-admin .pmr-admin-message {
    margin: 18px 20px 0;
}

.pmr-admin-table {
    padding: 20px;
    transition: opacity 160ms ease;
}

.pmr-admin-summary {
    display: grid;
    grid-template-columns: 1.35fr repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin: 0 0 24px;
}

.pmr-admin-summary__item {
    display: flex;
    align-items: center;
    gap: 13px;
    min-width: 0;
    padding: 16px;
    border: 1px solid #e1e7ea;
    border-radius: 8px;
    background: #fbfcfc;
}

.pmr-admin-summary__item--primary {
    border-color: var(--pmr-blue);
    background: var(--pmr-blue);
}

.pmr-admin-summary__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    border-radius: 8px;
    background: rgba(0, 135, 163, 0.1);
    color: var(--pmr-teal);
}

.pmr-admin-summary__item--primary .pmr-admin-summary__icon {
    background: rgba(255, 255, 255, 0.1);
    color: var(--pmr-gold);
}

.pmr-admin-icon {
    display: inline-block;
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
}

.pmr-admin-summary__item > div {
    min-width: 0;
}

.pmr-admin-summary__item span:not(.pmr-admin-summary__icon) {
    display: block;
    color: #697680;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.pmr-admin-summary__item strong {
    display: block;
    margin-top: 1px;
    color: var(--pmr-blue);
    font-family: "League Spartan", Arial, Helvetica, sans-serif;
    font-size: 30px;
    line-height: 1;
}

.pmr-admin-summary__item small {
    display: block;
    margin-top: 4px;
    color: rgba(255, 255, 255, 0.65);
    font-size: 11px;
}

.pmr-admin-summary__item--primary span:not(.pmr-admin-summary__icon),
.pmr-admin-summary__item--primary strong {
    color: var(--pmr-white);
}

.pmr-admin-results-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 12px;
}

.pmr-admin .pmr-admin-results-heading h2 {
    margin: 0;
    color: var(--pmr-blue);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.1;
}

.pmr-admin .pmr-admin-results-heading p {
    margin: 4px 0 0;
    color: #78838b;
    font-size: 12px;
}

.pmr-admin-results-heading > span {
    color: #6d7881;
    font-size: 12px;
    font-weight: 800;
}

.pmr-admin .pmr-table-wrap {
    border-color: #e1e7ea;
    border-radius: 8px;
}

.pmr-admin .pmr-table {
    min-width: 1180px;
    color: #34424c;
}

.pmr-admin .pmr-table th,
.pmr-admin .pmr-table td {
    padding: 16px 14px;
    border-color: #e8ecef;
}

.pmr-admin .pmr-table th {
    background: #f5f7f8;
    color: #596771;
    font-size: 10px;
    letter-spacing: 0.06em;
}

.pmr-admin .pmr-table th:nth-child(1) {
    width: 14%;
}

.pmr-admin .pmr-table th:nth-child(2) {
    width: 16%;
}

.pmr-admin .pmr-table th:nth-child(3) {
    width: 22%;
}

.pmr-admin .pmr-table th:nth-child(4) {
    width: 25%;
}

.pmr-admin .pmr-table th:nth-child(5) {
    width: 10%;
}

.pmr-admin .pmr-table th:nth-child(6) {
    width: 13%;
}

.pmr-reservation-row {
    box-shadow: inset 3px 0 0 transparent;
}

.pmr-reservation-row--pending {
    box-shadow: inset 3px 0 0 #d5a000;
}

.pmr-reservation-row--completed {
    box-shadow: inset 3px 0 0 var(--pmr-green);
}

.pmr-reservation-row--cancelled {
    box-shadow: inset 3px 0 0 #c95a5a;
    opacity: 0.72;
}

.pmr-reservation-row:hover {
    background: #fbfcfc;
}

.pmr-reservation-reference,
.pmr-pickup-date,
.pmr-customer-name {
    display: block;
    color: var(--pmr-blue);
}

.pmr-reservation-reference {
    font-size: 17px;
}

.pmr-table-meta,
.pmr-marketing-consent {
    display: block;
    margin-top: 5px;
    color: #7b8790;
    font-size: 11px;
    line-height: 1.4;
}

.pmr-basket-count {
    gap: 5px;
    margin-top: 8px;
    padding: 5px 8px;
    border-radius: 6px;
    background: rgba(0, 135, 163, 0.1);
    color: var(--pmr-teal);
    font-size: 12px;
    font-weight: 700;
}

.pmr-basket-count .pmr-admin-icon {
    width: 15px;
    height: 15px;
    flex-basis: 15px;
}

.pmr-basket-count strong {
    color: var(--pmr-blue);
    font-size: 15px;
}

.pmr-customer-name {
    margin-bottom: 7px;
}

.pmr-admin .pmr-contact-link {
    display: flex;
    gap: 6px;
    width: fit-content;
    max-width: 100%;
    margin-top: 4px;
    color: var(--pmr-teal) !important;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
}

.pmr-admin .pmr-contact-link:hover,
.pmr-admin .pmr-contact-link:focus {
    color: var(--pmr-blue) !important;
    text-decoration: underline;
}

.pmr-contact-link .pmr-admin-icon {
    width: 14px;
    height: 14px;
    flex-basis: 14px;
}

.pmr-contact-link span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.pmr-observations {
    max-height: 84px;
    overflow: auto;
    color: #45535d;
    font-size: 12px;
    line-height: 1.5;
}

.pmr-observations--empty {
    color: #9aa3aa;
    font-style: italic;
}

.pmr-marketing-consent strong {
    color: #52616b;
}

.pmr-admin .pmr-status {
    gap: 6px;
    min-height: 30px;
    padding: 5px 9px;
    border-radius: 6px;
}

.pmr-admin .pmr-status::before {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    content: "";
}

.pmr-admin .pmr-row-actions {
    display: grid;
    min-width: 150px;
    gap: 6px;
}

.pmr-admin .pmr-admin-action {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 7px;
    width: 100%;
    min-height: 34px;
    border-radius: 6px;
    font-size: 11px;
}

.pmr-admin-action .pmr-admin-icon {
    width: 15px;
    height: 15px;
    flex-basis: 15px;
}

.pmr-admin .pmr-admin-action--complete {
    border-color: var(--pmr-green);
    background: var(--pmr-green);
    color: var(--pmr-white);
}

.pmr-admin .pmr-admin-action--complete:hover,
.pmr-admin .pmr-admin-action--complete:focus {
    border-color: #155f3a;
    background: #155f3a;
    color: var(--pmr-white);
}

.pmr-admin .pmr-admin-action--cancel {
    border-color: #eccdcd;
    background: #fff6f6;
    color: var(--pmr-danger);
}

.pmr-admin .pmr-admin-action--pending {
    border-color: #eadcae;
    background: #fffaf0;
    color: #8a6500;
}

.pmr-admin .pmr-admin-action--icon {
    width: 34px;
    min-width: 34px;
    padding: 7px;
    justify-content: center;
}

.pmr-admin .pmr-empty {
    display: flex;
    min-height: 220px;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 32px;
    border-style: dashed;
    background: #fbfcfc;
    text-align: center;
}

.pmr-empty > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    margin-bottom: 12px;
    border-radius: 8px;
    background: rgba(0, 135, 163, 0.1);
    color: var(--pmr-teal);
}

.pmr-empty > span .pmr-admin-icon {
    width: 24px;
    height: 24px;
    flex-basis: 24px;
}

.pmr-empty strong {
    color: var(--pmr-blue);
    font-size: 16px;
}

.pmr-admin .pmr-empty p {
    margin: 4px 0 0;
    font-size: 12px;
}

/* Private login */
.pmr-admin-login-page {
    min-height: 640px;
    padding: 64px 0;
}

.pmr-login-shell {
    position: relative;
    z-index: 1;
    display: grid;
    width: min(980px, calc(100% - 32px));
    min-height: 520px;
    margin: 0 auto;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.82fr);
    overflow: hidden;
    border: 1px solid #e1e7ea;
    border-radius: 8px;
    background: var(--pmr-white);
    box-shadow: 0 24px 54px rgba(0, 44, 62, 0.12);
}

.pmr-login-brand {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 48px;
    background: var(--pmr-blue);
    color: var(--pmr-white);
}

.pmr-login-brand__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    margin-bottom: 24px;
    border-radius: 8px;
    background: var(--pmr-gold);
    color: var(--pmr-blue);
}

.pmr-login-brand__icon .pmr-icon {
    width: 27px;
    height: 27px;
    flex-basis: 27px;
}

.pmr-login .pmr-login-brand p {
    margin: 0 0 8px;
    color: var(--pmr-gold);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.pmr-login .pmr-login-brand h1 {
    margin: 0 0 14px;
    color: var(--pmr-white);
    font-size: 48px;
    font-weight: 800;
    line-height: 1;
}

.pmr-login-brand > span:last-child {
    color: rgba(255, 255, 255, 0.68);
    font-size: 14px;
}

.pmr-login .pmr-login__box {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 44px;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.pmr-login-lock {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    margin-bottom: 18px;
    border-radius: 8px;
    background: rgba(0, 135, 163, 0.1);
    color: var(--pmr-teal);
}

.pmr-login .pmr-login__box h2 {
    margin: 0 0 8px;
    color: var(--pmr-blue);
    font-size: 30px;
}

.pmr-login .pmr-login__box > p {
    margin: 0;
    font-size: 13px;
}

.pmr-login .pmr-login-form {
    margin-top: 24px;
}

.pmr-login .pmr-login-form .pmr-submit {
    width: 100%;
    background: var(--pmr-gold);
    color: #151515;
}

.pmr-login .pmr-login-form .pmr-submit:hover,
.pmr-login .pmr-login-form .pmr-submit:focus {
    background: #edc83f;
    color: #151515;
}

.pmr-admin-page .screen-reader-text {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

@media (max-width: 1240px) {
    .pmr-admin-toolbar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pmr-admin-toolbar__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 900px) {
    .pmr-admin-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pmr-login-shell {
        grid-template-columns: 1fr;
    }

    .pmr-login-brand {
        min-height: 250px;
    }
}

@media (max-width: 760px) {
    .pmr-admin-page {
        padding: 20px 0 36px;
    }

    .pmr-admin-shell {
        width: min(100% - 20px, 1440px);
    }

    .pmr-admin-hero {
        padding: 12px 2px 20px;
    }

    .pmr-admin-hero__content,
    .pmr-admin-results-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .pmr-admin .pmr-admin-hero h1 {
        font-size: 36px;
    }

    .pmr-admin-hero__actions {
        width: 100%;
        justify-content: flex-start;
    }

    .pmr-admin-hero__actions .pmr-secondary-button {
        width: auto;
    }

    .pmr-admin-toolbar {
        display: flex;
        align-items: stretch;
        flex-direction: column;
        gap: 18px;
        padding: 16px;
    }

    .pmr-admin-presets {
        display: grid;
        width: 100%;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .pmr-admin-filter-group:not(.pmr-admin-filter-group--date) .pmr-admin-presets {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pmr-admin-preset {
        white-space: normal;
    }

    .pmr-admin-date-input {
        display: block;
        margin: 8px 0 0;
    }

    .pmr-admin .pmr-admin-date-input input {
        width: 100%;
    }

    .pmr-admin-toolbar__actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pmr-admin-table {
        padding: 16px;
    }

    .pmr-admin-summary {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    .pmr-admin-summary__item {
        align-items: flex-start;
        min-width: 0;
        padding: 13px;
    }

    .pmr-admin-summary__icon {
        display: none;
    }

    .pmr-admin-summary__item strong {
        font-size: 27px;
    }

    .pmr-admin .pmr-table {
        min-width: 0;
    }

    .pmr-admin .pmr-table tr {
        border-radius: 8px;
        box-shadow: inset 3px 0 0 transparent, 0 8px 22px rgba(0, 44, 62, 0.05);
    }

    .pmr-admin .pmr-reservation-row--pending {
        box-shadow: inset 3px 0 0 #d5a000, 0 8px 22px rgba(0, 44, 62, 0.05);
    }

    .pmr-admin .pmr-reservation-row--completed {
        box-shadow: inset 3px 0 0 var(--pmr-green), 0 8px 22px rgba(0, 44, 62, 0.05);
    }

    .pmr-admin .pmr-reservation-row--cancelled {
        box-shadow: inset 3px 0 0 #c95a5a, 0 8px 22px rgba(0, 44, 62, 0.05);
    }

    .pmr-admin .pmr-table td {
        grid-template-columns: minmax(92px, 30%) minmax(0, 1fr);
        padding: 13px;
    }

    .pmr-admin .pmr-row-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pmr-admin .pmr-admin-action--icon {
        width: 34px;
    }

    .pmr-admin-login-page {
        min-height: 0;
        padding: 28px 0;
    }

    .pmr-login-shell {
        width: min(100% - 20px, 980px);
        min-height: 0;
    }

    .pmr-login-brand,
    .pmr-login .pmr-login__box {
        padding: 30px 24px;
    }

    .pmr-login-brand {
        min-height: 220px;
    }

    .pmr-login .pmr-login-brand h1 {
        font-size: 38px;
    }
}

@media (max-width: 480px) {
    .pmr-admin-summary {
        grid-template-columns: 1fr;
    }

    .pmr-admin-toolbar__actions {
        grid-template-columns: 1fr;
    }

    .pmr-admin .pmr-table td {
        display: block;
    }

    .pmr-admin .pmr-table td::before {
        display: block;
        margin-bottom: 7px;
        font-size: 10px;
        text-transform: uppercase;
    }

    .pmr-admin .pmr-row-actions {
        grid-template-columns: 1fr;
    }
}

/* Keep the private workspace independent from theme and Elementor controls. */
.pmr-admin-page button,
.pmr-admin-page input,
.pmr-admin-page select,
.pmr-admin-page a {
    letter-spacing: 0 !important;
    text-shadow: none !important;
}

.pmr-admin-page button {
    margin: 0 !important;
    font-family: "Montserrat", Arial, Helvetica, sans-serif !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    box-shadow: none !important;
    transform: none !important;
    appearance: none !important;
}

.pmr-admin-page button:hover,
.pmr-admin-page button:focus,
.pmr-admin-page button:active {
    box-shadow: none !important;
    transform: none !important;
}

.pmr-admin-login-page button {
    margin: 0 !important;
    font-family: "Montserrat", Arial, Helvetica, sans-serif !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    text-shadow: none !important;
    box-shadow: none !important;
    transform: none !important;
    appearance: none !important;
}

.pmr-admin-login-page .pmr-icon {
    position: static !important;
    inset: auto !important;
    display: block !important;
    width: 20px !important;
    height: 20px !important;
    flex: 0 0 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    fill: none !important;
    stroke: currentColor !important;
    transform: none !important;
}

.pmr-admin-login-page .pmr-login-brand__icon .pmr-icon {
    width: 27px !important;
    height: 27px !important;
    flex-basis: 27px !important;
}

.pmr-admin-login-page .pmr-submit,
.pmr-admin-login-page .pmr-submit:hover,
.pmr-admin-login-page .pmr-submit:focus {
    border: 0 !important;
    background: var(--pmr-gold) !important;
    color: #151515 !important;
    box-shadow: none !important;
    transform: none !important;
}

.pmr-admin-page .pmr-icon,
.pmr-admin-page .pmr-admin-icon {
    position: static !important;
    inset: auto !important;
    display: block !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    vertical-align: middle !important;
    fill: none !important;
    stroke: currentColor !important;
    transform: none !important;
    pointer-events: none !important;
    width: 18px !important;
    height: 18px !important;
    flex-basis: 18px !important;
}

.pmr-admin-page .pmr-admin-brand__icon .pmr-icon {
    width: 17px !important;
    height: 17px !important;
    flex-basis: 17px !important;
}

.pmr-admin-page .pmr-empty > span .pmr-admin-icon {
    width: 24px !important;
    height: 24px !important;
    flex-basis: 24px !important;
}

.pmr-admin-page .pmr-admin-brand__icon,
.pmr-admin-page .pmr-admin-summary__icon,
.pmr-admin-page .pmr-empty > span {
    line-height: 0 !important;
}

.pmr-admin-page .pmr-icon-button-text,
.pmr-admin-page .pmr-admin-action,
.pmr-admin-page .pmr-admin-filter-label,
.pmr-admin-page .pmr-contact-link,
.pmr-admin-page .pmr-basket-count {
    align-items: center !important;
}

.pmr-admin-page .pmr-secondary-button {
    border: 1px solid #dfe5e9 !important;
    background: #ffffff !important;
    color: var(--pmr-blue) !important;
}

.pmr-admin-page .pmr-secondary-button:hover,
.pmr-admin-page .pmr-secondary-button:focus {
    border-color: var(--pmr-blue) !important;
    background: #f4f7f8 !important;
    color: var(--pmr-blue) !important;
}

.pmr-admin-page .pmr-submit {
    border: 1px solid var(--pmr-blue) !important;
    background: var(--pmr-blue) !important;
    color: #ffffff !important;
}

.pmr-admin-page .pmr-submit:hover,
.pmr-admin-page .pmr-submit:focus {
    border-color: #00435c !important;
    background: #00435c !important;
    color: #ffffff !important;
}

.pmr-admin-page .pmr-admin-preset {
    border: 0 !important;
    background: transparent !important;
    color: #596771 !important;
}

.pmr-admin-page .pmr-admin-preset:hover,
.pmr-admin-page .pmr-admin-preset:focus-visible {
    background: #f0f4f6 !important;
    color: var(--pmr-blue) !important;
}

.pmr-admin-page .pmr-admin-preset.is-active {
    background: var(--pmr-blue) !important;
    color: #ffffff !important;
}

.pmr-admin-page .pmr-admin-action--complete {
    border: 1px solid var(--pmr-green) !important;
    background: var(--pmr-green) !important;
    color: #ffffff !important;
}

.pmr-admin-page .pmr-admin-action--complete:hover,
.pmr-admin-page .pmr-admin-action--complete:focus {
    border-color: #155f3a !important;
    background: #155f3a !important;
    color: #ffffff !important;
}

.pmr-admin-page .pmr-admin-action--cancel {
    border: 1px solid #eccdcd !important;
    background: #fff6f6 !important;
    color: var(--pmr-danger) !important;
}

.pmr-admin-page .pmr-admin-action--cancel:hover,
.pmr-admin-page .pmr-admin-action--cancel:focus {
    border-color: var(--pmr-danger) !important;
    background: #fff0f0 !important;
    color: var(--pmr-danger) !important;
}

.pmr-admin-page .pmr-admin-action--pending {
    border: 1px solid #eadcae !important;
    background: #fffaf0 !important;
    color: #8a6500 !important;
}

.pmr-admin-page .pmr-admin-action--pending:hover,
.pmr-admin-page .pmr-admin-action--pending:focus {
    border-color: #b88b16 !important;
    background: #fff5d8 !important;
    color: #765600 !important;
}

.pmr-admin-page .pmr-admin-action--danger {
    border: 1px solid #eccdcd !important;
    background: #ffffff !important;
    color: var(--pmr-danger) !important;
}

.pmr-admin-page .pmr-admin-action--danger:hover,
.pmr-admin-page .pmr-admin-action--danger:focus {
    border-color: var(--pmr-danger) !important;
    background: #fff0f0 !important;
    color: var(--pmr-danger) !important;
}

.pmr-admin-toolbar {
    grid-template-columns: minmax(330px, 1.15fr) minmax(210px, 0.7fr) minmax(260px, 1fr) auto;
}

.pmr-admin-filter-group select {
    width: 100%;
    min-height: 44px;
    border: 1px solid #d8e0e5 !important;
    border-radius: 8px !important;
    background-color: #ffffff !important;
    color: var(--pmr-blue) !important;
    font: inherit !important;
    font-size: 13px !important;
    box-shadow: none !important;
}

.pmr-admin-filter-group select:hover,
.pmr-admin-filter-group select:focus {
    border-color: var(--pmr-teal) !important;
    outline: 2px solid rgba(0, 135, 163, 0.13) !important;
    outline-offset: 1px !important;
    box-shadow: none !important;
}

.pmr-admin-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 720px;
}

.pmr-admin-summary__item:not(.pmr-admin-summary__item--primary) small {
    color: #7b8790;
}

.pmr-reservation-heading {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: space-between;
}

.pmr-status--mobile {
    display: none;
}

@media (max-width: 760px) {
    .pmr-admin-page {
        font-size: 14px;
    }

    .pmr-admin-brand {
        margin-bottom: 12px;
    }

    .pmr-admin .pmr-admin-hero h1 {
        font-size: 32px;
    }

    .pmr-admin .pmr-admin-hero p {
        margin-top: 5px;
        font-size: 13px;
    }

    .pmr-admin-hero__actions {
        gap: 8px;
    }

    .pmr-admin-hero__actions .pmr-secondary-button {
        min-height: 38px;
        padding: 8px 10px;
    }

    .pmr-admin-workspace {
        margin-top: 16px;
    }

    .pmr-admin-toolbar {
        gap: 14px;
        padding: 14px;
    }

    .pmr-admin-filter-label {
        margin-bottom: 6px;
    }

    .pmr-admin .pmr-admin-date-input input,
    .pmr-admin-filter-group--search input,
    .pmr-admin-filter-group select {
        min-height: 42px;
    }

    .pmr-admin-toolbar__actions .pmr-submit,
    .pmr-admin-toolbar__actions .pmr-secondary-button {
        min-height: 42px;
    }

    .pmr-admin-table {
        padding: 14px;
    }

    .pmr-admin-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: none;
        margin-bottom: 18px;
    }

    .pmr-admin-summary__item {
        min-height: 90px;
        padding: 12px;
    }

    .pmr-admin-summary__item strong {
        font-size: 28px;
    }

    .pmr-admin-summary__item small {
        font-size: 10px;
        line-height: 1.25;
    }

    .pmr-admin-results-heading {
        display: flex;
        align-items: center;
        flex-direction: row;
        margin-bottom: 8px;
    }

    .pmr-admin .pmr-admin-results-heading h2 {
        font-size: 22px;
    }

    .pmr-admin .pmr-table {
        border-spacing: 0 10px;
    }

    .pmr-admin .pmr-table tr {
        padding: 12px;
    }

    .pmr-admin .pmr-table td {
        display: block;
        padding: 8px 0;
        border: 0;
    }

    .pmr-admin .pmr-table td::before {
        display: none;
    }

    .pmr-admin .pmr-table td + td {
        border-top: 1px solid #edf0f2;
    }

    .pmr-admin .pmr-col-reservation {
        padding-top: 0;
        padding-bottom: 10px;
    }

    .pmr-admin .pmr-col-pickup,
    .pmr-admin .pmr-col-customer {
        padding: 10px 0;
    }

    .pmr-admin .pmr-col-status {
        display: none !important;
    }

    .pmr-admin .pmr-col-details--empty {
        display: none !important;
    }

    .pmr-admin .pmr-marketing-consent,
    .pmr-admin .pmr-table-meta,
    .pmr-admin .pmr-contact-link--email {
        display: none;
    }

    .pmr-admin .pmr-status--mobile {
        display: inline-flex;
    }

    .pmr-admin .pmr-pickup-date,
    .pmr-admin .pmr-customer-name {
        font-size: 14px;
    }

    .pmr-admin .pmr-contact-link {
        margin-top: 6px;
        font-size: 13px;
    }

    .pmr-admin .pmr-observations {
        max-height: none;
        font-size: 12px;
    }

    .pmr-admin .pmr-col-actions {
        padding-top: 10px;
    }

    .pmr-admin .pmr-row-actions {
        display: flex;
        gap: 6px;
    }

    .pmr-admin .pmr-admin-action {
        width: auto;
        flex: 1 1 auto;
        justify-content: center;
    }

    .pmr-admin .pmr-admin-action--icon {
        display: none;
    }

    .pmr-admin .pmr-admin-action--danger {
        display: none;
    }

    .pmr-admin .pmr-empty {
        min-height: 150px;
        padding: 24px 16px;
    }
}

@media (max-width: 420px) {
    .pmr-admin-summary__item {
        min-height: 76px;
    }

}

/* Simple two-list workflow: pending reservations and completed reservations. */
.pmr-admin-page .pmr-admin-toolbar {
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) auto !important;
    align-items: end !important;
    gap: 12px !important;
    padding: 16px 20px !important;
}

.pmr-admin-page .pmr-admin-filter-group--search {
    max-width: 620px;
}

.pmr-admin-page .pmr-admin-toolbar__actions {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.pmr-admin-page .pmr-admin-table {
    padding: 20px !important;
}

.pmr-reservation-section + .pmr-reservation-section {
    margin-top: 32px;
    padding-top: 28px;
    border-top: 1px solid #e2e7ea;
}

.pmr-reservation-section__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 12px;
}

.pmr-admin .pmr-reservation-section__header h2 {
    margin: 0;
    color: var(--pmr-blue);
    font-size: 26px;
    font-weight: 800;
    line-height: 1.1;
}

.pmr-admin .pmr-reservation-section__header p {
    margin: 4px 0 0;
    color: #74818a;
    font-size: 12px;
}

.pmr-reservation-section__totals {
    display: flex;
    align-items: baseline;
    gap: 7px;
    color: #6c7881;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.pmr-reservation-section__totals strong {
    color: var(--pmr-blue);
    font-size: 16px;
}

.pmr-reservation-section--completed .pmr-reservation-section__header h2 {
    color: var(--pmr-green);
}

.pmr-admin-page .pmr-table {
    min-width: 1040px !important;
}

.pmr-admin-page .pmr-table th:nth-child(1) {
    width: 14% !important;
}

.pmr-admin-page .pmr-table th:nth-child(2) {
    width: 18% !important;
}

.pmr-admin-page .pmr-table th:nth-child(3) {
    width: 27% !important;
}

.pmr-admin-page .pmr-table th:nth-child(4) {
    width: 29% !important;
}

.pmr-admin-page .pmr-table th:nth-child(5) {
    width: 12% !important;
}

.pmr-admin-page .pmr-reservation-row--completed {
    opacity: 1 !important;
}

.pmr-admin-page .pmr-basket-count {
    padding-left: 8px !important;
}

.pmr-admin-page .pmr-col-actions .pmr-admin-action {
    width: 100% !important;
    justify-content: center !important;
}

.pmr-admin-page .pmr-empty {
    min-height: 120px !important;
    padding: 24px !important;
}

@media (max-width: 760px) {
    .pmr-admin-page .pmr-admin-toolbar {
        display: flex !important;
        align-items: stretch !important;
        flex-direction: column !important;
        padding: 14px !important;
    }

    .pmr-admin-page .pmr-admin-filter-group--search {
        max-width: none;
    }

    .pmr-admin-page .pmr-admin-toolbar__actions {
        display: grid !important;
        grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr) !important;
    }

    .pmr-admin-page .pmr-admin-table {
        padding: 14px !important;
    }

    .pmr-reservation-section + .pmr-reservation-section {
        margin-top: 24px;
        padding-top: 22px;
    }

    .pmr-reservation-section__header {
        align-items: flex-start;
        gap: 8px;
        margin-bottom: 9px;
    }

    .pmr-admin .pmr-reservation-section__header h2 {
        font-size: 22px;
    }

    .pmr-admin .pmr-reservation-section__header p {
        max-width: 230px;
        font-size: 11px;
        line-height: 1.4;
    }

    .pmr-reservation-section__totals {
        align-items: flex-end;
        flex-direction: column;
        gap: 0;
        line-height: 1.3;
        text-align: right;
    }

    .pmr-admin-page .pmr-table {
        min-width: 0 !important;
    }

    .pmr-admin-page .pmr-table tr {
        padding: 0 !important;
    }

    .pmr-admin-page .pmr-table td {
        padding: 12px 14px !important;
    }

    .pmr-admin-page .pmr-table-meta {
        display: block !important;
    }

    .pmr-admin-page .pmr-contact-link--email {
        display: flex !important;
    }

    .pmr-admin-page .pmr-col-details--empty {
        display: none !important;
    }

    .pmr-admin-page .pmr-col-actions .pmr-admin-action {
        min-height: 42px !important;
    }

    .pmr-admin-page .pmr-empty {
        min-height: 105px !important;
        padding: 20px 14px !important;
    }
}
