/* =============================================================
   eCapacita — Main Stylesheet
   Dark mode default | Bootstrap 5 extension
   Palette: #1a1a2e (deep navy) | #d4af37 (gold) | #16213e (sidebar)
   ============================================================= */

/* ── Bootstrap 5 CDN import ─────────────────────────────────── */
@import url("https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css");
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css");
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Roboto+Mono:wght@400;500&display=swap");

/* ── CSS Custom Properties ───────────────────────────────────── */
:root {
    --ec-gold:          #d4af37;
    --ec-gold-light:    #f0d060;
    --ec-gold-dark:     #a88a20;
    --ec-navy:          #1a1a2e;
    --ec-navy-mid:      #16213e;
    --ec-navy-light:    #0f3460;
    --ec-sidebar-w:     260px;
    --ec-topbar-h:      60px;
    --ec-radius:        10px;
    --ec-radius-sm:     6px;
    --ec-transition:    .2s ease;
    --ec-shadow:        0 2px 12px rgba(0,0,0,.35);
    --ec-shadow-lg:     0 8px 32px rgba(0,0,0,.45);
}

/* Dark theme overrides (default) */
[data-bs-theme="dark"] {
    --bs-body-bg:           #0d0d1a;
    --bs-body-color:        #e0e0e8;
    --bs-border-color:      #2a2a4a;
    --bs-card-bg:           #12122a;
    --bs-secondary-bg:      #1a1a35;
    --ec-card-bg:           #12122a;
    --ec-card-border:       #2a2a4a;
    --ec-input-bg:          #1a1a35;
    --ec-nav-hover:         rgba(212,175,55,.12);
    --ec-nav-active:        rgba(212,175,55,.20);
    --ec-text-muted:        #8888aa;
}

/* Light theme overrides */
[data-bs-theme="light"] {
    --bs-body-bg:           #f4f4f8;
    --bs-body-color:        #1a1a2e;
    --bs-border-color:      #dddde8;
    --ec-card-bg:           #ffffff;
    --ec-card-border:       #dddde8;
    --ec-input-bg:          #ffffff;
    --ec-nav-hover:         rgba(26,26,46,.07);
    --ec-nav-active:        rgba(26,26,46,.12);
    --ec-text-muted:        #666688;
}

/* ── Base ────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-size: .9rem;
    line-height: 1.6;
    transition: background-color var(--ec-transition), color var(--ec-transition);
}

a { color: var(--ec-gold); text-decoration: none; }
a:hover { color: var(--ec-gold-light); text-decoration: underline; }

code, pre, .ec-secret-key {
    font-family: 'Roboto Mono', monospace;
    font-size: .82rem;
}

/* ── Layout ──────────────────────────────────────────────────── */
.ec-layout {
    display: flex;
    min-height: 100vh;
    overflow-x: hidden;
}

/* ── Sidebar ─────────────────────────────────────────────────── */
.ec-sidebar {
    width: var(--ec-sidebar-w);
    min-height: 100vh;
    background: var(--ec-navy-mid);
    border-right: 1px solid var(--ec-card-border);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1040;
    transition: transform var(--ec-transition);
    overflow-y: auto;
    overflow-x: hidden;
}

.ec-sidebar-brand {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.25rem 1rem;
    border-bottom: 1px solid rgba(212,175,55,.15);
}

.ec-logo { height: 36px; }

.ec-sidebar-nav { flex: 1; padding: .75rem 0; }

.ec-nav-section { padding: .5rem 0 .25rem; }

.ec-nav-label {
    display: block;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ec-text-muted);
    padding: .4rem 1.25rem .2rem;
}

.ec-nav-link {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .5rem 1.25rem;
    color: #c8c8e0;
    font-size: .88rem;
    font-weight: 450;
    border-radius: 0;
    transition: background var(--ec-transition), color var(--ec-transition), padding var(--ec-transition);
    border-left: 3px solid transparent;
    text-decoration: none;
}

.ec-nav-link:hover {
    background: var(--ec-nav-hover);
    color: var(--ec-gold-light);
    text-decoration: none;
}

.ec-nav-link.active,
.ec-nav-link.ec-active {
    background: var(--ec-nav-active);
    color: var(--ec-gold);
    border-left-color: var(--ec-gold);
    font-weight: 600;
}

.ec-nav-link i { font-size: 1rem; width: 1.2rem; text-align: center; flex-shrink: 0; }

