/* ============================================
   Elo Touch Brand Design System
   ============================================ */

:root {
    /* Elo Brand Colors - Primary */
    --elo-logo-blue: #3BA6EF;
    --elo-light-blue: #99E0FF;
    --elo-cta-blue: #0069FF;
    --elo-royal: #0032A0;
    --elo-midnight: #012169;

    /* Elo Brand Colors - Neutrals */
    --elo-dark-grey: #33353A;
    --elo-blue-gray: #4A4E59;
    --elo-medium-gray: #95989F;
    --elo-cool-gray: #E0E3EA;
    --elo-light-gray: #EEF1F7;
    --elo-white: #FFFFFF;

    /* Elo Brand Colors - UI Accents (corrected to brand palette) */
    --elo-ui-green: #55B172;
    --elo-ui-yellow: #FBC45F;
    --elo-ui-red: #F0606C;
    --elo-ui-cyan: #31CDCE;

    /* Approved gradients */
    --elo-grad-header: linear-gradient(135deg, var(--elo-logo-blue) 0%, var(--elo-cta-blue) 100%);
    --elo-grad-page: linear-gradient(135deg, var(--elo-logo-blue) 0%, var(--elo-cta-blue) 50%, var(--elo-royal) 100%);
    --elo-grad-deep: linear-gradient(135deg, var(--elo-cta-blue) 0%, var(--elo-royal) 55%, var(--elo-midnight) 100%);

    /* Type scale */
    --fs-xs: 0.8125rem;  /* 13 */
    --fs-sm: 0.875rem;   /* 14 */
    --fs-md: 1rem;       /* 16 */
    --fs-lg: 1.25rem;    /* 20 */
    --fs-xl: 1.75rem;    /* 28 */
    --fs-2xl: 2.5rem;    /* 40 */

    /* Spacing (8px grid) */
    --sp-1: 0.5rem; --sp-2: 1rem; --sp-3: 1.5rem; --sp-4: 2rem;

    /* Font + radius — Mulish is a license-free webfont close to Avenir Next (loaded in the layouts) */
    --elo-font: 'Mulish', 'Avenir Next Lt Pro', 'Avenir Next', 'Avenir', Arial, sans-serif;
    --radius-card: 8px;
    --radius-pill: 50px;
}

/* ============================================
   Base Typography & Layout
   ============================================ */

html {
    font-size: 14px;
    position: relative;
    min-height: 100%;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

body {
    font-family: var(--elo-font);
    color: var(--elo-dark-grey);
    background-color: var(--elo-white);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--elo-dark-grey);
    font-weight: 600;
}

a {
    color: var(--elo-cta-blue);
}

a:hover {
    color: var(--elo-royal);
}

/* ============================================
   Footer
   ============================================ */

.elo-footer-brand {
    font-weight: 700;
    color: var(--elo-logo-blue);
    letter-spacing: 0.05em;
}

.elo-footer-sep {
    margin: 0 0.5rem;
    color: rgba(255, 255, 255, 0.3);
}

.elo-footer-link {
    color: rgba(255, 255, 255, 0.7) !important;
    text-decoration: none;
}

.elo-footer-link:hover {
    color: var(--elo-white) !important;
}

/* ============================================
   Buttons
   ============================================ */

.btn-primary {
    background-color: var(--elo-cta-blue);
    border-color: var(--elo-cta-blue);
    border-radius: 50px;
    padding: 0.5rem 1.5rem;
    font-weight: 500;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--elo-royal);
    border-color: var(--elo-royal);
}

.btn-outline-primary {
    color: var(--elo-cta-blue);
    border-color: var(--elo-cta-blue);
    border-radius: 50px;
    padding: 0.5rem 1.5rem;
    font-weight: 500;
}

.btn-outline-primary:hover {
    background-color: var(--elo-cta-blue);
    border-color: var(--elo-cta-blue);
    color: var(--elo-white);
}

.btn-success { background-color: var(--elo-ui-green); border-color: var(--elo-ui-green); border-radius: var(--radius-pill); font-weight: 500; }

.btn-danger  { background-color: var(--elo-ui-red);   border-color: var(--elo-ui-red);   border-radius: var(--radius-pill); font-weight: 500; }

