﻿@import 'tailwindcss';
@import '../../vendor/livewire/flux/dist/flux.css';

@source '../views';
@source '../../vendor/laravel/framework/src/Illuminate/Pagination/resources/views/*.blade.php';
@source '../../vendor/livewire/flux-pro/stubs/**/*.blade.php';
@source '../../vendor/livewire/flux/stubs/**/*.blade.php';

@custom-variant dark (&:where(.dark, .dark *));

@theme {
    --font-sans: 'Instrument Sans', ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';

    --color-zinc-50: #fafafa;
    --color-zinc-100: #f5f5f5;
    --color-zinc-200: #e5e5e5;
    --color-zinc-300: #d4d4d4;
    --color-zinc-400: #a3a3a3;
    --color-zinc-500: #737373;
    --color-zinc-600: #525252;
    --color-zinc-700: #404040;
    --color-zinc-800: #262626;
    --color-zinc-900: #171717;
    --color-zinc-950: #0a0a0a;

    --color-accent: var(--color-neutral-800);
    --color-accent-content: var(--color-neutral-800);
    --color-accent-foreground: var(--color-white);
}

@layer theme {
    .dark {
        --color-accent: var(--color-white);
        --color-accent-content: var(--color-white);
        --color-accent-foreground: var(--color-neutral-800);
    }
}

@layer base {

    *,
    ::after,
    ::before,
    ::backdrop,
    ::file-selector-button {
        border-color: var(--color-gray-200, currentColor);
    }
}

[data-flux-field]:not(ui-radio, ui-checkbox) {
    @apply grid gap-2;
}

[data-flux-label] {
    @apply  !mb-0 !leading-tight;
}

input:focus[data-flux-control],
textarea:focus[data-flux-control],
select:focus[data-flux-control] {
    @apply outline-hidden ring-2 ring-accent ring-offset-2 ring-offset-accent-foreground;
}

/* \[:where(&)\]:size-4 {
    @apply size-4;
} */


@layer base {
    .executive-body {
        font-family: 'Inter', 'Segoe UI', sans-serif;
        background: #f7f9fc;
        color: #1f2937;
    }
}