.ec-sidebar-footer {
    border-top: 1px solid rgba(212,175,55,.15);
    padding: .75rem 0;
}

/* ── Main Wrapper ────────────────────────────────────────────── */
.ec-main-wrapper {
    flex: 1;
    margin-left: var(--ec-sidebar-w);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ── Topbar ──────────────────────────────────────────────────── */
.ec-topbar {
    height: var(--ec-topbar-h);
    background: var(--ec-card-bg);
    border-bottom: 1px solid var(--ec-card-border);
    display: flex;
    align-items: center;
    padding: 0 1.5rem;
    gap: 1rem;
    position: sticky;
    top: 0;
    z-index: 100;
}

.ec-topbar-breadcrumb { flex: 1; }

.ec-topbar-actions {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.ec-btn-ghost {
    background: transparent;
    border: 1px solid transparent;
    color: inherit;
    padding: .35rem .55rem;
    border-radius: var(--ec-radius-sm);
}
.ec-btn-ghost:hover {
    background: var(--ec-nav-hover);
    border-color: var(--ec-card-border);
    color: var(--ec-gold);
}

.ec-user-btn {
    display: flex;
    align-items: center;
    background: transparent;
    border: 1px solid var(--ec-card-border);
    border-radius: 50px;
    padding: .3rem .65rem .3rem .3rem;
    color: inherit;
    transition: all var(--ec-transition);
}
.ec-user-btn:hover { border-color: var(--ec-gold); background: var(--ec-nav-hover); }

.ec-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--ec-gold-dark), var(--ec-gold));
    color: #1a1a2e;
    font-weight: 700;
    font-size: .8rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Flash Messages / Toast ──────────────────────────────────── */
.ec-toast-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    max-width: 420px;
    width: 100%;
    pointer-events: none;
}
.ec-flash {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .75rem 1.5rem;
    font-size: .88rem;
    border-left: 4px solid;
    position: relative;
    border-radius: .375rem;
    box-shadow: 0 4px 12px rgba(0,0,0,.25);
    pointer-events: auto;
    animation: ecToastIn .35s ease-out;
}
.ec-flash.ec-toast-out {
    animation: ecToastOut .3s ease-in forwards;
}
@keyframes ecToastIn {
    from { opacity: 0; transform: translateX(40px); }
    to   { opacity: 1; transform: translateX(0); }
}
@keyframes ecToastOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(40px); }
}
.ec-flash .btn-close { margin-left: auto; }
.ec-flash-success { background: rgba(40,167,69,.15); border-color: #28a745; color: #5dba74; }
.ec-flash-error   { background: rgba(220,53,69,.15); border-color: #dc3545; color: #e97c85; }
.ec-flash-warning { background: rgba(255,193,7,.15); border-color: #ffc107; color: #ffd54f; }
.ec-flash-info    { background: rgba(23,162,184,.15); border-color: #17a2b8; color: #4dc4d6; }

/* ── Main Content ────────────────────────────────────────────── */
.ec-content {
    flex: 1;
    padding: 1.75rem;
}

.ec-footer {
    padding: .75rem 1.5rem;
    border-top: 1px solid var(--ec-card-border);
    display: flex;
    align-items: center;
    font-size: .78rem;
    color: var(--ec-text-muted);
}

/* ── Page Header ─────────────────────────────────────────────── */
.ec-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: .75rem;
}

.ec-page-title {
    font-size: 1.35rem;
    font-weight: 700;
    margin: 0;
    letter-spacing: -.01em;
}

/* ── Cards ───────────────────────────────────────────────────── */
.ec-card {
    background: var(--ec-card-bg) !important;
    border: 1px solid var(--ec-card-border) !important;
    border-radius: var(--ec-radius) !important;
    box-shadow: var(--ec-shadow);
}

.ec-card-header {
    background: rgba(255,255,255,.03) !important;
    border-bottom: 1px solid var(--ec-card-border) !important;
    padding: .85rem 1.25rem !important;
    font-weight: 600;
}

/* ── KPI Cards ───────────────────────────────────────────────── */
.ec-kpi-card {
    background: var(--ec-card-bg);
    border: 1px solid var(--ec-card-border);
    border-top: 3px solid;
    border-radius: var(--ec-radius);
    padding: 1.1rem;
    text-align: center;
    transition: transform var(--ec-transition), box-shadow var(--ec-transition);
}
.ec-kpi-card:hover { transform: translateY(-2px); box-shadow: var(--ec-shadow-lg); }
.ec-kpi-icon { font-size: 1.6rem; margin-bottom: .35rem; }
.ec-kpi-value { font-size: 1.6rem; font-weight: 700; line-height: 1.1; }
.ec-kpi-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--ec-text-muted); margin-top: .2rem; }

/* ── Tables ──────────────────────────────────────────────────── */
.ec-table { font-size: .87rem; }
.ec-table thead th {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--ec-text-muted);
    border-bottom: 2px solid var(--ec-card-border);
    padding: .65rem 1rem;
    white-space: nowrap;
}
.ec-table tbody td {
    padding: .7rem 1rem;
    vertical-align: middle;
    border-bottom: 1px solid rgba(255,255,255,.04);
}
.ec-table tbody tr:hover { background: var(--ec-nav-hover); }

