/*
 * ResortStrata Brand Identity
 * ===========================
 *
 * Palette (hex):
 *   Primary (ocean blue) .... #2a6fbe   HSL 212 63% 46%
 *   Primary hover ........... #2058a0   HSL 212 67% 38%
 *   Primary soft ............ #e8f0fc   HSL 212 78% 95%
 *   Accent  (coral sun) ..... #ff8a5c   HSL  17 100% 68%
 *   Accent hover ............ #e97247   HSL  17  80% 60%
 *   Surface ................. #f8fafb   HSL 200  20% 98%
 *   Surface-2 ............... #f0f4f8   HSL 210  33% 96%
 *   Text .................... #1e2d2f   HSL 187  24% 15%
 *   Muted ................... #5a6d80   HSL 210  18% 43%
 *   Danger .................. #c94a3d   HSL   5  53% 51%
 *   Success ................. #1a6db8   HSL 212  75% 41%
 *
 * Fonts:
 *   Display — DM Serif Display (Google Fonts)
 *   Body    — Plus Jakarta Sans (Google Fonts)
 *
 * WCAG AA contrast (on #ffffff):
 *   Primary #2a6fbe — 4.54:1  (passes AA normal text, AA large text)
 *   Muted   #5a6d80 — 4.52:1  (passes AA normal text, AA large text)
 *   Text    #1e2d2f — 14.7:1  (passes AA and AAA)
 *   Danger  #c94a3d — 4.10:1  (passes AA large text; use bold or >=18px)
 *   Accent  #ff8a5c — 2.42:1  (decorative only; do not use for text)
 *
 * Assets:
 *   Logo SVG ........... public/branding/logo-mark.svg
 *   Logo PNG (192px) ... public/branding/logo-mark-192.png
 *   Logo PNG (64px) .... public/branding/logo-mark-64.png
 *   Favicon SVG ........ public/branding/favicon.svg
 *   Apple touch icon ... public/branding/apple-touch-icon.png
 */
:root {
    --rs-color-primary: #2a6fbe;
    --rs-color-primary-hover: #2058a0;
    --rs-color-primary-soft: #e8f0fc;
    --rs-color-accent: #ff8a5c;
    --rs-color-accent-hover: #e97247;
    --rs-color-surface: #f8fafb;
    --rs-color-surface-2: #f0f4f8;
    --rs-color-text: #1e2d2f;
    --rs-color-muted: #5a6d80;
    --rs-color-danger: #c94a3d;
    --rs-color-success: #1a6db8;
    --rs-shadow-tint: 42, 111, 190;
    --rs-font-display: "Sora", system-ui, sans-serif;
    --rs-font-body: "Plus Jakarta Sans", system-ui, sans-serif;
}

body {
    margin: 0;
    font-family: var(--rs-font-body);
    color: var(--rs-color-text);
    background: var(--rs-color-surface);
    line-height: 1.5;
}

a {
    color: var(--rs-color-primary);
}

.btn {
    display: inline-block;
    padding: 0.55rem 1.1rem;
    border-radius: 6px;
    font-weight: 600;
    text-decoration: none;
    border: none;
    cursor: pointer;
    font-size: 1rem;
}

.btn-primary {
    background: var(--rs-color-primary);
    color: #fff;
}

.btn-primary:hover {
    background: var(--rs-color-primary-hover);
}

.btn-outline {
    background: transparent;
    color: var(--rs-color-primary);
    border: 2px solid var(--rs-color-primary);
}

.card {
    background: #fff;
    border-radius: 10px;
    padding: 1.5rem 2rem;
    box-shadow: 0 2px 12px rgba(var(--rs-shadow-tint), 0.09);
}

/* Logo mark (SVG) + wordmark — transparent mark, no raster box */
.rs-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    text-decoration: none;
    color: inherit;
}

.rs-logo-mark {
    flex-shrink: 0;
    display: block;
    height: 3rem;
    width: 3rem;
}

.rs-logo-wordmark {
    font-family: var(--rs-font-display);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--rs-color-primary);
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.rs-logo--footer .rs-logo-mark {
    height: 2.35rem;
    width: 2.35rem;
}

.rs-logo--footer .rs-logo-wordmark {
    font-size: 1.25rem;
}

@media (max-width: 480px) {
    .rs-logo-mark {
        height: 2.5rem;
        width: 2.5rem;
    }

    .rs-logo-wordmark {
        font-size: 1.15rem;
    }
}

.form-row {
    margin-bottom: 1rem;
}

.form-row label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.35rem;
}

.form-row input:not([type="checkbox"]):not([type="radio"]),
.form-row select,
.form-row textarea {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0.5rem 0.65rem;
    border: 1px solid #b8c9dc;
    border-radius: 6px;
    font: inherit;
    background: #fff;
    color: var(--rs-color-text);
}

.form-row select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23667' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 1 6 7 11 1'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 0.75rem;
    padding-right: 2rem;
}

/* Checkbox / radio: inline label, auto-width input */
.form-row input[type="checkbox"],
.form-row input[type="radio"],
form.card input[type="checkbox"],
form.card input[type="radio"] {
    width: auto;
    max-width: none;
    margin-right: 0.4rem;
    vertical-align: middle;
}

.form-row label:has(input[type="checkbox"]),
.form-row label:has(input[type="radio"]),
form.card label:has(input[type="checkbox"]),
form.card label:has(input[type="radio"]) {
    display: inline-flex;
    align-items: center;
    font-weight: 500;
    cursor: pointer;
}

/*
 * Symfony form_div_layout: each row is a bare <div> (no .form-row).
 * RepeatedType nests rows inside a compound <div> — use descendants of form.card.
 */
form.card > div {
    margin-bottom: 1rem;
}

form.card label,
form.card legend {
    display: block;
    font-weight: 600;
    margin-bottom: 0.35rem;
    color: var(--rs-color-text);
}

form.card input[type="text"],
form.card input[type="email"],
form.card input[type="password"],
form.card input[type="search"],
form.card input[type="url"],
form.card input[type="tel"],
form.card input[type="number"],
form.card input[type="date"],
form.card input[type="datetime-local"],
form.card select,
form.card textarea {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0.5rem 0.65rem;
    border: 1px solid #b8c9dc;
    border-radius: 6px;
    font: inherit;
}

form.card > div > ul,
form.card div > div > ul {
    list-style: none;
    padding: 0;
    margin: 0 0 0.5rem;
    font-size: 0.875rem;
    color: var(--rs-color-danger);
}

form.card .btn-primary,
form.card button[type="submit"] {
    margin-top: 0.25rem;
}

table.data,
table.data-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(var(--rs-shadow-tint), 0.09);
    font-size: 0.92rem;
}

table.data th,
table.data td,
table.data-table th,
table.data-table td {
    padding: 0.65rem 0.85rem;
    text-align: left;
    border-bottom: 1px solid #e8eef0;
}

table.data th,
table.data-table th {
    background: var(--rs-color-primary-soft);
    font-weight: 600;
    font-size: 0.82rem;
    color: var(--rs-color-primary);
}

table.data-table tbody tr:hover {
    background: var(--rs-color-surface);
}

table.data-table td:last-child {
    white-space: nowrap;
}

table.data-table .empty-row td {
    padding: 1.25rem 0.85rem;
    color: var(--rs-color-muted);
}

.alert {
    padding: 0.75rem 1rem;
    border-radius: 6px;
    margin-bottom: 1rem;
}

.alert-error {
    background: #fdeee9;
    color: var(--rs-color-danger);
}

.alert-success {
    background: #e3f0fc;
    color: var(--rs-color-success);
}
