/* =============================================================
   public-fresh.css — modern overlay that ships AFTER application.css
   for all public (non-admin) pages. The booking widget already lives
   in this language (templates/public/home/_booking.twig). This file
   carries it across the rest of the public chrome: typography,
   navbar, footer, buttons, generic form fields, and a handful of
   layout polish bits. Per-page redesigns are out of scope here.
   ============================================================= */

:root {
    --brand:               #710908;
    --brand-light:         #8a0c0a;
    --brand-dark:          #5a0707;
    --brand-tint:          rgba(113, 9, 8, 0.08);
    --brand-tint-strong:   rgba(113, 9, 8, 0.16);
    --brand-border:        #e5d4d3;
    --brand-border-strong: #d6c0bf;
    --accent:              #BD9351;

    --bg:           #fffcf7;
    --surface:      #ffffff;
    --text:         #2a2a2a;
    --text-muted:   #6a6a6a;
    --text-quiet:   #9a9a9a;
    --border:       #ececec;

    --radius:    6px;
    --radius-sm: 4px;
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 6px 18px rgba(0, 0, 0, 0.08);
}

/* ---- base typography ---- */
body {
    color: var(--text);
    font-family: 'Ubuntu', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4 {
    color: var(--text);
    font-family: inherit;
    letter-spacing: -0.005em;
}
h1 { font-weight: 300; font-size: 32px; line-height: 1.2; }
h2 { font-weight: 400; font-size: 24px; line-height: 1.3; }
h3 { font-weight: 500; font-size: 20px; line-height: 1.3; }
h4 { font-weight: 600; font-size: 16px; }
p  { color: var(--text); }
a  { color: var(--brand); transition: color 0.15s; }
a:hover, a:focus { color: var(--brand-light); text-decoration: none; }

hr { border: 0; border-top: 1px solid var(--border); margin: 24px 0; }

/* ---- navbar ---- */
.navbar.navbar-default {
    background: var(--surface);
    border: 0;
    border-bottom: 1px solid var(--border);
    margin-bottom: 0;
    border-radius: 0;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
    min-height: 64px;
}
.navbar.navbar-default .navbar-brand {
    padding: 21px 15px;        /* (64 - 22) / 2 = 21px, centres the 22px logo */
    height: auto;
}
.navbar.navbar-default .navbar-brand img {
    display: block;
}
@media (max-width: 767px) {
    /* Match the hamburger's 15px margin-right so the logo sits the same
       distance from the left edge as the toggle does from the right. */
    .navbar.navbar-default .navbar-brand { padding: 21px 15px; }
}
.navbar.navbar-default .navbar-nav > li > a {
    color: var(--text);
    font-weight: 400;
    font-size: 14px;
    letter-spacing: 0.3px;
    padding: 22px 14px;
    transition: color 0.15s;
    border-bottom: 2px solid transparent;
}
.navbar.navbar-default .navbar-nav > li > a:hover,
.navbar.navbar-default .navbar-nav > li > a:focus {
    color: var(--brand);
    background: transparent;
}
.navbar.navbar-default .navbar-nav > .active > a,
.navbar.navbar-default .navbar-nav > .active > a:hover,
.navbar.navbar-default .navbar-nav > .active > a:focus {
    color: var(--brand);
    background: transparent;
    border-bottom-color: var(--brand);
}
.navbar.navbar-default .navbar-nav > .open > a,
.navbar.navbar-default .navbar-nav > .open > a:hover,
.navbar.navbar-default .navbar-nav > .open > a:focus {
    background: transparent;
    color: var(--brand);
}
.navbar.navbar-default .navbar-toggle {
    border-color: var(--brand-border);
    margin-top: 16px;
    margin-bottom: 16px;
    border-radius: var(--radius);
}
.navbar.navbar-default .navbar-toggle:hover,
.navbar.navbar-default .navbar-toggle:focus {
    background-color: var(--brand-tint);
    border-color: var(--brand);
}
.navbar.navbar-default .navbar-toggle .icon-bar {
    background-color: var(--brand);
}
.navbar.navbar-default .dropdown-menu {
    border: 1px solid var(--brand-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    padding: 6px 0;
    margin-top: 4px;
    min-width: 140px;
}
.navbar.navbar-default .dropdown-menu > li > a {
    padding: 8px 16px;
    color: var(--text);
    font-size: 14px;
}
.navbar.navbar-default .dropdown-menu > li > a:hover,
.navbar.navbar-default .dropdown-menu > li > a:focus {
    background: var(--brand-tint);
    color: var(--brand);
}
.navbar.navbar-default .caret { border-top-color: var(--brand); }

/* mobile: roomier collapsed menu */
@media (max-width: 767px) {
    .navbar.navbar-default .navbar-collapse {
        border-top: 1px solid var(--border);
        box-shadow: none;
    }
    .navbar.navbar-default .navbar-nav { margin: 0; }
    .navbar.navbar-default .navbar-nav > li > a {
        padding: 14px 18px;
        border-bottom: 1px solid var(--border);
    }
    .navbar.navbar-default .navbar-nav > .active > a { border-bottom-color: var(--border); }
}

/* ---- buttons (Bootstrap .btn family) ---- */
.btn {
    border-radius: var(--radius);
    padding: 10px 20px;
    font-weight: 600;
    letter-spacing: 0.3px;
    font-size: 14px;
    border: 1px solid transparent;
    transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.05s;
}
.btn:active { transform: translateY(1px); }
.btn-primary {
    background: var(--brand);
    border-color: var(--brand);
    color: #fff;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background: var(--brand-light) !important;
    border-color: var(--brand-light) !important;
    color: #fff;
}
.btn-default {
    background: var(--surface);
    border-color: var(--brand-border-strong);
    color: var(--text);
}
.btn-default:hover,
.btn-default:focus {
    background: var(--brand-tint);
    border-color: var(--brand);
    color: var(--brand);
}
.btn-link {
    color: var(--brand);
    text-decoration: none;
}
.btn-link:hover { color: var(--brand-light); text-decoration: underline; }
.btn-lg { padding: 14px 28px; font-size: 16px; }
.btn-sm { padding: 6px 12px; font-size: 13px; }
.btn-block { display: block; width: 100%; }

/* ---- generic form polish (Bootstrap .form-control + bare inputs) ---- */
.form-control {
    border: 1px solid var(--brand-border);
    border-radius: var(--radius);
    box-shadow: none;
    color: var(--text);
    font-size: 15px;
    padding: 10px 14px;
    height: auto;
    min-height: 44px;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.form-control:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 3px var(--brand-tint);
    outline: none;
}
.form-group label {
    color: var(--text);
    font-weight: 500;
    font-size: 14px;
    margin-bottom: 6px;
}
textarea.form-control { min-height: 100px; resize: vertical; }

/* ---- alerts ---- */
.alert {
    border-radius: var(--radius);
    border: 1px solid transparent;
    padding: 12px 16px;
}
.alert-success {
    background: #f1f8ef;
    border-color: #d6e9c6;
    color: #3c763d;
}
.alert-danger {
    background: #fdf2f1;
    border-color: #ebccd1;
    color: #a94442;
}
.alert .close {
    color: inherit;
    opacity: 0.55;
    text-shadow: none;
}
.alert .close:hover { opacity: 1; }

/* ---- modal polish (contact form) ---- */
.modal-content {
    border: 0;
    border-radius: 8px;
    box-shadow: var(--shadow-md);
}
.modal-header {
    border-bottom: 1px solid var(--border);
    padding: 16px 22px;
}
.modal-title {
    color: var(--text);
    font-weight: 500;
    font-size: 20px;
}
.modal-body { padding: 22px; }
.modal-footer {
    border-top: 1px solid var(--border);
    padding: 14px 22px;
}
.modal-header .close {
    color: var(--text-muted);
    opacity: 0.7;
    text-shadow: none;
    font-size: 24px;
    font-weight: 300;
}
.modal-header .close:hover { color: var(--brand); opacity: 1; }

/* ---- footer ---- */
.footer {
    background: var(--surface);
    border-top: 1px solid var(--border);
    margin-top: 60px;
    padding: 40px 0 24px;
    color: var(--text-muted);
}
.footer .footerNav { margin-bottom: 24px; }
.footer .footerNav ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px 28px;
}
.footer .footerNav a {
    color: var(--text);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    padding: 4px 0;
    display: inline-block;
}
.footer .footerNav a:hover { color: var(--brand); }

.footer .copyrights {
    padding-top: 22px;
    border-top: 1px solid var(--border);
    font-size: 13px;
    color: var(--text-quiet);
    line-height: 1.6;
}
.footer .copyrights p { margin: 0; color: inherit; }
.footer .copyrights .footerLogo { margin-bottom: 8px; }
.footer .copyrights .tuv img { max-width: 100%; height: auto; }
@media (max-width: 767px) {
    .footer .copyrights .text-right { text-align: center; margin-top: 16px; }
    .footer .copyrights .col-md-6 { text-align: center; }
}

/* ---- spacing / page chrome ---- */
.alert + .container,
.alert + .row { margin-top: 16px; }

/* keep the homepage hero/carousel untouched — leave .owl-* alone */

/* ---- selection / focus accents site-wide ---- */
::selection { background: var(--brand-tint-strong); color: var(--text); }
:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }
.btn:focus-visible { outline-offset: 3px; }