/* ── Forms ───────────────────────────────────────────────────── */
.form-control, .form-select {
    background-color: var(--ec-input-bg);
    border-color: var(--ec-card-border);
    color: inherit;
    border-radius: var(--ec-radius-sm);
    font-size: .9rem;
}
.form-control:focus, .form-select:focus {
    background-color: var(--ec-input-bg);
    border-color: var(--ec-gold);
    color: inherit;
    box-shadow: 0 0 0 .2rem rgba(212,175,55,.2);
}
.form-label { font-weight: 500; font-size: .88rem; margin-bottom: .4rem; }
.form-text  { font-size: .78rem; }
.input-group-text {
    background-color: var(--ec-input-bg);
    border-color: var(--ec-card-border);
    color: var(--ec-text-muted);
}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn-ec-gold {
    background: linear-gradient(135deg, var(--ec-gold-dark), var(--ec-gold));
    border: none;
    color: #1a1a2e;
    font-weight: 600;
    letter-spacing: .02em;
    transition: all var(--ec-transition);
}
.btn-ec-gold:hover {
    background: linear-gradient(135deg, var(--ec-gold), var(--ec-gold-light));
    color: #1a1a2e;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(212,175,55,.4);
}
.btn-ec-gold:active { transform: none; }

/* ── Badges ──────────────────────────────────────────────────── */
.badge { font-size: .72rem; font-weight: 600; letter-spacing: .03em; }

