:root {
    --premium-primary: #2563eb;
    --premium-primary-dark: #1d4ed8;
    --premium-success: #0f766e;
    --premium-warning: #d97706;
    --premium-danger: #dc2626;
    --premium-bg: #eef2ff;
    --premium-card-radius: 26px;
    --premium-shadow: 0 24px 60px rgba(15, 23, 42, 0.14);
    --premium-shadow-soft: 0 12px 32px rgba(15, 23, 42, 0.08);
    --premium-border: rgba(148, 163, 184, 0.18);
    --premium-surface: rgba(255, 255, 255, 0.82);
}

html, body {
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

body {
    background:
        radial-gradient(circle at top left, rgba(37, 99, 235, 0.14), transparent 28%),
        radial-gradient(circle at bottom right, rgba(14, 165, 233, 0.12), transparent 26%),
        linear-gradient(180deg, #eef2ff 0%, #f8fafc 100%);
}

.content-wrapper {
    background: transparent !important;
}

.content-header h1 {
    font-weight: 800;
    letter-spacing: -0.02em;
}

.card,
.premium-card,
.premium-surface {
    border-radius: var(--premium-card-radius);
    box-shadow: var(--premium-shadow-soft);
    border: 1px solid var(--premium-border);
}

.premium-surface {
    background: var(--premium-surface);
    backdrop-filter: blur(10px);
}

.premium-app-shell .main-header,
.premium-app-shell .main-sidebar,
.premium-app-shell .main-footer {
    border: 0;
}

.premium-topbar {
    background: rgba(255, 255, 255, 0.82) !important;
    backdrop-filter: blur(12px);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.07);
}

.premium-topbar-logo {
    width: 32px;
    height: 32px;
    object-fit: contain;
    border-radius: 10px;
    background: rgba(255,255,255,0.92);
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.10);
    padding: 0.18rem;
}

.premium-topbar-title {
    font-weight: 800;
    color: #0f172a;
    letter-spacing: -0.01em;
}

.premium-icon-btn {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(37, 99, 235, 0.08);
    color: var(--premium-primary-dark) !important;
}

.premium-topbar-chip,
.premium-user-pill {
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(37, 99, 235, 0.08);
    border-radius: 999px;
    padding: 0.55rem 0.9rem;
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.08);
}

.premium-sidebar {
    background: linear-gradient(180deg, #0f172a 0%, #111827 45%, #172554 100%) !important;
}

.premium-brand-link {
    display: flex;
    align-items: center;
    gap: 0.95rem;
    min-height: 78px;
    padding: 0.95rem 1rem;
    border-bottom: 0 !important;
}

.premium-brand-logo-wrap {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.22);
    padding: 0.28rem;
    flex-shrink: 0;
}

.premium-brand-logo {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 14px;
}

.premium-brand-copy {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
}

.premium-brand-copy .brand-text {
    color: #fff;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.premium-brand-copy small {
    color: rgba(255, 255, 255, 0.72);
}

.nav-sidebar .nav-link {
    border-radius: 16px;
    margin: 0.18rem 0.55rem;
    color: rgba(255, 255, 255, 0.84);
    font-weight: 600;
}

.nav-sidebar .nav-link.active,
.nav-sidebar .nav-link:hover {
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.92), rgba(59, 130, 246, 0.86)) !important;
    box-shadow: 0 16px 36px rgba(37, 99, 235, 0.35);
    color: #fff !important;
}

.nav-sidebar .nav-link .nav-icon {
    font-size: 1rem;
}

.premium-content-header {
    padding-top: 1.25rem;
}

.premium-page-actions .btn {
    margin-left: 0.35rem;
    margin-bottom: 0.35rem;
}

.premium-btn {
    border-radius: 16px !important;
    box-shadow: 0 12px 24px rgba(37, 99, 235, 0.16);
    font-weight: 700;
}

.premium-hero {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem 1.65rem;
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(255,255,255,0.88), rgba(255,255,255,0.68));
    border: 1px solid rgba(37,99,235,0.1);
    box-shadow: var(--premium-shadow);
}

.premium-hero-dashboard {
    background:
      radial-gradient(circle at top right, rgba(56,189,248,0.18), transparent 30%),
      linear-gradient(135deg, rgba(255,255,255,0.94), rgba(239,246,255,0.88));
}

.premium-overline {
    display: inline-block;
    margin-bottom: 0.35rem;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    color: #2563eb;
}

.premium-role-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.7rem 1rem;
    background: rgba(37,99,235,0.08);
    color: var(--premium-primary-dark);
    font-weight: 700;
    box-shadow: 0 8px 24px rgba(37,99,235,0.10);
}

.premium-shortcut-card,
.simple-menu-card,
.municipio-card,
.person-card {
    border-radius: 24px;
    border: 1px solid var(--premium-border);
    box-shadow: var(--premium-shadow-soft);
    transition: transform .2s ease, box-shadow .2s ease;
}

.premium-shortcut-card:hover,
.simple-menu-card:hover,
.municipio-card:hover,
.person-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--premium-shadow);
}

.premium-shortcut-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}

.bg-primary-soft { background: rgba(37,99,235,0.10); }
.bg-success-soft { background: rgba(16,185,129,0.12); }
.bg-danger-soft { background: rgba(239,68,68,0.12); }