.btn-warning { background-color: var(--elo-ui-yellow); border-color: var(--elo-ui-yellow); border-radius: var(--radius-pill); font-weight: 500; color: var(--elo-dark-grey); }

.btn-info {
    background-color: var(--elo-logo-blue);
    border-color: var(--elo-logo-blue);
    border-radius: 50px;
    font-weight: 500;
    color: var(--elo-white);
}

.btn-info:hover {
    background-color: var(--elo-cta-blue);
    border-color: var(--elo-cta-blue);
    color: var(--elo-white);
}

.btn-outline-success {
    color: var(--elo-ui-green);
    border-color: var(--elo-ui-green);
    border-radius: 50px;
}

.btn-outline-success:hover {
    background-color: var(--elo-ui-green);
    color: var(--elo-white);
}

.btn-secondary {
    background-color: var(--elo-medium-gray);
    border-color: var(--elo-medium-gray);
    border-radius: 50px;
    font-weight: 500;
}

.btn-sm {
    border-radius: 50px;
    padding: 0.25rem 0.75rem;
}

/* ============================================
   Cards
   ============================================ */

.card {
    border: 1px solid var(--elo-cool-gray);
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.card-body {
    padding: 1.5rem;
}

/* ============================================
   Alerts (Elo-branded)
   ============================================ */

.alert-info {
    background-color: #e8f4fd;
    border-color: var(--elo-logo-blue);
    color: var(--elo-midnight);
}

.alert-warning { background-color: #fff8e1; border-color: var(--elo-ui-yellow); color: var(--elo-dark-grey); }

.alert-success { background-color: #e8f5e9; border-color: var(--elo-ui-green); color: var(--elo-dark-grey); }

.alert-primary {
    background-color: #e3eeff;
    border-color: var(--elo-cta-blue);
    color: var(--elo-midnight);
}

.alert-danger  { background-color: #fde8e8; border-color: var(--elo-ui-red); color: var(--elo-dark-grey); }

.alert-link {
    color: var(--elo-cta-blue);
    font-weight: 600;
}

.alert-link:hover {
    color: var(--elo-royal);
}

/* ============================================
   Tables
   ============================================ */

.table thead th {
    background-color: var(--elo-light-gray);
    color: var(--elo-dark-grey);
    font-weight: 600;
    border-bottom: 2px solid var(--elo-cool-gray);
}

.table-hover tbody tr:hover {
    background-color: var(--elo-light-gray);
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(238, 241, 247, 0.5);
}

/* ============================================
   Breadcrumbs
   ============================================ */

.breadcrumb {
    background-color: var(--elo-light-gray);
    border-radius: 50px;
    padding: 0.5rem 1rem;
}

.breadcrumb-item a {
    color: var(--elo-cta-blue);
}

.breadcrumb-item.active {
    color: var(--elo-dark-grey);
}

/* ============================================
   Pagination
   ============================================ */

.page-link {
    color: var(--elo-cta-blue);
    border-color: var(--elo-cool-gray);
}

.page-link:hover {
    color: var(--elo-royal);
    background-color: var(--elo-light-gray);
}

.page-item.active .page-link {
    background-color: var(--elo-cta-blue);
    border-color: var(--elo-cta-blue);
}

/* ============================================
   Forms
   ============================================ */

a:focus-visible, button:focus-visible, .page-link:focus-visible, .form-control:focus-visible, .form-select:focus-visible {
    outline: 2px solid var(--elo-logo-blue);
    outline-offset: 2px;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--elo-logo-blue);
    box-shadow: 0 0 0 0.2rem rgba(59, 166, 239, 0.25);
}

.form-floating label {
    color: var(--elo-medium-gray);
}

/* ============================================
   Modals
   ============================================ */

.modal-header {
    background-color: var(--elo-light-gray);
    border-bottom: 2px solid var(--elo-cool-gray);
}

.modal-title {
    color: var(--elo-dark-grey);
    font-weight: 600;
}

/* ============================================
   Dropdown
   ============================================ */

.dropdown-menu {
    border-color: var(--elo-cool-gray);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.dropdown-item:hover {
    background-color: var(--elo-light-gray);
    color: var(--elo-cta-blue);
}

/* ============================================
   Utility
   ============================================ */

.text-elo-blue {
    color: var(--elo-cta-blue) !important;
}

.bg-elo-light {
    background-color: var(--elo-light-gray) !important;
}
