﻿:root {
    --primary: #cf112c;
    --secondary: #7f7d8e;
    --accent: #2f80ed;

    --success: #16a34a;
    --danger: #cf112c;
    --warning: #f59e0b;
    --info: #2f80ed;

    --bg: #ffffff;
    --surface: #f6f7fb;
    --text: #12131a;
    --muted: #5b5f72;
    --border: #e2e4ee;

    --radius: 14px;
    --shadow: 0 8px 24px rgba(16, 24, 40, 0.1);
    --focus: 0 0 0 4px rgba(47, 128, 237, 0.25);
    --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;

    --bs-primary: var(--primary);
    --bs-secondary: var(--secondary);
    --bs-success: var(--success);
    --bs-danger: var(--danger);
    --bs-warning: var(--warning);
    --bs-info: var(--info);
    --bs-light: var(--surface);
    --bs-dark: var(--text);
    --bs-primary-rgb: 207, 17, 44;
    --bs-secondary-rgb: 127, 125, 142;
    --bs-success-rgb: 22, 163, 74;
    --bs-danger-rgb: 207, 17, 44;
    --bs-warning-rgb: 245, 159, 11;
    --bs-info-rgb: 47, 128, 237;
    --bs-body-color: var(--text);
    --bs-body-bg: var(--bg);
    --bs-border-color: var(--border);
    --bs-font-sans-serif: var(--font);

    --brand-primary: var(--primary);
    --brand-secondary: var(--secondary);
    --brand-accent: var(--accent);
    --surface-light: var(--surface);
    --card-light: var(--surface);
    --text-main: var(--text);
    --text-muted: var(--muted);
    --border-light: var(--border);
}

html.theme-dark,
body.theme-dark {
    --bg: #0f1117;
    --surface: #151824;
    --text: #f2f4ff;
    --muted: #b7bbd0;
    --border: #2a2f44;
    --shadow: 0 10px 30px rgba(0, 0, 0, 0.45);
    --focus: 0 0 0 4px rgba(47, 128, 237, 0.35);

    --bs-body-color: var(--text);
    --bs-body-bg: var(--bg);
    --bs-border-color: var(--border);
}

html {
    font-size: 15px;
}

body {
    margin: 0;
    font-family: var(--font);
    color: var(--text);
    background: var(--bg);
}

html.theme-dark,
body.theme-dark {
    color-scheme: dark;
}

.form-label {
    font-size: 0.91rem;
    color: var(--muted);
    font-weight: 600;
}

.btn-primary,
.playedu-btn-primary {
    background-color: var(--primary);
    border-color: var(--primary);
    color: #fff;
    font-weight: 700;
    border-radius: 12px;
    min-height: 30px;
}

.btn-primary:hover,
.playedu-btn-primary:hover {
    background-color: #a30d22;
    border-color: #a30d22;
    color: #fff;
}

.btn-primary:focus,
.playedu-btn-primary:focus {
    box-shadow: var(--focus);
}

.validation-summary-errors ul {
    margin: 0;
    padding-left: 18px;
}
.campamento-badge {
    border: 1px solid transparent;
    font-weight: 600;
}

.campamento-badge--success {
    background-color: #e9f7ef;
    border-color: #2f8f5b;
    color: #2f8f5b;
}

.campamento-badge--danger {
    background-color: #fdecec;
    border-color: #c53a3a;
    color: #c53a3a;
}