.premium-metric-card {
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    padding: 1.35rem 1.3rem;
    background: rgba(255,255,255,0.9);
    border: 1px solid rgba(148,163,184,0.18);
    box-shadow: var(--premium-shadow-soft);
    min-height: 148px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.premium-metric-card::after {
    content: '';
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 4px;
    background: currentColor;
    opacity: .6;
}

.premium-metric-card.accent-primary { color: var(--premium-primary); }
.premium-metric-card.accent-success { color: #0f766e; }
.premium-metric-card.accent-warning { color: #d97706; }
.premium-metric-card.accent-danger { color: #dc2626; }

.premium-metric-label {
    color: #475569;
    font-size: .92rem;
    font-weight: 600;
}

.premium-metric-value {
    font-size: 2.2rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: #0f172a;
    margin-top: .35rem;
}

.premium-metric-icon {
    width: 62px;
    height: 62px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.7);
    box-shadow: inset 0 0 0 1px rgba(148,163,184,0.14);
    font-size: 1.45rem;
}

.premium-table-wrap {
    border-radius: 20px;
    overflow: hidden;
}

.table-premium {
    margin-bottom: 0;
    background: transparent;
}

.table-premium thead th {
    border-top: 0;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
    color: #475569;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: rgba(248, 250, 252, 0.85);
}

.table-premium tbody td {
    border-top: 1px solid rgba(226, 232, 240, 0.9);
    vertical-align: middle;
}

.table-premium tbody tr:hover {
    background: rgba(239, 246, 255, 0.45);
}

.table-link-strong {
    color: #0f172a;
    font-weight: 700;
}

.premium-count-pill {
    display: inline-flex;
    min-width: 40px;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    background: rgba(37,99,235,0.08);
    color: var(--premium-primary-dark);
    font-weight: 700;
}

.address-status-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border-radius: 20px;
    background: rgba(248,250,252,0.88);
    border: 1px solid rgba(148,163,184,0.20);
}

.form-control,
.custom-select,
.input-group-text,
.btn,
.swal2-popup {
    border-radius: 16px !important;
}

.form-control,
.custom-select {
    border-color: rgba(148, 163, 184, 0.32);
    box-shadow: none !important;
}

.form-control:focus,
.custom-select:focus {
    border-color: rgba(37, 99, 235, 0.56);
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.12) !important;
}

.form-control-lg,
.input-group-lg > .form-control,
.input-group-lg > .input-group-append > .input-group-text,
.input-group-lg > .input-group-prepend > .input-group-text {
    min-height: 56px;
}

.required::after {
    content: ' *';
    color: #dc2626;
}

.info-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.48rem 0.72rem;
    border-radius: 999px;
    background: #eff6ff;
    color: #1e40af;
    font-size: 0.82rem;
    margin-right: 0.45rem;
    margin-bottom: 0.45rem;
}

.document-preview {
    width: 100%;
    max-height: 280px;
    object-fit: cover;
    border-radius: 18px;
    border: 1px solid #e5e7eb;
}

.card-tools-inline .btn {
    margin-right: 0.35rem;
    margin-bottom: 0.35rem;
}

.premium-footer {
    background: rgba(255,255,255,0.82);
    backdrop-filter: blur(10px);
}

.premium-login-body {
    min-height: 100vh;
    background:
      radial-gradient(circle at top left, rgba(37,99,235,0.18), transparent 35%),
      radial-gradient(circle at bottom right, rgba(14,165,233,0.16), transparent 30%),
      linear-gradient(180deg, #eef4ff 0%, #f7f9fc 100%);
}

.premium-login-shell {
    width: min(540px, 94vw);
}

.premium-login-brand {
    text-align: center;
}

.premium-login-logo-wrap {
    width: 112px;
    height: 112px;
    margin: 0 auto 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 30px;
    background: rgba(255,255,255,0.96);
    box-shadow: 0 18px 45px rgba(37, 99, 235, 0.18);
    padding: 0.55rem;
}

.premium-login-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.login-preloader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(248, 250, 252, 0.92);
    backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .22s ease, visibility .22s ease;
    z-index: 2000;
}

.login-preloader-overlay.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
}

.login-preloader-card {
    width: min(460px, 94vw);
    text-align: center;
    background: rgba(255,255,255,0.96);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 32px;
    box-shadow: 0 28px 80px rgba(15, 23, 42, 0.18);
    padding: 2rem 1.5rem 1.65rem;
}

.login-preloader-logo-wrap {
    width: 124px;
    height: 124px;
    margin: 0 auto 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 34px;
    background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(239,246,255,0.96));
    box-shadow: 0 20px 50px rgba(37, 99, 235, 0.16);
    padding: 0.7rem;
}

.login-preloader-logo {
    width: 100%;
    height: 100%;
    object-fit: contain;
    animation: logoFloat 1.8s ease-in-out infinite;
}

.login-preloader-card h2 {
    font-size: 1.5rem;
    font-weight: 800;
    margin-bottom: 0.4rem;
    color: #0f172a;
}

.login-preloader-card p {
    margin-bottom: 1rem;
    color: #475569;
}

.login-preloader-progress {
    width: 100%;
    height: 12px;
    border-radius: 999px;
    background: #e2e8f0;
    overflow: hidden;
    box-shadow: inset 0 2px 8px rgba(15, 23, 42, 0.08);
}