.ec-badge-active      { background: rgba(40,167,69,.18);  color: #5dba74; border: 1px solid rgba(40,167,69,.3); }
.ec-badge-inactive    { background: rgba(108,117,125,.18);color: #9ea5ac; border: 1px solid rgba(108,117,125,.3); }
.ec-badge-pending     { background: rgba(255,193,7,.15);  color: #ffd54f; border: 1px solid rgba(255,193,7,.3); }
.ec-badge-approved    { background: rgba(40,167,69,.18);  color: #5dba74; border: 1px solid rgba(40,167,69,.3); }
.ec-badge-rejected    { background: rgba(220,53,69,.15);  color: #e97c85; border: 1px solid rgba(220,53,69,.3); }
.ec-badge-selected    { background: rgba(212,175,55,.18); color: var(--ec-gold); border: 1px solid rgba(212,175,55,.3); }
.ec-badge-completed   { background: rgba(23,162,184,.18); color: #4dc4d6; border: 1px solid rgba(23,162,184,.3); }
.ec-badge-cancelled   { background: rgba(108,117,125,.18);color: #9ea5ac; border: 1px solid rgba(108,117,125,.3); }
.ec-badge-draft       { background: rgba(108,117,125,.18);color: #9ea5ac; border: 1px solid rgba(108,117,125,.3); }
.ec-badge-published   { background: rgba(40,167,69,.18);  color: #5dba74; border: 1px solid rgba(40,167,69,.3); }
.ec-badge-archived    { background: rgba(108,117,125,.18);color: #9ea5ac; border: 1px solid rgba(108,117,125,.3); }
.ec-badge-open        { background: rgba(40,167,69,.18);  color: #5dba74; border: 1px solid rgba(40,167,69,.3); }
.ec-badge-in_progress { background: rgba(23,162,184,.18); color: #4dc4d6; border: 1px solid rgba(23,162,184,.3); }
.ec-badge-suspended   { background: rgba(255,100,50,.15); color: #ff8060; border: 1px solid rgba(255,100,50,.3); }

/* ── Auth Layout ─────────────────────────────────────────────── */
.ec-auth-body {
    background: radial-gradient(ellipse at top left, #1a1a2e 0%, #0d0d1a 60%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.ec-auth-wrapper { width: 100%; max-width: 420px; }

.ec-auth-card {
    background: var(--ec-card-bg);
    border: 1px solid var(--ec-card-border);
    border-radius: 16px;
    padding: 2.5rem;
    box-shadow: var(--ec-shadow-lg);
}

.ec-auth-brand { text-align: center; margin-bottom: 2rem; }
.ec-auth-logo  { height: 52px; }
.ec-auth-title { font-size: 1.5rem; font-weight: 700; color: var(--ec-gold); margin: .5rem 0 .25rem; }
.ec-auth-subtitle { color: var(--ec-text-muted); font-size: .85rem; margin: 0; }

.ec-auth-footer {
    text-align: center;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--ec-card-border);
    font-size: .82rem;
    color: var(--ec-text-muted);
}
.ec-auth-footer a { color: var(--ec-text-muted); }

.ec-totp-input {
    font-size: 2rem !important;
    letter-spacing: .5rem;
    font-family: 'Roboto Mono', monospace;
}

/* ── 2FA Badge ───────────────────────────────────────────────── */
.ec-2fa-icon { line-height: 1; }

/* ── Validate Certificate ────────────────────────────────────── */
.ec-validate-badge {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    margin: 0 auto;
}
.ec-validate-badge.valid   { background: rgba(40,167,69,.15); color: #28a745; }
.ec-validate-badge.invalid { background: rgba(220,53,69,.15);  color: #dc3545; }

/* ── Error Pages ─────────────────────────────────────────────── */
.ec-error-page { padding: 3rem 0; }
.ec-error-code {
    font-size: 7rem;
    font-weight: 900;
    color: var(--ec-gold);
    line-height: 1;
    opacity: .8;
}

/* ── Public Layout ───────────────────────────────────────────── */
.ec-public-navbar {
    background: rgba(13,13,26,.95);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(212,175,55,.15);
    padding: .75rem 0;
    position: sticky;
    top: 0;
    z-index: 1000;
}

.ec-navbar-brand {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ec-gold) !important;
}
.ec-navbar-brand:hover { color: var(--ec-gold-light) !important; }

.ec-public-footer {
    background: var(--ec-navy-mid);
    border-top: 1px solid rgba(212,175,55,.1);
    padding: 2rem 0;
    margin-top: auto;
}

/* ── Notifications Dropdown ──────────────────────────────────── */
.ec-notifications { min-width: 300px; max-height: 400px; overflow-y: auto; }

/* ── Password Rules ──────────────────────────────────────────── */
.ec-password-rules { list-style: none; padding: 0; margin: 0; }
.ec-password-rules li { padding: .1rem 0; font-size: .8rem; }

/* ── QR Screen ───────────────────────────────────────────────── */
.ec-qr-wrapper { display: inline-block; }

/* ── Sidebar overlay (mobile) ────────────────────────────────── */
.ec-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 1039;
}

/* ── Pagination ──────────────────────────────────────────────── */
.pagination .page-link {
    background: var(--ec-input-bg);
    border-color: var(--ec-card-border);
    color: inherit;
    font-size: .85rem;
}
.pagination .page-link:hover {
    background: var(--ec-nav-hover);
    border-color: var(--ec-gold);
    color: var(--ec-gold);
}
.pagination .page-item.active .page-link {
    background: var(--ec-gold);
    border-color: var(--ec-gold);
    color: #1a1a2e;
    font-weight: 700;
}

/* ── Dropdowns ───────────────────────────────────────────────── */
.dropdown-menu {
    background: var(--ec-card-bg);
    border-color: var(--ec-card-border);
    box-shadow: var(--ec-shadow-lg);
    font-size: .88rem;
}
.dropdown-item { color: inherit; }
.dropdown-item:hover, .dropdown-item:focus {
    background: var(--ec-nav-hover);
    color: var(--ec-gold-light);
}
.dropdown-header { color: var(--ec-text-muted); font-size: .75rem; font-weight: 600; text-transform: uppercase; }
.dropdown-divider { border-color: var(--ec-card-border); }

/* ── Breadcrumb ──────────────────────────────────────────────── */
.breadcrumb-item a { color: var(--ec-text-muted); }
.breadcrumb-item.active { color: inherit; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--ec-text-muted); }

/* ── Alerts ──────────────────────────────────────────────────── */
.alert { border-radius: var(--ec-radius-sm); font-size: .88rem; }

/* ── Modals ──────────────────────────────────────────────────── */
.modal-content {
    background: var(--ec-card-bg);
    border-color: var(--ec-card-border);
}
.modal-header { border-bottom-color: var(--ec-card-border); }
.modal-footer { border-top-color: var(--ec-card-border); }

/* ── Progress ────────────────────────────────────────────────── */
.progress { background: var(--ec-card-border); }

/* ── Tabs ────────────────────────────────────────────────────── */
.nav-tabs { border-bottom-color: var(--ec-card-border); }
.nav-tabs .nav-link {
    color: var(--ec-text-muted);
    border-color: transparent;
    font-size: .88rem;
}
.nav-tabs .nav-link:hover { color: var(--ec-gold); border-color: transparent; }
.nav-tabs .nav-link.active {
    background: transparent;
    border-color: var(--ec-card-border) var(--ec-card-border) var(--bs-body-bg);
    color: var(--ec-gold);
    font-weight: 600;
}

/* ── Charts area ─────────────────────────────────────────────── */
canvas { max-width: 100%; }

/* ── Responsive — Sidebar mobile ────────────────────────────── */
@media (max-width: 991.98px) {
    .ec-sidebar {
        transform: translateX(-100%);
        box-shadow: var(--ec-shadow-lg);
    }
    .ec-sidebar.is-open {
        transform: translateX(0);
    }
    .ec-sidebar-overlay.is-visible { display: block; }
    .ec-main-wrapper { margin-left: 0; }
    .ec-content { padding: 1rem; }
}

@media (max-width: 575.98px) {
    .ec-auth-card { padding: 1.75rem 1.25rem; }
    .ec-kpi-value { font-size: 1.3rem; }
    .ec-error-code { font-size: 5rem; }
}

/* ── Utilities ───────────────────────────────────────────────── */
.text-gold  { color: var(--ec-gold) !important; }
.bg-navy    { background-color: var(--ec-navy) !important; }
.border-gold{ border-color: var(--ec-gold) !important; }
.fw-450     { font-weight: 450; }
.cursor-pointer { cursor: pointer; }
.ec-truncate { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 0; }

/* ── Light mode adjustments ──────────────────────────────────── */
[data-bs-theme="light"] .ec-sidebar {
    background: #1a1a2e;
}
[data-bs-theme="light"] .ec-sidebar .ec-nav-label,
[data-bs-theme="light"] .ec-sidebar .ec-nav-link {
    color: #c8c8e0;
}
[data-bs-theme="light"] .ec-sidebar .ec-nav-link:hover {
    color: var(--ec-gold-light);
}
[data-bs-theme="light"] .ec-auth-body {
    background: linear-gradient(135deg, #f0f0f8 0%, #e8e8f4 100%);
}
[data-bs-theme="light"] .ec-auth-card {
    border-color: #dddde8;
    box-shadow: 0 4px 24px rgba(0,0,0,.08);
}

/* ── Landing Page ───────────────────────────────────────────── */
.ec-public-body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.ec-public-body main {
    flex: 1;
}

/* Hero */
.ec-landing-hero {
    position: relative;
    overflow: hidden;
    padding: 2rem 0 0;
    background: linear-gradient(160deg, #0d0d1a 0%, #1a1a2e 40%, #16213e 100%);
}

.ec-hero-bg-pattern {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 80% 30%, rgba(212,175,55,.08) 0%, transparent 50%),
        radial-gradient(ellipse at 20% 80%, rgba(23,162,184,.05) 0%, transparent 40%);
    pointer-events: none;
}

.ec-hero-badge {
    display: inline-flex;
    align-items: center;
    padding: .4rem 1rem;
    background: rgba(212,175,55,.1);
    border: 1px solid rgba(212,175,55,.2);
    border-radius: 50px;
    font-size: .82rem;
    font-weight: 600;
    color: var(--ec-gold);
}

.ec-hero-title {
    font-size: clamp(2rem, 4.5vw, 3.2rem);
    font-weight: 800;
    line-height: 1.12;
    margin-bottom: 1rem;
    letter-spacing: -.02em;
}

.ec-hero-desc {
    font-size: 1.08rem;
    color: var(--ec-text-muted);
    max-width: 500px;
    line-height: 1.7;
}

/* Hero illustration cards */
.ec-hero-illustration {
    position: relative;
    width: 100%;
    height: 380px;
}

.ec-hero-card {
    position: absolute;
    background: var(--ec-card-bg);
    border: 1px solid var(--ec-card-border);
    border-radius: 14px;
    padding: 1rem 1.25rem;
    display: flex;
    align-items: center;
    gap: .85rem;
    font-size: .88rem;
    box-shadow: var(--ec-shadow);
    transition: transform .3s ease;
    min-width: 220px;
}
.ec-hero-card:hover { transform: translateY(-4px); }

.ec-hero-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.ec-hero-card-1 { top: 8%;  left: 5%;  animation: ec-float 6s ease-in-out infinite; }
.ec-hero-card-2 { top: 40%; right: 0;  animation: ec-float 6s ease-in-out infinite 2s; }
.ec-hero-card-3 { bottom: 8%; left: 10%; animation: ec-float 6s ease-in-out infinite 4s; }

@keyframes ec-float {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-8px); }
}

/* Stats bar */
.ec-stats-bar {
    padding: 3rem 0;
    background: var(--ec-navy-mid);
    border-top: 1px solid rgba(212,175,55,.08);
    border-bottom: 1px solid rgba(212,175,55,.08);
}

.ec-stat-item {
    padding: .5rem;
}

.ec-stat-icon {
    font-size: 2rem;
    margin-bottom: .5rem;
    display: block;
}

.ec-stat-value {
    font-size: 2.4rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -.02em;
}

.ec-stat-label {
    color: var(--ec-text-muted);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-top: .3rem;
}

/* Section badge */
.ec-section-badge {
    display: inline-flex;
    align-items: center;
    padding: .3rem .75rem;
    background: rgba(212,175,55,.1);
    border: 1px solid rgba(212,175,55,.15);
    border-radius: 50px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--ec-gold);
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* Features section */
.ec-landing-features {
    padding: 5rem 0;
}

.ec-feature-card {
    background: var(--ec-card-bg);
    border: 1px solid var(--ec-card-border);
    border-radius: var(--ec-radius);
    padding: 1.5rem;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.ec-feature-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--ec-shadow-lg);
    border-color: rgba(212,175,55,.2);
}

.ec-feature-icon {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}

/* Courses section */
.ec-landing-courses {
    padding: 5rem 0;
    background: var(--bs-secondary-bg);
}

/* CTA section */
.ec-landing-cta {
    padding: 5rem 0 6rem;
}

.ec-cta-box {
    background: linear-gradient(135deg, rgba(212,175,55,.08), rgba(26,26,46,.6));
    border: 1px solid rgba(212,175,55,.15);
    border-radius: 24px;
    padding: 4rem 2rem;
}

.ec-cta-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(212,175,55,.12);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: var(--ec-gold);
}

/* Course type badges */
.ec-badge-presencial   { background: rgba(23,162,184,.18); color: #4dc4d6; border: 1px solid rgba(23,162,184,.3); }
.ec-badge-ead          { background: rgba(111,66,193,.18); color: #a78bfa; border: 1px solid rgba(111,66,193,.3); }
.ec-badge-hibrido      { background: rgba(253,126,20,.18); color: #fdba74; border: 1px solid rgba(253,126,20,.3); }
.ec-badge-online       { background: rgba(111,66,193,.18); color: #a78bfa; border: 1px solid rgba(111,66,193,.3); }

/* Landing responsive */
@media (max-width: 991.98px) {
    .ec-landing-hero { padding: 1rem 0 0; }
    .ec-hero-title { font-size: 2rem; }
    .ec-stat-value { font-size: 1.8rem; }
    .ec-landing-features,
    .ec-landing-courses,
    .ec-landing-cta { padding: 3rem 0; }
    .ec-cta-box { padding: 2.5rem 1.5rem; }
}

@media (max-width: 575.98px) {
    .ec-hero-title { font-size: 1.7rem; }
    .ec-hero-desc { font-size: .95rem; }
    .ec-stat-value { font-size: 1.5rem; }
    .ec-stat-icon { font-size: 1.5rem; }
    .ec-feature-card { padding: 1.25rem; }
    .ec-cta-box { padding: 2rem 1rem; border-radius: 16px; }
}