@layer components {
    .executive-frame {
        min-height: 100vh;
        display: grid;
        grid-template-columns: 260px 1fr;
    }

    .executive-sidebar {
        background: #0f2a44;
        color: #e5edf6;
        padding: 26px 18px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }

    .executive-branding {
        display: flex;
        align-items: center;
        gap: 12px;
    }

    .executive-brand-logo {
        width: 44px;
        height: 44px;
        border-radius: 10px;
        object-fit: contain;
        background: #ffffff;
        padding: 4px;
    }

    .executive-brand-subtitle {
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: #98afc5;
    }

    .executive-brand-title {
        font-size: 16px;
        font-weight: 700;
        color: #ffffff;
    }

    .executive-divider {
        margin: 20px 0;
        height: 1px;
        background: rgba(255, 255, 255, 0.15);
    }

    .executive-nav {
        display: grid;
        gap: 6px;
    }

    .executive-nav-item {
        position: relative;
        border-radius: 10px;
        padding: 11px 12px 11px 16px;
        color: #d4deea;
        font-size: 14px;
        font-weight: 500;
        transition: background-color 0.2s ease, color 0.2s ease;
    }

    .executive-nav-item:hover {
        background: rgba(255, 255, 255, 0.08);
        color: #ffffff;
    }

    .executive-nav-item.is-active {
        background: rgba(255, 255, 255, 0.08);
        color: #ffffff;
    }

    .executive-nav-item.is-active::before {
        content: '';
        position: absolute;
        left: 0;
        top: 8px;
        bottom: 8px;
        width: 4px;
        border-radius: 8px;
        background: #f5c400;
    }

    .executive-sidebar-footer {
        font-size: 12px;
        color: #95abc0;
    }

    .executive-main-panel {
        display: flex;
        flex-direction: column;
        min-width: 0;
    }

    .executive-topbar {
        height: 72px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 24px;
        background: #ffffff;
        box-shadow: 0 1px 4px rgba(15, 42, 68, 0.08);
    }

    .executive-page-title {
        font-size: clamp(22px, 2vw, 28px);
        font-weight: 700;
        color: #10253d;
    }

    .executive-toolbar {
        display: flex;
        align-items: center;
        gap: 10px;
    }

    .executive-pill {
        border: 1px solid #d3deea;
        border-radius: 999px;
        padding: 8px 14px;
        background: #f7f9fc;
        font-size: 12px;
        color: #2a4058;
        font-weight: 600;
    }

    .executive-avatar {
        width: 34px;
        height: 34px;
        border-radius: 999px;
        display: grid;
        place-items: center;
        background: #0f2a44;
        color: #ffffff;
        font-size: 13px;
        font-weight: 700;
    }

    .executive-role-badge {
        padding: 6px 10px;
        border-radius: 999px;
        background: #eef3f9;
        color: #0f2a44;
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-weight: 700;
    }

    .executive-mobile-nav {
        display: none;
        padding: 12px 16px;
        gap: 8px;
        overflow-x: auto;
        background: #ffffff;
        border-bottom: 1px solid #d9e2ec;
    }

    .executive-mobile-item {
        border: 1px solid #d9e2ec;
        border-radius: 999px;
        padding: 6px 12px;
        font-size: 12px;
        font-weight: 600;
        color: #2a4058;
        white-space: nowrap;
    }

    .executive-mobile-item.is-active {
        border-color: #0f2a44;
        color: #0f2a44;
        background: #eef3f9;
    }

    .executive-content {
        flex: 1;
        overflow-y: auto;
    }

    .executive-content-inner {
        max-width: 1180px;
        margin: 0 auto;
        padding: 28px 24px 34px;
    }

    .executive-section {
        margin-bottom: 32px;
    }

    .executive-gap-compact {
        margin-bottom: 24px;
    }

    .executive-card {
        background: #ffffff;
        border: 1px solid #e3ebf4;
        border-radius: 12px;
        padding: 22px;
        box-shadow: 0 8px 20px rgba(15, 42, 68, 0.05);
    }

    .executive-kpi-grid {
        display: grid;
        gap: 16px;
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .executive-kpi-card {
        min-height: 130px;
        display: grid;
        align-content: start;
        gap: 8px;
    }

    .executive-kpi-title {
        font-size: 12px;
        color: #66768a;
        font-weight: 600;
    }

    .executive-kpi-value {
        font-size: clamp(28px, 2.2vw, 34px);
        font-weight: 800;
        line-height: 1.15;
        color: #0f2a44;
    }

    .executive-kpi-trend {
        font-size: 13px;
        display: flex;
        align-items: center;
        gap: 6px;
        font-weight: 600;
    }

    .executive-kpi-trend.is-up {
        color: #1f8a48;
    }

    .executive-kpi-trend.is-down {
        color: #c6453a;
    }

    .executive-chart-card {
        min-height: 360px;
    }

    .executive-card-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 16px;
        margin-bottom: 14px;
    }

    .executive-card-title {
        font-size: 18px;
        font-weight: 700;
        color: #10253d;
    }

    .executive-card-subtitle {
        margin-top: 2px;
        font-size: 13px;
        color: #6a7a8f;
    }

    .executive-toggle-group {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .executive-toggle {
        border-radius: 999px;
        border: 1px solid #d3deea;
        background: #ffffff;
        padding: 6px 12px;
        font-size: 12px;
        color: #3b4d63;
        font-weight: 600;
    }

    .executive-toggle.is-active {
        background: #0f2a44;
        border-color: #0f2a44;
        color: #ffffff;
    }

    .executive-info {
        width: 28px;
        height: 28px;
        border-radius: 999px;
        border: 1px solid #d3deea;
        font-size: 12px;
        font-weight: 700;
        color: #0f2a44;
    }

    .executive-line-chart {
        height: 260px;
        border: 1px solid #e3ebf4;
        border-radius: 10px;
        padding: 12px;
        background: #fcfdff;
    }

    .executive-line-chart svg {
        width: 100%;
        height: 210px;
        display: block;
    }

    .executive-axis-labels {
        margin-top: 8px;
        display: flex;
        justify-content: space-between;
        color: #6a7a8f;
        font-size: 12px;
        padding: 0 6px;
    }

    .executive-two-column {
        display: grid;
        gap: 16px;
        grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
    }

    .executive-bar-stack {
        display: grid;
        gap: 14px;
    }

    .executive-bar-row {
        display: grid;
        grid-template-columns: 88px minmax(0, 1fr) 52px;
        align-items: center;
        gap: 10px;
    }

    .executive-bar-label {
        font-size: 13px;
        font-weight: 600;
        color: #364c64;
    }

    .executive-bar-track {
        height: 12px;
        border-radius: 999px;
        background: #edf2f8;
        overflow: hidden;
    }

    .executive-bar-fill {
        height: 100%;
        border-radius: 999px;
    }

    .executive-bar-fill.is-highlight {
        background: linear-gradient(90deg, #2556d8, #3e5cff);
    }

    .executive-bar-fill.is-muted {
        background: linear-gradient(90deg, #758eb0, #90a6c2);
        opacity: 0.72;
    }

    .executive-bar-value {
        font-size: 12px;
        color: #44586f;
        font-weight: 700;
    }

    .executive-insight-list {
        display: grid;
        gap: 10px;
    }

    .executive-mini-insight {
        border: 1px solid #dde6f1;
        border-radius: 10px;
        background: #f9fbfe;
        padding: 14px;
    }

    .executive-mini-insight p {
        font-size: 13px;
        color: #2e445c;
        line-height: 1.5;
    }

    .executive-section-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        margin-bottom: 12px;
    }

    .executive-section-head h3 {
        font-size: 18px;
        font-weight: 700;
        color: #10253d;
    }

    .executive-link-action {
        font-size: 13px;
        color: #2556d8;
        font-weight: 600;
    }

    .executive-signature-grid {
        display: grid;
        gap: 16px;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .executive-signature-card {
        display: grid;
        gap: 12px;
    }

    .executive-signature-card h4 {
        font-size: 17px;
        color: #10253d;
        font-weight: 700;
        line-height: 1.35;
    }

    .executive-signature-card p {
        font-size: 13px;
        color: #5f7288;
    }

    .executive-signature-card a {
        font-size: 13px;
        color: #2556d8;
        font-weight: 600;
    }

    .executive-chip {
        width: fit-content;
        border-radius: 999px;
        background: #eaf2ff;
        color: #1b4dc8;
        font-size: 11px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        padding: 5px 10px;
    }

    .executive-chip.is-warning {
        background: #fff3dd;
        color: #8b5a06;
    }

    .executive-chip.is-growth {
        background: #e4f8ee;
        color: #1f7e4b;
    }

    .executive-forecast-kpi-grid {
        display: grid;
        gap: 16px;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .executive-forecast-kpi {
        min-height: 130px;
    }

    .executive-callout {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        background: linear-gradient(130deg, #0f2a44, #1e456d);
        color: #ffffff;
    }

    .executive-callout p {
        font-size: 18px;
        font-weight: 600;
        max-width: 700px;
    }

    .executive-callout .executive-link-action {
        color: #f6c316;
    }

    .executive-prototype-flow {
        display: flex;
        justify-content: flex-end;
    }

    .executive-table-wrap {
        overflow-x: auto;
        border-radius: 10px;
        border: 1px solid #d9e2ec;
    }

    .executive-table {
        width: 100%;
        border-collapse: collapse;
        min-width: 560px;
    }

    .executive-table th,
    .executive-table td {
        padding: 12px 14px;
        text-align: left;
        font-size: 13px;
        border-bottom: 1px solid #edf2f7;
    }

    .executive-table th {
        color: #5f7288;
        font-weight: 700;
        background: #f7f9fc;
    }

    .executive-table td {
        color: #24384f;
        font-weight: 500;
    }

    .executive-positive {
        color: #1f8a48;
        font-weight: 700;
    }

    .executive-health-list {
        margin-top: 14px;
        display: grid;
        gap: 12px;
    }

    .executive-health-list div {
        display: flex;
        justify-content: space-between;
        align-items: center;
        border-radius: 10px;
        border: 1px solid #dde6f1;
        background: #f9fbfe;
        padding: 12px 14px;
    }

    .executive-health-list span {
        color: #5f7288;
        font-size: 13px;
    }

    .executive-health-list strong {
        color: #0f2a44;
        font-size: 13px;
        font-weight: 700;
    }

    .executive-analytics-grid {
        display: grid;
        gap: 16px;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .executive-analytics-card {
        display: grid;
        gap: 12px;
    }

    .executive-sparkline {
        height: 48px;
        display: grid;
        align-items: end;
        grid-template-columns: repeat(6, minmax(0, 1fr));
        gap: 5px;
    }

    .executive-sparkline span {
        border-radius: 8px 8px 3px 3px;
        background: linear-gradient(180deg, #5a79d6, #8da2d5);
    }

    .executive-sparkline span:nth-child(1) { height: 40%; }
    .executive-sparkline span:nth-child(2) { height: 58%; }
    .executive-sparkline span:nth-child(3) { height: 51%; }
    .executive-sparkline span:nth-child(4) { height: 72%; }
    .executive-sparkline span:nth-child(5) { height: 78%; }
    .executive-sparkline span:nth-child(6) { height: 88%; }

    .executive-governance-grid {
        display: grid;
        gap: 16px;
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .executive-governance-card {
        display: grid;
        gap: 12px;
        min-height: 170px;
    }

    .executive-governance-value {
        font-size: 25px;
        font-weight: 700;
        color: #10253d;
        line-height: 1.25;
    }

    .executive-status-pill {
        width: fit-content;
        border-radius: 999px;
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-weight: 700;
        padding: 6px 10px;
    }

    .executive-status-pill.is-ok {
        background: #e4f8ee;
        color: #1f7e4b;
    }

    .executive-status-pill.is-info {
        background: #eaf2ff;
        color: #1b4dc8;
    }

    .executive-login-body {
        min-height: 100vh;
        background:
            radial-gradient(circle at 20% 20%, rgba(245, 196, 0, 0.18) 0, rgba(245, 196, 0, 0) 42%),
            linear-gradient(135deg, #0f2a44, #1a4569 50%, #27567f);
    }

    .executive-login-shell {
        min-height: 100vh;
        display: grid;
        place-items: center;
        padding: 24px;
    }

    .executive-login-panel {
        width: 100%;
        max-width: 460px;
        border-radius: 16px;
        background: rgba(255, 255, 255, 0.98);
        box-shadow: 0 22px 40px rgba(5, 24, 43, 0.3);
        padding: 30px;
        display: grid;
        gap: 16px;
    }

    .executive-login-brand p {
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.1em;
        color: #607089;
        font-weight: 700;
    }

    .executive-login-brand h1 {
        font-size: 24px;
        color: #10253d;
        font-weight: 800;
    }

    .executive-login-panel h2 {
        font-size: 28px;
        color: #10253d;
        font-weight: 700;
    }

    .executive-login-copy {
        font-size: 14px;
        color: #5f7288;
    }

    .executive-login-action {
        display: block;
        border-radius: 10px;
        background: #0f2a44;
        color: #ffffff;
        text-align: center;
        padding: 12px;
        font-size: 14px;
        font-weight: 600;
    }

    .executive-login-points {
        list-style: disc;
        padding-left: 18px;
        color: #3e526a;
        font-size: 13px;
        display: grid;
        gap: 6px;
    }
}

@media (max-width: 1280px) {
    .executive-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .executive-signature-grid,
    .executive-governance-grid,
    .executive-analytics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1024px) {
    .executive-frame {
        grid-template-columns: 1fr;
    }

    .executive-sidebar {
        display: none;
    }

    .executive-mobile-nav {
        display: flex;
    }

    .executive-topbar {
        padding-inline: 16px;
        height: auto;
        min-height: 72px;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        gap: 8px;
        padding-block: 10px;
    }

    .executive-toolbar {
        width: 100%;
        overflow-x: auto;
    }

    .executive-two-column {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .executive-content-inner {
        padding-inline: 14px;
    }

    .executive-kpi-grid,
    .executive-forecast-kpi-grid,
    .executive-signature-grid,
    .executive-governance-grid,
    .executive-analytics-grid {
        grid-template-columns: 1fr;
    }

    .executive-card {
        padding: 18px;
    }

    .executive-callout {
        flex-direction: column;
        align-items: flex-start;
    }
}