.login-preloader-progress-bar {
    width: 0%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #16a34a 0%, #38bdf8 52%, #2563eb 100%);
    box-shadow: 0 8px 20px rgba(37, 99, 235, 0.22);
    transition: width .25s ease;
}

.login-preloader-status {
    margin-top: 0.85rem;
    color: #334155;
    font-weight: 700;
    font-size: 0.95rem;
}

@keyframes logoFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

.premium-login-card {
    border-radius: 28px;
}

.swal2-popup {
    box-shadow: var(--premium-shadow) !important;
}

@media (max-width: 991.98px) {
    .premium-page-actions {
        text-align: left !important;
        margin-top: 0.85rem;
    }
}

@media (max-width: 767.98px) {
    .premium-hero,
    .address-status-card {
        flex-direction: column;
        align-items: stretch;
    }
    .premium-login-shell {
        width: min(94vw, 500px);
    }
    .premium-topbar-chip,
    .premium-user-pill {
        display: none !important;
    }
}


.excel-premium-card{border:1px solid rgba(99,102,241,.16);box-shadow:0 20px 45px rgba(15,23,42,.08);}
.excel-premium-badge{display:inline-flex;align-items:center;padding:.65rem 1rem;border-radius:999px;background:linear-gradient(135deg,#0f172a,#312e81);color:#fff;font-weight:700;box-shadow:0 16px 32px rgba(49,46,129,.2);}
.premium-kicker{display:inline-flex;align-items:center;padding:.35rem .75rem;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.75rem;}
.premium-info-box{padding:1rem 1.1rem;border-radius:1rem;background:#f8fafc;border:1px solid #dbeafe;color:#334155;}
.premium-card .table thead th{background:#0f172a;color:#fff;border:none;}
.premium-card .table tbody tr:nth-child(even){background:#f8fafc;}
.premium-card .table tbody tr:hover{background:#eef2ff;}

/* v20 premium deluxe */
.premium-chart-card .card-body { min-height: 320px; }
.premium-chart-head { display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; margin-bottom:1rem; }
.premium-chart-head h3 { font-size:1.05rem; font-weight:800; margin:0 0 .15rem; }
.premium-chart-badge { display:inline-flex; align-items:center; gap:.5rem; padding:.55rem .9rem; border-radius:999px; background:rgba(79,70,229,.08); color:#4338ca; font-weight:700; }
.premium-chart-canvas-wrap { position:relative; height:250px; }
.premium-chart-canvas-wrap canvas { width:100% !important; height:250px !important; }

.table-premium-deluxe thead th,
.table-premium thead th {
    background: linear-gradient(180deg, #f8fafc 0%, #eef2ff 100%);
    color:#0f172a;
    font-size:.78rem;
    text-transform:uppercase;
    letter-spacing:.04em;
    border-bottom:1px solid #dbe4ff;
}
.table-premium-deluxe tbody tr:hover,
.table-premium tbody tr:hover { background:#f8fbff; }
.table-premium-deluxe td, .table-premium-deluxe th,
.table-premium td, .table-premium th { vertical-align:middle; }
.premium-datatable-wrapper .dataTables_length,
.premium-datatable-wrapper .dataTables_filter { margin-bottom: .75rem; }
.premium-datatable-wrapper .premium-dt-search {
    min-width: 240px;
    border-radius: 999px;
    border:1px solid #dbe4ff;
    box-shadow:none;
    padding-left: 1rem;
}
.premium-datatable-wrapper .dataTables_paginate .paginate_button {
    border-radius: 999px !important;
    margin: 0 .15rem;
    border: 0 !important;
}
.premium-datatable-wrapper .dataTables_paginate .paginate_button.current,
.premium-datatable-wrapper .dataTables_paginate .paginate_button.current:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #2563eb 100%) !important;
    color:#fff !important;
}
.premium-datatable-wrapper .dataTables_paginate .paginate_button:hover {
    background:#eef2ff !important;
    color:#1e293b !important;
}
.premium-datatable-wrapper .dataTables_info { color:#64748b; font-size:.88rem; }
.premium-table-shell {
    border:1px solid #e5e7eb;
    border-radius:1rem;
    overflow:hidden;
    background:#fff;
    box-shadow:0 14px 40px rgba(15,23,42,.04);
}
.premium-export-note {
    display:flex;
    align-items:center;
    gap:.75rem;
    padding:1rem 1.1rem;
    border-radius:1rem;
    background:linear-gradient(135deg,#eff6ff 0%,#eef2ff 100%);
    color:#1e3a8a;
    font-weight:600;
}
.premium-stat-mini {
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    padding:.45rem .8rem;
    border-radius:999px;
    background:#f8fafc;
    color:#334155;
    font-size:.82rem;
    font-weight:700;
}
.premium-kpi-grid {
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:1rem;
}
.premium-kpi-card {
    border-radius:1.25rem;
    padding:1.1rem 1rem;
    background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);
    color:#fff;
    box-shadow:0 18px 45px rgba(15,23,42,.18);
}
.premium-kpi-card .value { font-size:2rem; font-weight:800; line-height:1; }
.premium-kpi-card .label { opacity:.8; text-transform:uppercase; letter-spacing:.06em; font-size:.75rem; }
.premium-modal-table .btn { border-radius:999px; }

/* =========================
   SOC Premium Security Center
   ========================= */
.soc-shell {
    padding-bottom: 1rem;
}

.soc-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, .7fr);
    gap: 1.5rem;
    padding: 1.6rem 1.7rem;
    border-radius: 30px;
    background:
        radial-gradient(circle at top right, rgba(34, 211, 238, 0.18), transparent 28%),
        radial-gradient(circle at bottom left, rgba(59, 130, 246, 0.16), transparent 30%),
        linear-gradient(135deg, rgba(15, 23, 42, 0.94), rgba(30, 41, 59, 0.88));
    color: #fff;
    box-shadow: 0 30px 70px rgba(2, 6, 23, 0.28);
}

.soc-kicker {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    color: #bfdbfe;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.soc-hero h2 {
    font-size: 2.15rem;
    font-weight: 800;
    margin: 0.9rem 0 0.65rem;
    letter-spacing: -0.03em;
}

.soc-hero p {
    max-width: 760px;
    color: rgba(255, 255, 255, 0.78);
    margin-bottom: 1rem;
}

.soc-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.soc-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.7rem 0.95rem;
    border-radius: 999px;
    background: rgba(255,255,255,0.1);
    color: #e2e8f0;
    font-weight: 600;
}

.soc-score-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 1rem;
    border-radius: 26px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
}

.soc-score-ring {
    --score: 0;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    background:
        radial-gradient(circle at center, rgba(15, 23, 42, 0.92) 0 58%, transparent 58%),
        conic-gradient(#22c55e calc(var(--score) * 1%), rgba(255,255,255,0.12) 0);
    display: grid;
    place-items: center;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08), 0 24px 40px rgba(2, 6, 23, 0.24);
}

.soc-score-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 108px;
    height: 108px;
    border-radius: 50%;
    background: rgba(15, 23, 42, 0.96);
}

.soc-score-value {
    font-size: 2.3rem;
    font-weight: 800;
    line-height: 1;
}

.soc-score-inner small {
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 0.68rem;
    color: #93c5fd;
}

.soc-score-title {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: #93c5fd;
    font-weight: 800;
}

.soc-score-subtitle {
    font-size: 1.1rem;
    font-weight: 700;
    max-width: 180px;
}

.soc-filterbar,
.soc-panel,
.soc-metric-card {
    background: rgba(255,255,255,0.86);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(148,163,184,0.18);
    border-radius: 26px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

.soc-filterbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.2rem;
}

.soc-filter-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.soc-filter-actions .btn {
    border-radius: 999px;
    padding-inline: 0.9rem;
    font-weight: 700;
}

.soc-filter-actions .btn.active {
    box-shadow: 0 14px 24px rgba(15, 23, 42, 0.12);
}

.soc-metric-card {
    position: relative;
    overflow: hidden;
    min-height: 164px;
    padding: 1.15rem;
}

.soc-metric-card::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 4px;
    background: currentColor;
    opacity: 0.7;
}

.soc-metric-card.critical { color: #dc2626; }
.soc-metric-card.high { color: #ea580c; }
.soc-metric-card.medium { color: #2563eb; }
.soc-metric-card.healthy { color: #16a34a; }

.soc-metric-icon {
    width: 50px;
    height: 50px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(15, 23, 42, 0.06);
    margin-bottom: 0.9rem;
    font-size: 1.2rem;
}

.soc-metric-label {
    font-size: 0.84rem;
    color: #64748b;
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.soc-metric-value {
    font-size: 2rem;
    line-height: 1;
    font-weight: 800;
    margin-bottom: 0.45rem;
    color: #0f172a;
}

.soc-metric-trend {
    font-size: 0.82rem;
    color: #64748b;
}

.soc-metric-trend.up::before,
.soc-metric-trend.flat::before {
    margin-right: 0.4rem;
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
}

.soc-metric-trend.up::before { content: "\f062"; color: #16a34a; }
.soc-metric-trend.flat::before { content: "\f068"; color: #64748b; }

.soc-panel {
    padding: 1.15rem 1.2rem;
}

.soc-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.soc-panel-head h3 {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.soc-panel-head p {
    margin: 0.25rem 0 0;
    color: #64748b;
}

.soc-mini-badge {
    padding: 0.5rem 0.8rem;
    border-radius: 999px;
    background: rgba(37, 99, 235, 0.08);
    color: #1d4ed8;
    font-weight: 700;
    white-space: nowrap;
}

.soc-priority-grid,
.soc-recommendation-list,
.soc-coverage-list,
.soc-risk-stack {
    display: grid;
    gap: 0.9rem;
}

.soc-priority-card,
.soc-rec-card,
.soc-coverage-item,
.soc-session-card,
.soc-guidelines {
    border-radius: 22px;
    border: 1px solid rgba(148,163,184,0.18);
    background: rgba(255,255,255,0.86);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.soc-priority-card {
    padding: 1rem 1rem 1rem 1.05rem;
    border-left: 5px solid transparent;
}

.soc-priority-card[data-soc-severity="critical"] { border-left-color: #dc2626; }
.soc-priority-card[data-soc-severity="high"] { border-left-color: #ea580c; }
.soc-priority-card[data-soc-severity="medium"] { border-left-color: #2563eb; }
.soc-priority-card[data-soc-severity="healthy"] { border-left-color: #16a34a; }

.soc-priority-card h4,
.soc-rec-card h4 {
    font-size: 1.02rem;
    font-weight: 800;
    margin: 0.8rem 0 0.45rem;
}

.soc-priority-card p,
.soc-rec-card p {
    margin: 0;
    color: #475569;
}

.soc-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.soc-action-btn {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(15,23,42,0.94), rgba(37,99,235,0.94));
    color: #fff !important;
    box-shadow: 0 18px 28px rgba(37, 99, 235, 0.18);
    font-weight: 700;
}

.soc-action-btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.soc-session-card {
    padding: 0.75rem 0.9rem;
}

.soc-session-title,
.soc-stack-title {
    font-weight: 800;
    margin-bottom: 0.65rem;
    color: #0f172a;
}

.soc-session-card th,
.soc-session-card td {
    border-top: 0 !important;
    padding: 0.4rem 0;
}

.soc-bars {
    min-height: 220px;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.8rem;
    align-items: end;
    padding: 0.6rem 0.25rem 0;
}

.soc-bar-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.55rem;
}

.soc-bars-stack {
    width: 100%;
    height: 180px;
    display: flex;
    align-items: end;
    justify-content: center;
    gap: 0.35rem;
    padding: 0 0.3rem;
}

.soc-bar {
    display: inline-block;
    width: 18px;
    min-height: 8px;
    border-radius: 999px 999px 8px 8px;
    transition: transform .2s ease;
}

.soc-bar:hover { transform: translateY(-2px); }
.soc-bar.login { background: linear-gradient(180deg, #60a5fa, #2563eb); }
.soc-bar.risk { background: linear-gradient(180deg, #fb7185, #dc2626); }

.soc-bar-label {
    font-size: 0.78rem;
    color: #64748b;
    font-weight: 700;
}

.soc-legend {
    display: flex;
    gap: 1rem;
    margin-top: 0.8rem;
    color: #475569;
    font-size: 0.84rem;
}

.soc-coverage-meter {
    margin-bottom: 1rem;
}

.soc-coverage-bar {
    width: 100%;
    height: 13px;
    border-radius: 999px;
    background: rgba(148,163,184,0.16);
    overflow: hidden;
}

.soc-coverage-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #2563eb, #22c55e);
}

.soc-coverage-meta {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.65rem;
    font-size: 0.86rem;
    color: #475569;
}

.soc-coverage-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.95rem 1rem;
}

.soc-missing-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.55rem;
}

.soc-missing-tags span {
    border-radius: 999px;
    background: rgba(239, 68, 68, 0.08);
    color: #b91c1c;
    padding: 0.28rem 0.55rem;
    font-size: 0.75rem;
    font-weight: 700;
}

.soc-table thead th {
    border-top: 0;
    color: #475569;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.soc-table tbody td,
.soc-table tbody th {
    vertical-align: middle;
}

.soc-badge-status,
.soc-severity-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 999px;
    padding: 0.45rem 0.72rem;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.05em;
}

.soc-badge-status.is-ok {
    background: rgba(34,197,94,0.12);
    color: #166534;
}

.soc-badge-status.is-risk {
    background: rgba(239,68,68,0.10);
    color: #b91c1c;
}

.soc-severity-pill.critical { background: rgba(239,68,68,0.12); color: #b91c1c; }
.soc-severity-pill.high { background: rgba(249,115,22,0.14); color: #c2410c; }
.soc-severity-pill.medium { background: rgba(37,99,235,0.12); color: #1d4ed8; }
.soc-severity-pill.healthy { background: rgba(34,197,94,0.12); color: #166534; }

.soc-rec-card {
    padding: 1rem 1rem 1.05rem;
}

.soc-rec-card.is-enabled {
    border-color: rgba(34,197,94,0.28);
    box-shadow: 0 16px 32px rgba(34,197,94,0.10);
}

.soc-rec-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
}

.soc-rec-icon.critical { background: rgba(239,68,68,0.1); color: #b91c1c; }
.soc-rec-icon.high { background: rgba(249,115,22,0.14); color: #c2410c; }
.soc-rec-icon.medium { background: rgba(37,99,235,0.1); color: #1d4ed8; }
.soc-rec-icon.healthy { background: rgba(34,197,94,0.1); color: #166534; }

.soc-rec-next {
    margin-top: 0.8rem;
    padding-top: 0.75rem;
    border-top: 1px dashed rgba(148,163,184,0.24);
    color: #334155;
    font-size: 0.9rem;
}

.soc-rec-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.85rem;
}

.soc-risk-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.65rem 0.85rem;
    border-radius: 16px;
    background: rgba(248, 250, 252, 0.95);
    border: 1px solid rgba(148,163,184,0.14);
    margin-bottom: 0.55rem;
}

.soc-guidelines {
    padding: 1rem;
}

.soc-guidelines ul {
    margin: 0;
    padding-left: 1.1rem;
    color: #334155;
}

.soc-guidelines li + li {
    margin-top: 0.55rem;
}

@media (max-width: 991.98px) {
    .soc-hero {
        grid-template-columns: 1fr;
    }

    .soc-filterbar,
    .soc-panel-head,
    .soc-coverage-meta {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .soc-action-grid {
        grid-template-columns: 1fr;
    }

    .soc-bars {
        gap: 0.35rem;
    }

    .soc-bar {
        width: 12px;
    }

    .soc-coverage-item {
        flex-direction: column;
        align-items: flex-start;
    }
}


.excel-center-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.7rem 1.8rem;
    border-radius: 28px;
    border: 1px solid rgba(99,102,241,.14);
    box-shadow: 0 22px 44px rgba(15,23,42,.08);
    background:
        radial-gradient(circle at top right, rgba(59,130,246,.16), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,250,252,.92));
}

.excel-hero-copy {
    max-width: 760px;
}

.excel-hero-kicker {
    display: inline-flex;
    align-items: center;
    padding: .5rem .82rem;
    border-radius: 999px;
    background: rgba(37,99,235,.08);
    color: #1d4ed8;
    font-weight: 800;
    font-size: .78rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: .8rem;
}

.excel-hero-title {
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -.03em;
    color: #0f172a;
}

.excel-hero-text {
    color: #475569;
    font-size: 1rem;
    max-width: 760px;
}

.excel-hero-badges {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    min-width: 220px;
}

.excel-badge-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .82rem 1rem;
    border-radius: 18px;
    background: rgba(15,23,42,.94);
    color: #fff;
    font-weight: 700;
    box-shadow: 0 16px 30px rgba(15,23,42,.18);
}

.excel-panel-card {
    border: 1px solid rgba(148,163,184,.16);
    box-shadow: 0 24px 50px rgba(15,23,42,.08);
    border-radius: 28px;
    overflow: hidden;
}

.excel-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.excel-section-head h3 {
    font-weight: 800;
    letter-spacing: -.02em;
    color: #0f172a;
}

.excel-section-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.55), 0 14px 28px rgba(37,99,235,.12);
}

.excel-form-grid .form-group label {
    font-weight: 700;
    color: #334155;
    margin-bottom: .55rem;
}

.excel-input,
.excel-upload-label {
    background: rgba(248,250,252,.94) !important;
    border-color: rgba(148,163,184,.28) !important;
}

.excel-input:hover,
.excel-upload-label:hover {
    border-color: rgba(99,102,241,.34) !important;
}

.excel-upload-shell {
    border-radius: 18px;
    overflow: hidden;
    box-shadow: inset 0 0 0 1px rgba(148,163,184,.14);
}

.excel-upload-shell .custom-file-label {
    min-height: 56px;
    display: flex;
    align-items: center;
    padding-left: 1rem;
}

.excel-upload-shell .custom-file-label::after {
    height: calc(100% - 10px);
    top: 5px;
    right: 5px;
    border-radius: 12px;
    background: linear-gradient(135deg, #2563eb, #4f46e5);
    color: #fff;
    border-left: 0;
    display: inline-flex;
    align-items: center;
    font-weight: 700;
    box-shadow: 0 10px 20px rgba(79,70,229,.18);
}

.excel-action-row,
.excel-secondary-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .9rem;
    flex-wrap: wrap;
}

.excel-inline-note {
    display: inline-flex;
    align-items: center;
    padding: .78rem 1rem;
    border-radius: 16px;
    background: rgba(15,23,42,.05);
    color: #334155;
    font-weight: 600;
}

.excel-primary-btn,
.excel-secondary-btn,
.excel-action-btn {
    min-height: 48px;
    border-radius: 16px !important;
    font-weight: 800;
    letter-spacing: -.01em;
}

.excel-primary-btn {
    min-width: 180px;
    box-shadow: 0 18px 30px rgba(37,99,235,.18);
}

.excel-secondary-btn,
.excel-action-btn.btn-outline-primary,
.excel-action-btn.btn-outline-secondary {
    background: rgba(255,255,255,.9);
    border-width: 1px;
    box-shadow: 0 10px 24px rgba(15,23,42,.06);
}

.excel-primary-btn:hover,
.excel-secondary-btn:hover,
.excel-action-btn:hover {
    transform: translateY(-1px);
}

@media (max-width: 991.98px) {
    .excel-center-hero {
        flex-direction: column;
        align-items: flex-start;
    }

    .excel-hero-badges {
        width: 100%;
        min-width: 0;
        flex-direction: row;
        flex-wrap: wrap;
    }
}

@media (max-width: 575.98px) {
    .excel-center-hero,
    .excel-panel-card .card-body {
        padding: 1.2rem !important;
    }

    .excel-hero-title {
        font-size: 1.55rem;
    }

    .excel-primary-btn,
    .excel-secondary-btn {
        width: 100%;
        justify-content: center;
    }

    .excel-inline-note {
        width: 100%;
    }
}


/* Excel center premium refresh */
.excel-center-shell {
    position: relative;
}
.excel-center-hero {
    gap: 1.5rem;
    padding: 2rem 2.1rem;
    border-radius: 30px;
    border: 1px solid rgba(99, 102, 241, .12);
    box-shadow: 0 26px 50px rgba(15, 23, 42, .08);
    background:
        radial-gradient(circle at 100% 0, rgba(59,130,246,.18), transparent 26%),
        radial-gradient(circle at 0 100%, rgba(79,70,229,.12), transparent 24%),
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,252,.96));
}
.excel-hero-title {
    font-size: 2.2rem;
    line-height: 1.04;
}
.excel-hero-badges {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-end;
    min-width: 0;
}
.excel-badge-pill {
    border-radius: 999px;
    padding: .82rem 1rem;
    background: rgba(15, 23, 42, .92);
}
.excel-panel-card {
    border-radius: 30px;
    border: 1px solid rgba(148,163,184,.18);
    box-shadow: 0 24px 48px rgba(15,23,42,.07);
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.97));
}
.excel-panel-card .card-body {
    padding: 2rem !important;
}
.excel-section-head {
    margin-bottom: 1.35rem;
}
.excel-section-head h3 {
    font-size: 1.8rem;
    letter-spacing: -.03em;
}
.excel-section-icon {
    width: 62px;
    height: 62px;
    border-radius: 20px;
    box-shadow: 0 18px 36px rgba(15,23,42,.10);
}
.excel-section-icon-success {
    background: linear-gradient(135deg, rgba(34,197,94,.16), rgba(16,185,129,.11));
    color: #16a34a;
}
.excel-section-icon-primary {
    background: linear-gradient(135deg, rgba(37,99,235,.16), rgba(99,102,241,.11));
    color: #2563eb;
}
.excel-form-grid .form-group {
    margin-bottom: 1rem;
}
.excel-input {
    min-height: 56px;
    border-radius: 18px;
    padding-left: 1rem;
    font-weight: 600;
    color: #334155;
    background: #f8fafc !important;
    border: 1px solid rgba(148,163,184,.24) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}
.excel-upload-shell,
.excel-upload-shell .custom-file-label {
    border-radius: 18px;
}
.excel-upload-shell .custom-file-label {
    min-height: 58px;
    background: #f8fafc !important;
    border: 1px solid rgba(148,163,184,.24) !important;
    color: #475569;
    font-weight: 600;
}
.excel-upload-shell .custom-file-label::after {
    border-radius: 14px;
    padding: 0 1rem;
    background: linear-gradient(135deg, #1d4ed8, #4f46e5);
    color: #fff;
    font-weight: 800;
    line-height: 44px;
}
.excel-action-row,
.excel-secondary-actions {
    gap: 1rem;
}
.excel-inline-note {
    min-height: 52px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(15,23,42,.05), rgba(99,102,241,.05));
    border: 1px solid rgba(148,163,184,.14);
    color: #334155;
}
.excel-primary-btn,
.excel-secondary-btn {
    min-height: 52px;
    padding: .9rem 1.35rem;
    border-radius: 16px !important;
    font-size: 1rem;
    font-weight: 800;
}
.excel-primary-btn.btn-success {
    background: linear-gradient(135deg, #16a34a, #22c55e);
    border: 0;
    box-shadow: 0 18px 36px rgba(34,197,94,.22);
}
.excel-primary-btn.btn-primary {
    background: linear-gradient(135deg, #1d4ed8, #4f46e5);
    border: 0;
    box-shadow: 0 18px 36px rgba(37,99,235,.22);
}
.excel-secondary-btn {
    border-width: 1px;
    background: rgba(255,255,255,.94);
    box-shadow: 0 12px 24px rgba(15,23,42,.06);
}
@media (max-width: 991.98px) {
    .excel-hero-title {
        font-size: 1.8rem;
    }
    .excel-hero-badges {
        justify-content: flex-start;
    }
}
@media (max-width: 575.98px) {
    .excel-panel-card .card-body,
    .excel-center-hero {
        padding: 1.2rem !important;
    }
    .excel-section-head h3 {
        font-size: 1.45rem;
    }
}



/* Excel center luxe refresh */
.excel-luxe-shell {
    position: relative;
}
.excel-luxe-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(280px, .7fr);
    gap: 1.35rem;
    padding: 2.1rem 2.15rem;
    border-radius: 34px;
    overflow: hidden;
    border: 1px solid rgba(148,163,184,.16);
    background:
        radial-gradient(circle at 12% 18%, rgba(34,197,94,.14), transparent 22%),
        radial-gradient(circle at 88% 12%, rgba(59,130,246,.18), transparent 25%),
        radial-gradient(circle at 100% 100%, rgba(99,102,241,.16), transparent 30%),
        linear-gradient(145deg, rgba(15,23,42,.98), rgba(30,41,59,.96) 45%, rgba(248,250,252,.98) 130%);
    box-shadow: 0 28px 58px rgba(15,23,42,.16);
    color: #fff;
    margin-bottom: 1.35rem;
}
.excel-luxe-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,.08), transparent 32%);
    pointer-events: none;
}
.excel-luxe-hero__copy,
.excel-luxe-hero__panel {
    position: relative;
    z-index: 1;
}
.excel-luxe-chip,
.excel-luxe-section-chip {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .46rem .82rem;
    border-radius: 999px;
    font-weight: 800;
    font-size: .82rem;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.excel-luxe-chip {
    background: rgba(255,255,255,.12);
    color: #eff6ff;
    margin-bottom: 1rem;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
}
.excel-luxe-title {
    margin: 0 0 .7rem;
    font-size: 2.45rem;
    line-height: 1.02;
    font-weight: 900;
    letter-spacing: -.04em;
    max-width: 820px;
}
.excel-luxe-text {
    margin: 0;
    color: rgba(226,232,240,.92);
    font-size: 1.03rem;
    max-width: 760px;
}
.excel-luxe-pillbar {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem;
    margin-top: 1.3rem;
}
.excel-luxe-pill {
    display: inline-flex;
    align-items: center;
    padding: .72rem .98rem;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: #fff;
    font-weight: 700;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
}
.excel-luxe-hero__panel {
    display: grid;
    gap: .9rem;
    align-content: start;
}
.excel-luxe-stat {
    padding: 1rem 1rem 1.05rem;
    border-radius: 22px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
    backdrop-filter: blur(8px);
}
.excel-luxe-stat span {
    display: block;
    color: rgba(226,232,240,.82);
    font-size: .82rem;
    margin-bottom: .3rem;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.excel-luxe-stat strong {
    display: block;
    color: #fff;
    font-size: 1.08rem;
    line-height: 1.2;
}
.excel-luxe-ghost {
    min-height: 52px;
    border-radius: 18px !important;
    border: 0 !important;
    color: #0f172a !important;
    font-weight: 800 !important;
    box-shadow: 0 18px 32px rgba(15,23,42,.16);
}
.excel-luxe-card {
    border: 1px solid rgba(148,163,184,.16);
    border-radius: 30px;
    overflow: hidden;
    background:
        radial-gradient(circle at 100% 0, rgba(59,130,246,.08), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
    box-shadow: 0 22px 50px rgba(15,23,42,.08);
}
.excel-luxe-card .card-body {
    padding: 2rem 2rem 2.05rem !important;
}
.excel-luxe-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.4rem;
}
.excel-luxe-card__head h3 {
    margin: .6rem 0 .4rem;
    font-size: 1.95rem;
    font-weight: 900;
    letter-spacing: -.04em;
    color: #0f172a;
}
.excel-luxe-card__head p {
    margin: 0;
    color: #64748b;
    font-size: 1rem;
}
.excel-luxe-section-chip {
    background: rgba(79,70,229,.1);
    color: #4f46e5;
}
.excel-luxe-icon {
    width: 70px;
    height: 70px;
    border-radius: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(34,197,94,.18), rgba(16,185,129,.12));
    color: #16a34a;
    font-size: 1.4rem;
    box-shadow: 0 20px 36px rgba(15,23,42,.08);
    flex-shrink: 0;
}
.excel-luxe-icon--blue {
    background: linear-gradient(135deg, rgba(37,99,235,.18), rgba(99,102,241,.14));
    color: #2563eb;
}
.excel-luxe-form .form-group label,
.excel-luxe-card label {
    font-weight: 800;
    color: #1e293b;
    margin-bottom: .6rem;
}
.excel-luxe-input,
.excel-luxe-upload .custom-file-label {
    min-height: 58px;
    border-radius: 18px !important;
    border: 1px solid rgba(148,163,184,.22) !important;
    background: linear-gradient(180deg, #ffffff, #f8fafc) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
    padding-left: 1rem;
    font-weight: 700;
    color: #334155;
}
.excel-luxe-input:focus,
.excel-luxe-upload .custom-file-input:focus ~ .custom-file-label {
    border-color: rgba(59,130,246,.46) !important;
    box-shadow: 0 0 0 .2rem rgba(59,130,246,.12), inset 0 1px 0 rgba(255,255,255,.75) !important;
}
.excel-luxe-upload .custom-file-label::after {
    border-radius: 14px;
    border: 0;
    right: 6px;
    top: 6px;
    bottom: 6px;
    height: auto;
    padding: 0 1rem;
    background: linear-gradient(135deg, #1d4ed8, #4f46e5);
    color: #fff;
    font-weight: 800;
    line-height: 46px;
}
.excel-luxe-toolbar,
.excel-luxe-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.excel-luxe-note {
    display: inline-flex;
    align-items: center;
    min-height: 54px;
    padding: .95rem 1rem;
    border-radius: 18px;
    color: #334155;
    font-weight: 700;
    background: linear-gradient(135deg, rgba(15,23,42,.04), rgba(59,130,246,.05));
    border: 1px solid rgba(148,163,184,.14);
}
.excel-luxe-btn {
    min-height: 54px;
    padding: .9rem 1.4rem;
    border-radius: 18px !important;
    font-size: 1rem;
    font-weight: 900 !important;
    border: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 18px 36px rgba(15,23,42,.10);
}
.excel-luxe-btn--success {
    color: #fff !important;
    background: linear-gradient(135deg, #16a34a, #22c55e);
}
.excel-luxe-btn--primary {
    color: #fff !important;
    background: linear-gradient(135deg, #1d4ed8, #4f46e5);
}
.excel-luxe-btn--light {
    color: #1d4ed8 !important;
    background: #fff;
    border: 1px solid rgba(59,130,246,.22) !important;
}
.excel-luxe-btn:hover,
.excel-luxe-ghost:hover {
    transform: translateY(-1px);
    text-decoration: none;
}
@media (max-width: 1199.98px) {
    .excel-luxe-title {
        font-size: 2.1rem;
    }
}
@media (max-width: 991.98px) {
    .excel-luxe-hero {
        grid-template-columns: 1fr;
        padding: 1.5rem;
    }
}
@media (max-width: 575.98px) {
    .excel-luxe-title {
        font-size: 1.74rem;
    }
    .excel-luxe-card .card-body {
        padding: 1.2rem !important;
    }
    .excel-luxe-toolbar,
    .excel-luxe-actions {
        align-items: stretch;
    }
    .excel-luxe-btn,
    .excel-luxe-ghost {
        width: 100%;
    }
}