/* ---- pickadate calendar (booking widget) ---- */
.picker__frame {
    max-width: 320px;
}
.picker__box {
    background: var(--surface);
    padding: 14px 16px;
    border: 1px solid var(--brand-border);
    border-radius: 8px;
    box-shadow: var(--shadow-md);
    color: var(--text);
}
.picker__header {
    margin-top: 4px;
    padding-bottom: 6px;
}
.picker__month, .picker__year {
    color: var(--text);
    font-weight: 600;
    font-style: normal;
    font-size: 16px;
    margin: 0 4px;
}
.picker__year { color: var(--text-muted); font-size: 14px; }
.picker__select--month,
.picker__select--year {
    border: 1px solid var(--brand-border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text);
    font-size: 14px;
    height: auto;
    padding: 4px 6px;
}
.picker__select--month:focus,
.picker__select--year:focus {
    border-color: var(--brand);
    outline: none;
}
.picker__nav--prev,
.picker__nav--next {
    width: 12px;
    height: 12px;
    border-radius: var(--radius-sm);
}
.picker__nav--prev:hover,
.picker__nav--next:hover {
    background: var(--brand-tint);
    cursor: pointer;
}
.picker__nav--prev:before { border-right-color: var(--brand); }
.picker__nav--next:before { border-left-color: var(--brand); }
.picker__nav--disabled,
.picker__nav--disabled:hover,
.picker__nav--disabled:before { background: transparent; }
.picker__nav--disabled:before { opacity: 0.25; }
.picker__table { margin: 8px 0 6px; }
.picker__weekday {
    color: var(--text-muted);
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    padding: 6px 0;
}
.picker__day {
    padding: 8px 0;
    border: 0;
    border-radius: var(--radius-sm);
    color: var(--text);
    font-weight: 400;
    font-size: 14px;
    transition: background 0.1s, color 0.1s;
}
.picker__day--outfocus { color: var(--text-quiet); }
.picker__day--today { color: var(--brand); font-weight: 600; }
.picker__day--today:before { border-top-color: var(--brand) !important; }
.picker__day--infocus:hover,
.picker__day--outfocus:hover,
.picker--focused .picker__day--highlighted,
.picker__day--highlighted:hover {
    background: var(--brand-tint);
    color: var(--brand);
    cursor: pointer;
}
.picker__day--highlighted {
    border: 1px solid var(--brand);
    color: var(--brand);
}
.picker--focused .picker__day--selected,
.picker__day--selected,
.picker__day--selected:hover {
    background: var(--brand) !important;
    color: #fff !important;
    border-radius: var(--radius-sm) !important;
    font-weight: 600;
}
.picker--focused .picker__day--disabled,
.picker__day--disabled,
.picker__day--disabled:hover {
    background: transparent;
    border: 0;
    color: var(--text-quiet);
    opacity: 0.45;
    cursor: not-allowed;
}
.picker__day--disabled:before { border-top-color: var(--text-quiet); }
.picker__footer { padding-top: 6px; }
.picker__button--today,
.picker__button--clear,
.picker__button--close {
    background: var(--surface);
    border: 1px solid var(--brand-border);
    border-radius: var(--radius-sm);
    color: var(--brand);
    font-weight: 600;
    font-size: 13px;
    padding: 8px 6px;
}
.picker__button--today:hover,
.picker__button--clear:hover,
.picker__button--close:hover {
    background: var(--brand-tint);
    border-color: var(--brand);
    color: var(--brand);
    cursor: pointer;
}
.picker__button--today:focus,
.picker__button--clear:focus,
.picker__button--close:focus {
    background: var(--brand-tint);
    border-color: var(--brand);
    outline: none;
}
.picker__button--today:before { border-top-color: var(--brand); }
.picker__button--clear:before { border-top-color: var(--brand-light); }
.picker__button--close:before { color: var(--brand); }
.picker__button--today[disabled],
.picker__button--today[disabled]:hover {
    background: transparent;
    border-color: var(--border);
    color: var(--text-quiet);
}
/* Soften the mobile bottom-sheet backdrop */
.picker--opened .picker__holder {
    background: rgba(0, 0, 0, 0.22);
}

/* Skip pickadate's slide-up / fade-in animation — make the calendar
   appear instantly when the field is clicked. */
.picker__frame,
.picker__holder,
.picker--opened .picker__frame,
.picker--opened .picker__holder {
    transition: none !important;
}
