/* Vazirmatn - self-hosted */
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-arabic-300-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-arabic-300-normal.woff') format('woff'); unicode-range: U+0600-06FF, U+0750-077F, U+FB50-FDFF, U+FE70-FEFF; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-latin-300-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-latin-300-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-arabic-400-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-arabic-400-normal.woff') format('woff'); unicode-range: U+0600-06FF, U+0750-077F, U+FB50-FDFF, U+FE70-FEFF; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-latin-400-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-latin-400-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 500; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-arabic-500-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-arabic-500-normal.woff') format('woff'); unicode-range: U+0600-06FF, U+0750-077F, U+FB50-FDFF, U+FE70-FEFF; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 500; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-latin-500-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-latin-500-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-arabic-600-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-arabic-600-normal.woff') format('woff'); unicode-range: U+0600-06FF, U+0750-077F, U+FB50-FDFF, U+FE70-FEFF; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-latin-600-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-latin-600-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-arabic-700-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-arabic-700-normal.woff') format('woff'); unicode-range: U+0600-06FF, U+0750-077F, U+FB50-FDFF, U+FE70-FEFF; }
@font-face { font-family: 'Vazirmatn'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/vazirmatn/vazirmatn-latin-700-normal.woff2') format('woff2'), url('/fonts/vazirmatn/vazirmatn-latin-700-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/* Inter - self-hosted */
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/inter/inter-latin-300-normal.woff2') format('woff2'), url('/fonts/inter/inter-latin-300-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/inter/inter-latin-400-normal.woff2') format('woff2'), url('/fonts/inter/inter-latin-400-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 500; font-display: swap; src: url('/fonts/inter/inter-latin-500-normal.woff2') format('woff2'), url('/fonts/inter/inter-latin-500-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/inter/inter-latin-600-normal.woff2') format('woff2'), url('/fonts/inter/inter-latin-600-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/inter/inter-latin-700-normal.woff2') format('woff2'), url('/fonts/inter/inter-latin-700-normal.woff') format('woff'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

:root {
    --bg: #07111a;
    --surface: rgba(10, 27, 40, 0.76);
    --surface-2: rgba(255, 255, 255, 0.075);
    --surface-3: rgba(255, 255, 255, 0.13);
    --border: rgba(139, 177, 203, 0.18);
    --text: #edf6fc;
    --muted: #b6cad9;
    --accent: #e4b45f;
    --accent-2: #34c9b0;
    --accent-3: #6eb5ff;
    --danger: #ef7a8f;
    --success: #6ce0a8;
    --warning: #f0bf68;
    --info: #7ebdff;
    --radius: 16px;
    --shadow: 0 22px 46px rgba(0, 0, 0, 0.3);
    --shell-sidebar-bg: linear-gradient(180deg, #091723 0%, #10273a 55%, #14314a 100%);
    --shell-border: rgba(139, 177, 203, 0.16);
    --header-bg: rgba(7, 17, 26, 0.82);
    --header-kicker: #a7bed1;
    --header-title: #ffffff;
    --header-link: #e4b45f;
    --header-link-hover: #f0c982;
    --sidebar-text: #edf6fc;
    --sidebar-group: #a3bed3;
    --sidebar-link: #edf6fc;
    --sidebar-link-hover-bg: rgba(255, 255, 255, 0.09);
    --sidebar-link-hover: #ffffff;
    --sidebar-link-active-bg: linear-gradient(135deg, #173448, #113f48 70%, #0d4c59 100%);
    --sidebar-link-active: #f8fbff;
    --brand-text: #ffffff;
    --menu-btn-border: rgba(139, 177, 203, 0.25);
    --menu-btn-line: #ffffff;
    --input-bg: rgba(255, 255, 255, 0.08);
    --input-text: #ffffff;
    --placeholder: #c2d3df;
    --modal-bg: #13293b;
    --dropdown-bg: #13293b;
    --table-head: #f6fbff;
    --table-line: rgba(255, 255, 255, 0.1);
}

html[data-theme="light"] {
    --bg: #edf2f7;
    --surface: rgba(255, 255, 255, 0.9);
    --surface-2: rgba(16, 39, 58, 0.05);
    --surface-3: rgba(16, 39, 58, 0.09);
    --border: rgba(19, 39, 58, 0.14);
    --text: #13283b;
    --muted: #60788b;
    --accent: #a9731f;
    --accent-2: #1e9d89;
    --accent-3: #3b7fd3;
    --success: #1f9a68;
    --warning: #c68c28;
    --info: #3675c9;
    --shadow: 0 18px 36px rgba(8, 23, 36, 0.1);
    --shell-sidebar-bg: linear-gradient(180deg, #f7fafc 0%, #e9f0f7 100%);
    --shell-border: rgba(19, 39, 58, 0.12);
    --header-bg: rgba(247, 250, 252, 0.88);
    --header-kicker: #5d7688;
    --header-title: #143049;
    --header-link: #8b641d;
    --header-link-hover: #68490f;
    --sidebar-text: #153046;
    --sidebar-group: #627c91;
    --sidebar-link: #173147;
    --sidebar-link-hover-bg: rgba(22, 51, 74, 0.06);
    --sidebar-link-hover: #10273a;
    --sidebar-link-active-bg: linear-gradient(135deg, #10344b, #14505a 90%);
    --sidebar-link-active: #f8fbff;
    --brand-text: #13283b;
    --menu-btn-border: rgba(19, 39, 58, 0.18);
    --menu-btn-line: #13283b;
    --input-bg: #ffffff;
    --input-text: #163046;
    --placeholder: #8098aa;
    --modal-bg: #f7fbff;
    --dropdown-bg: #ffffff;
    --table-head: #122d43;
    --table-line: rgba(19, 39, 58, 0.12);
}

html,
body {
    min-height: 100%;
    font-family: 'Vazirmatn', Tahoma, Arial, sans-serif;
    font-size: 14px;
    background: radial-gradient(circle at 10% -5%, #25445f 0%, transparent 40%),
        radial-gradient(circle at 88% 8%, #144a54 0%, transparent 32%),
        linear-gradient(160deg, var(--bg) 0%, #0b1a29 58%, #0d2232 100%);
    color: var(--text);
}

html[dir="rtl"],
html[dir="rtl"] body {
    direction: rtl;
    font-family: 'Vazirmatn', Tahoma, Arial, sans-serif;
}

html[dir="ltr"],
html[dir="ltr"] body {
    direction: ltr;
    font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
}

html[data-theme="light"],
html[data-theme="light"] body {
    background: radial-gradient(circle at 10% -5%, #dce8f4 0%, transparent 35%),
        radial-gradient(circle at 88% 10%, #deefe7 0%, transparent 30%),
        linear-gradient(160deg, #edf3f9 0%, #f8fbff 70%, #eef5fb 100%);
}

body {
    margin: 0;
    background-attachment: fixed;
}

html:not([data-theme="light"]) {
    --bs-body-color: var(--text);
    --bs-body-color-rgb: 237, 246, 252;
    --bs-secondary-color: var(--muted);
    --bs-secondary-color-rgb: 182, 202, 217;
    --bs-tertiary-color: #9db6c7;
    --bs-tertiary-color-rgb: 157, 182, 199;
    --bs-emphasis-color: #f6fbff;
    --bs-emphasis-color-rgb: 246, 251, 255;
    --bs-heading-color: #f6fbff;
    --bs-border-color: var(--border);
    --bs-border-color-translucent: rgba(255, 255, 255, 0.1);
}

html:not([data-theme="light"]) .text-muted,
html:not([data-theme="light"]) .text-secondary,
html:not([data-theme="light"]) .text-body-secondary {
    color: var(--muted) !important;
}

html:not([data-theme="light"]) .text-dark,
html:not([data-theme="light"]) .text-black,
html:not([data-theme="light"]) .link-dark {
    color: var(--text) !important;
}

html:not([data-theme="light"]) .bg-light,
html:not([data-theme="light"]) .bg-white,
html:not([data-theme="light"]) .card,
html:not([data-theme="light"]) .card.bg-light,
html:not([data-theme="light"]) .list-group-item,
html:not([data-theme="light"]) .dropdown-menu {
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 7%), var(--surface)) !important;
    color: var(--text) !important;
    border-color: var(--border) !important;
}

html:not([data-theme="light"]) .list-group-item-action {
    color: var(--text) !important;
}

html:not([data-theme="light"]) .list-group-item-action:hover,
html:not([data-theme="light"]) .list-group-item-action:focus,
html:not([data-theme="light"]) .dropdown-item:hover,
html:not([data-theme="light"]) .dropdown-item:focus {
    background: color-mix(in srgb, var(--accent-2), transparent 84%) !important;
    color: var(--text) !important;
}

html:not([data-theme="light"]) .list-group-item-warning {
    background: rgba(240, 191, 104, 0.14) !important;
    color: var(--text) !important;
}

html:not([data-theme="light"]) .dropdown-item,
html:not([data-theme="light"]) .page-link {
    color: var(--text) !important;
}

html:not([data-theme="light"]) .page-link {
    background: color-mix(in srgb, var(--surface), #ffffff 7%);
    border-color: var(--border);
}

html:not([data-theme="light"]) .page-link:hover,
html:not([data-theme="light"]) .page-link:focus {
    background: color-mix(in srgb, var(--surface-2), transparent 2%);
    border-color: color-mix(in srgb, var(--accent-3), transparent 55%);
}

html:not([data-theme="light"]) .table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text);
    --bs-table-striped-bg: color-mix(in srgb, var(--surface), #ffffff 10%);
    --bs-table-striped-color: var(--text);
    --bs-table-active-bg: color-mix(in srgb, var(--surface-2), transparent 2%);
    --bs-table-active-color: var(--text);
    --bs-table-hover-bg: color-mix(in srgb, var(--accent-2), transparent 30%);
    --bs-table-hover-color: var(--text);
    --bs-table-border-color: var(--table-line);
}

html:not([data-theme="light"]) .table > :not(caption) > * > * {
    color: inherit !important;
    background-color: var(--bs-table-bg) !important;
    border-bottom-color: var(--table-line) !important;
    box-shadow: none !important;
}

html:not([data-theme="light"]) .table-light {
    --bs-table-bg: color-mix(in srgb, var(--surface-2), transparent 4%);
    --bs-table-striped-bg: color-mix(in srgb, var(--surface-2), #ffffff 3%);
    --bs-table-color: var(--table-head);
    --bs-table-border-color: var(--table-line);
}

html:not([data-theme="light"]) .table > :not(caption) > .table-light > * {
    color: var(--table-head) !important;
    border-bottom-color: var(--table-line) !important;
}

html:not([data-theme="light"]) .table-secondary {
    --bs-table-bg: color-mix(in srgb, var(--surface-2), transparent 2%);
    --bs-table-striped-bg: color-mix(in srgb, var(--surface-2), #ffffff 4%);
    --bs-table-color: var(--text);
    --bs-table-border-color: var(--table-line);
}

html:not([data-theme="light"]) .table > :not(caption) > .table-secondary > * {
    color: var(--text) !important;
    border-bottom-color: var(--table-line) !important;
}

a {
    color: var(--accent);
}

a:hover {
    color: color-mix(in srgb, var(--accent), #ffffff 20%);
}

.page-shell {
    animation: fade-up 0.3s ease;
}

.dashboard-hero {
    position: relative;
    overflow: hidden;
    padding: 1.35rem;
    border-radius: calc(var(--radius) + 10px);
    border: 1px solid color-mix(in srgb, var(--border), #ffffff 8%);
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--accent), transparent 78%), transparent 34%),
        radial-gradient(circle at 85% 18%, color-mix(in srgb, var(--accent-2), transparent 76%), transparent 26%),
        linear-gradient(145deg, rgba(7, 19, 29, 0.94), rgba(15, 38, 54, 0.88));
    box-shadow: var(--shadow);
    margin-bottom: 1.2rem;
}

html[data-theme="light"] .dashboard-hero {
    background:
        radial-gradient(circle at top left, rgba(255, 201, 120, 0.28), transparent 34%),
        radial-gradient(circle at 85% 18%, rgba(57, 198, 176, 0.2), transparent 26%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(238, 246, 252, 0.96));
}

.hero-grid {
    display: grid;
    gap: 1rem;
}

.hero-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff5df;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

html[data-theme="light"] .hero-kicker {
    background: rgba(19, 39, 58, 0.06);
    color: #8f5f12;
}

.hero-title {
    margin: 0.9rem 0 0.35rem;
    font-size: clamp(1.8rem, 4vw, 3rem);
    line-height: 1.15;
    font-weight: 900;
}

.hero-copy {
    max-width: 62ch;
    margin: 0;
    color: color-mix(in srgb, var(--text), transparent 18%);
    font-size: 1rem;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 1.2rem;
}

.hero-panel {
    display: grid;
    gap: 0.75rem;
    align-content: start;
}

.glow-card {
    border: 1px solid color-mix(in srgb, var(--border), #ffffff 8%);
    border-radius: 18px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface-3), transparent 12%), color-mix(in srgb, var(--surface), transparent 6%));
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow);
}

.glow-card-body {
    padding: 1rem;
}

.hero-mini-stat {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.hero-mini-stat strong {
    font-size: 1.25rem;
}

.hero-mini-stat span,
.eyebrow {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.action-grid,
.feature-grid,
.split-grid {
    display: grid;
    gap: 1rem;
}

.action-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding: 1.1rem;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 6%), var(--surface));
    color: var(--text);
    text-decoration: none;
    box-shadow: var(--shadow);
    transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.action-card:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--accent-2), #ffffff 12%);
    color: var(--text);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
}

.action-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, color-mix(in srgb, var(--accent), #ffffff 6%), color-mix(in srgb, var(--accent-2), transparent 26%));
    color: #0b1520;
    font-size: 1.25rem;
    font-weight: 900;
}

.action-card h3,
.feature-card h3 {
    margin: 0;
    font-size: 1.08rem;
    font-weight: 800;
}

.action-card p,
.feature-card p,
.metric-copy,
.list-card p {
    margin: 0;
    color: var(--muted);
}

.action-link {
    color: var(--accent);
    font-size: 0.9rem;
    font-weight: 800;
}

.feature-card,
.list-card,
.section-card {
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 2px);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 7%), var(--surface));
    box-shadow: var(--shadow);
}

.feature-card {
    padding: 1.1rem;
}

.feature-list {
    margin: 0.85rem 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.55rem;
}

.feature-list li {
    padding: 0.7rem 0.85rem;
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface-2), transparent 8%);
    color: var(--text);
}

.panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.8rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.panel-head h3,
.panel-head h4,
.panel-head h5 {
    margin: 0.2rem 0 0;
    font-weight: 800;
}

.metric-grid {
    display: grid;
    gap: 0.9rem;
    margin-bottom: 1.2rem;
}

.metric-card {
    position: relative;
    overflow: hidden;
    padding: 1rem;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 6%), color-mix(in srgb, var(--surface-2), transparent 5%));
    box-shadow: var(--shadow);
}

.metric-card::after {
    content: "";
    position: absolute;
    inset: auto -10% -55% auto;
    width: 7rem;
    height: 7rem;
    border-radius: 999px;
    background: radial-gradient(circle, color-mix(in srgb, var(--accent-3), transparent 45%), transparent 70%);
    pointer-events: none;
}

.metric-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent-2), var(--accent), transparent);
    opacity: 0.95;
}

.metric-label {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.metric-value {
    margin: 0.35rem 0 0;
    font-size: clamp(1.35rem, 3vw, 2.1rem);
    font-weight: 900;
}

.metric-copy {
    margin-top: 0.45rem;
    font-size: 0.88rem;
}

.badge-soft {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.32rem 0.65rem;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 800;
    border: 1px solid transparent;
}

.badge-soft.success {
    color: #8bf0bc;
    background: rgba(33, 121, 77, 0.22);
    border-color: rgba(100, 216, 156, 0.22);
}

.badge-soft.neutral {
    color: #dfeafb;
    background: rgba(255, 255, 255, 0.09);
    border-color: rgba(255, 255, 255, 0.1);
}

.badge-soft.warning {
    color: #ffe3a5;
    background: rgba(178, 117, 24, 0.2);
    border-color: rgba(255, 201, 120, 0.18);
}

.badge-soft.info {
    color: #b9dbff;
    background: rgba(71, 129, 219, 0.18);
    border-color: rgba(110, 181, 255, 0.18);
}

html[data-theme="light"] .badge-soft.success {
    color: #157a4f;
    background: rgba(36, 138, 124, 0.12);
    border-color: rgba(36, 138, 124, 0.18);
}

html[data-theme="light"] .badge-soft.neutral {
    color: #284459;
    background: rgba(19, 39, 58, 0.06);
    border-color: rgba(19, 39, 58, 0.08);
}

html[data-theme="light"] .badge-soft.warning {
    color: #9b6611;
    background: rgba(255, 201, 120, 0.2);
    border-color: rgba(181, 119, 24, 0.18);
}

html[data-theme="light"] .badge-soft.info {
    color: #2d6ebc;
    background: rgba(59, 127, 211, 0.12);
    border-color: rgba(59, 127, 211, 0.18);
}

.ops-table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text);
    --bs-table-border-color: var(--table-line);
    --bs-table-hover-color: var(--text);
    --bs-table-hover-bg: color-mix(in srgb, var(--surface-2), transparent 2%);
    margin-bottom: 0;
}

.ops-table > :not(caption) > * > * {
    color: var(--text);
    border-bottom-color: var(--table-line);
    background-color: transparent;
}

.ops-table thead th {
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface-3), transparent 10%), color-mix(in srgb, var(--surface-2), transparent 8%));
    color: var(--table-head);
    border-bottom-color: var(--table-line);
}

.ops-status {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.78rem;
    font-weight: 800;
    white-space: nowrap;
}

.ops-status::before {
    content: "";
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 12px currentColor;
}

.ops-status.idle {
    color: var(--muted);
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.08);
}

.ops-status.live {
    color: var(--success);
    background: rgba(41, 146, 101, 0.16);
    border-color: rgba(108, 224, 168, 0.18);
}

.ops-status.closed {
    color: var(--warning);
    background: rgba(191, 138, 46, 0.15);
    border-color: rgba(240, 191, 104, 0.18);
}

html[data-theme="light"] .ops-status.idle {
    background: rgba(19, 39, 58, 0.05);
    border-color: rgba(19, 39, 58, 0.08);
}

html[data-theme="light"] .ops-status.live {
    background: rgba(31, 154, 104, 0.1);
    border-color: rgba(31, 154, 104, 0.16);
}

html[data-theme="light"] .ops-status.closed {
    background: rgba(198, 140, 40, 0.1);
    border-color: rgba(198, 140, 40, 0.16);
}

.ops-name {
    display: grid;
    gap: 0.15rem;
}

.ops-name small {
    color: var(--muted);
    font-size: 0.78rem;
}

.ops-price {
    display: inline-flex;
    flex-direction: column;
    gap: 0.15rem;
}

.ops-price small {
    color: var(--muted);
}

.ops-invoice {
    border: 1px solid var(--border);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 6%), color-mix(in srgb, var(--surface-2), transparent 4%));
}

.ops-invoice-total {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.7rem 0.95rem;
    border-radius: 14px;
    background: rgba(41, 146, 101, 0.14);
    color: #bdf5d6;
    font-weight: 900;
}

html[data-theme="light"] .ops-invoice-total {
    background: rgba(31, 154, 104, 0.12);
    color: #17704d;
}

.toolbar-shell {
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 2px);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 8%), var(--surface));
    box-shadow: var(--shadow);
    margin-bottom: 1rem;
}

.search-field {
    position: relative;
}

.search-field .form-control {
    min-height: 3rem;
    padding-inline: 1rem 3rem;
}

.search-icon {
    position: absolute;
    top: 50%;
    inset-inline-end: 1rem;
    transform: translateY(-50%);
    color: var(--muted);
    pointer-events: none;
}

.mini-stats {
    display: grid;
    gap: 0.75rem;
    margin-top: 1rem;
}

.mini-stat {
    padding: 0.8rem 0.9rem;
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-2), transparent 5%);
    border: 1px solid color-mix(in srgb, var(--border), transparent 8%);
}

.mini-stat strong {
    display: block;
    margin-top: 0.25rem;
    font-size: 1.15rem;
}

.section-stack {
    display: grid;
    gap: 1rem;
}

.table-header-note {
    color: var(--muted);
    font-size: 0.85rem;
}

.table td strong {
    font-weight: 800;
}

.page-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.8rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.page-head h2,
.page-head h3,
.page-head h1 {
    margin: 0;
    font-weight: 800;
}

.page-subtitle {
    margin: 0.3rem 0 0;
    color: var(--muted);
    font-size: 0.95rem;
}

.panel {
    border: 1px solid var(--border);
    background: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.panel-body {
    padding: 1rem;
}

.toolbar {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.table-wrap {
    overflow-x: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
}

.table {
    margin: 0;
    color: var(--text);
}

.table thead th {
    background: var(--surface-2);
    color: var(--table-head);
    border-bottom: 0;
    font-weight: 700;
    white-space: nowrap;
}

.table td,
.table th {
    border-color: var(--table-line);
    vertical-align: middle;
}

.table-hover tbody tr:hover td {
    background: color-mix(in srgb, var(--accent-2), transparent 30%);
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
    background: color-mix(in srgb, var(--surface), #ffffff 10%);
    color: var(--text);
}

.stat-grid {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 1rem;
}

.stat-card {
    padding: 0.85rem;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: var(--surface);
}

.stat-card p {
    margin: 0;
    color: var(--muted);
    font-size: 0.85rem;
}

.stat-card h4 {
    margin: 0.2rem 0 0;
    font-size: 1.2rem;
    font-weight: 800;
}

.btn {
    border-radius: 11px;
    font-weight: 700;
}

.btn-primary {
    border-color: #2aa18f;
    background: linear-gradient(135deg, #3ac8b1, #299a8a);
    color: #031410;
}

.btn-primary:hover {
    border-color: #2eb29f;
    background: linear-gradient(135deg, #52dbc5, #31a998);
    color: #031410;
}

.btn-success {
    border-color: #67bc66;
    background: linear-gradient(135deg, #83d57f, #5cb45c);
    color: #102010;
}

.btn-warning {
    border-color: #edb04f;
    background: linear-gradient(135deg, #ffcf7f, #efb252);
    color: #2f1c00;
}

.btn-danger {
    border-color: #ec7886;
    background: linear-gradient(135deg, #f49da8, #ec7886);
}

.btn-secondary {
    border-color: #3e4f5f;
    background: #2a3a4a;
}

html[data-theme="light"] .btn-secondary {
    border-color: #bfd0df;
    background: #e8eff6;
    color: #1a3650;
}

.form-control,
.form-select,
.form-control:focus,
.form-select:focus {
    border: 1px solid var(--border);
    background: var(--input-bg);
    color: var(--input-text);
    border-radius: 11px;
    box-shadow: none;
}

.form-control::placeholder {
    color: var(--placeholder);
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(57, 198, 176, 0.8);
}

.form-label {
    color: color-mix(in srgb, var(--text), #ffffff 10%);
    font-size: 0.86rem;
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.form-grid {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: minmax(0, 1fr);
}

.form-grid.cols-2 {
    grid-template-columns: minmax(0, 1fr);
}

.form-field {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.form-field .form-control,
.form-field .form-select {
    margin-bottom: 0;
    min-height: 2.8rem;
}

.form-hint {
    color: var(--muted);
    font-size: 0.78rem;
    margin-top: 0.1rem;
}

.full-span {
    grid-column: 1 / -1;
}

.form-actions {
    display: flex;
    justify-content: flex-start;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.form-card {
    border: 1px solid var(--border);
    background: var(--surface);
    border-radius: 14px;
    padding: 0.9rem;
}

.modal-content {
    border-radius: 16px;
    background: var(--modal-bg);
    border: 1px solid var(--border);
    color: var(--text);
}

.modal-header,
.modal-footer {
    border-color: var(--border);
}

.modal-header .btn-close {
    margin: 0;
    margin-right: auto;
}

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: transparent;
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    color: var(--placeholder);
    text-align: start;
}

.form-floating > label {
    color: var(--muted);
}

.form-floating > label::after {
    background: var(--input-bg) !important;
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-control-plaintext ~ label {
    color: var(--text);
}

.user-list-dropdown {
    position: absolute;
    background: var(--dropdown-bg);
    border: 1px solid var(--border);
    border-radius: 12px;
    max-height: 180px;
    overflow-y: auto;
    width: calc(100% - 2px);
    z-index: 1000;
}

.user-list-dropdown ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.user-list-dropdown li,
.user-list-dropdown span {
    padding: 8px 12px;
}

.user-list-dropdown li:hover {
    background: color-mix(in srgb, var(--accent-2), transparent 85%);
}

.alert {
    border-radius: 12px;
}

.empty-state {
    color: var(--muted);
    text-align: center;
    padding: 1rem;
}

.gc-pagination-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    flex-wrap: wrap;
}

.gc-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.4rem 0.55rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--surface), #ffffff 8%);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

.gc-page-btn,
.gc-page-nav {
    width: 2.15rem;
    height: 2.15rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    transition: all 0.2s ease;
}

.gc-page-nav {
    font-size: 1.05rem;
    font-weight: 900;
}

.gc-page-btn:hover:not(:disabled),
.gc-page-nav:hover:not(:disabled) {
    background: color-mix(in srgb, var(--accent-2), transparent 80%);
    color: var(--text);
}

.gc-page-btn.active {
    background: linear-gradient(135deg, var(--accent-3), var(--accent-2));
    color: #fff;
    box-shadow: 0 8px 18px rgba(26, 122, 170, 0.35);
}

.gc-page-btn:disabled,
.gc-page-nav:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.login-card {
    max-width: 460px;
    margin: 2rem auto;
}

@media (min-width: 760px) {
    .action-grid,
    .feature-grid,
    .metric-grid,
    .mini-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .split-grid,
    .hero-grid {
        grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.85fr);
    }
}

@media (min-width: 980px) {
    .stat-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .form-grid.cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .action-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .feature-grid,
    .metric-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .mini-stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@keyframes fade-up {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

input[type="email"],
input[type="password"] {
    direction: ltr;
    text-align: left;
}

.side-link {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.82rem 1.15rem;
    margin: 0.18rem 0.65rem;
    border-radius: 14px;
    color: var(--sidebar-link);
    text-decoration: none;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.side-link:hover {
    background: var(--sidebar-link-hover-bg);
    color: var(--sidebar-link-hover);
    padding-right: 1.35rem;
}

.side-link.active {
    background: var(--sidebar-link-active-bg);
    color: var(--sidebar-link-active);
    font-weight: 700;
    box-shadow: 0 6px 16px -2px rgba(255, 201, 116, 0.3);
}

.side-group {
    margin: 1.2rem 0 0.4rem 1.1rem;
    color: var(--sidebar-group);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.side-account {
    margin: 1.5rem 0.8rem 0.8rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

.side-link.active {
    background: linear-gradient(135deg, #ffc974, #ffeb9f) !important;
    color: #1f1200 !important;
}

.side-nav {
    padding: 0.6rem 0;
}

/* =========================
   SAFE SELECT FIX (NO SIDE EFFECTS)
   ========================= */

select,
.form-select {
    color: var(--input-text) !important;
    background-color: var(--input-bg) !important;
}

/* جلوگیری از سفید شدن متن داخل select */
select option {
    color: #000;
    background: #fff;
}

/* dark mode */
html:not([data-theme="light"]) select option {
    color: #fff;
    background: #122638;
}

/* fix focus فقط برای select */
select:focus,
.form-select:focus {
    color: var(--input-text) !important;
    background-color: var(--input-bg) !important;
}

/* ستاره قرمز برای فیلدهای اجباری */
.form-label.required::after {
    content: " *";
    color: #dc3545;        /* رنگ قرمز Bootstrap */
    font-weight: bold;
}

.form-label.required {
    font-weight: 500;      /* اختیاری - کمی بولدتر کنه */
}

.form-control {
    color: var(--input-text) !important;
    background-color: var(--input-bg) !important;
}

/* ═══════════════════════════════════════════════════════
   LANDING PAGE STYLES
   ═══════════════════════════════════════════════════════ */

/* ── Navbar ── */
.lp-nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(7, 17, 26, 0.88);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(139, 177, 203, 0.14);
}

.lp-nav-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0.9rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.lp-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    color: #fff;
}

.lp-brand-logo {
    width: 2rem;
    height: 2rem;
    border-radius: 0.55rem;
    object-fit: contain;
}

.lp-brand-name {
    font-size: 1.25rem;
    font-weight: 900;
    color: #fff;
}

.gc-navbar-logo {
    width: 2rem;
    height: 2rem;
    border-radius: 0.5rem;
    object-fit: contain;
}

/* ── Plan Tier Badge (landing + subscription page) ── */
.lp-pc__tier-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.65rem;
}

.lp-pc__tier-img {
    width: 3rem;
    height: 3.5rem;
    object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.25));
    transition: transform 0.2s ease;
}

.lp-pc:hover .lp-pc__tier-img {
    transform: scale(1.08) translateY(-2px);
}

.lp-pc__tier-label {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    opacity: 0.72;
}

/* Tier label colors */
.lp-pc__tier-label.tier-bronze { color: #CD7F32; }
.lp-pc__tier-label.tier-silver { color: #A8A8A8; }
.lp-pc__tier-label.tier-gold   { color: #FFB800; }

/* dashboard plan card tier badge */
.plan-tier-badge {
    width: 2.6rem;
    height: 3rem;
    object-fit: contain;
    filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.2));
    transition: transform 0.2s ease;
}

.plan-tier-badge:hover {
    transform: scale(1.1) translateY(-2px);
}

.plan-tier-label {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    opacity: 0.75;
    color: var(--accent-1, #FFB800);
}

.lp-nav-links {
    display: none;
    align-items: center;
    gap: 0.4rem;
}

.lp-nav-link {
    padding: 0.45rem 0.8rem;
    border-radius: 10px;
    color: rgba(237, 246, 252, 0.8);
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: 600;
    transition: color 0.2s, background 0.2s;
}

.lp-nav-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
}

.lp-nav-cta {
    padding: 0.48rem 1.1rem;
    border-radius: 10px;
    background: linear-gradient(135deg, #3ac8b1, #299a8a);
    color: #031410;
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: 800;
    transition: opacity 0.2s, transform 0.2s;
    white-space: nowrap;
}

.lp-nav-cta:hover {
    opacity: 0.88;
    transform: translateY(-1px);
    color: #031410;
}

.lp-hamburger {
    display: flex;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: 1px solid rgba(139, 177, 203, 0.25);
    border-radius: 10px;
    padding: 0.5rem 0.6rem;
    cursor: pointer;
}

.lp-hamburger span {
    display: block;
    width: 22px;
    height: 2px;
    background: #fff;
    border-radius: 2px;
}

/* Mobile nav open state */
.lp-nav.open .lp-nav-links {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    inset-inline: 0;
    background: rgba(7, 17, 26, 0.97);
    padding: 1rem;
    gap: 0.3rem;
    border-bottom: 1px solid rgba(139, 177, 203, 0.14);
}

/* ── Layout helpers ── */
.lp-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.25rem;
}

/* ── Section ── */
.lp-section {
    padding: 5rem 0;
}

.lp-section-alt {
    background: rgba(255, 255, 255, 0.025);
}

.lp-section-head {
    text-align: center;
    margin-bottom: 3rem;
}

.lp-eyebrow {
    display: inline-block;
    padding: 0.3rem 0.85rem;
    border-radius: 999px;
    background: rgba(52, 201, 176, 0.15);
    color: var(--accent-2);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    margin-bottom: 0.85rem;
}

.lp-section-title {
    margin: 0 0 0.65rem;
    font-size: clamp(1.7rem, 3.5vw, 2.5rem);
    font-weight: 900;
    line-height: 1.2;
}

.lp-section-sub {
    margin: 0 auto;
    max-width: 52ch;
    color: var(--muted);
    font-size: 1rem;
}

/* ── Hero ── */
.lp-hero {
    position: relative;
    overflow: hidden;
    padding: 6rem 0 5rem;
    text-align: center;
}

.lp-hero-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(80px);
    opacity: 0.35;
}

.lp-orb-1 {
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, #34c9b0, transparent 70%);
    top: -200px;
    left: -100px;
}

.lp-orb-2 {
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, #e4b45f, transparent 70%);
    bottom: -150px;
    right: -80px;
}

.lp-hero-inner {
    position: relative;
    max-width: 800px;
    margin: 0 auto;
}

.lp-kicker {
    display: inline-block;
    padding: 0.38rem 0.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff5df;
    font-size: 0.82rem;
    font-weight: 700;
    margin-bottom: 1.2rem;
}

.lp-hero-title {
    margin: 0 0 1rem;
    font-size: clamp(2rem, 5vw, 3.4rem);
    font-weight: 900;
    line-height: 1.15;
}

.lp-highlight {
    background: linear-gradient(90deg, #34c9b0, #e4b45f);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.lp-hero-sub {
    margin: 0 auto 2rem;
    max-width: 58ch;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.7;
}

.lp-hero-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 2.5rem;
}

.lp-hero-stats {
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 0.75rem 1.5rem;
    border-radius: 20px;
    border: 1px solid rgba(139, 177, 203, 0.18);
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(8px);
    flex-wrap: wrap;
    justify-content: center;
}

.lp-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.3rem 1.4rem;
    gap: 0.15rem;
}

.lp-stat strong {
    font-size: 1.6rem;
    font-weight: 900;
    color: var(--accent-2);
    line-height: 1;
}

.lp-stat span {
    font-size: 0.78rem;
    color: var(--muted);
    font-weight: 600;
}

.lp-stat-divider {
    width: 1px;
    height: 2.5rem;
    background: rgba(139, 177, 203, 0.2);
}

/* ── Buttons ── */
.lp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.7rem 1.5rem;
    border-radius: 12px;
    font-weight: 800;
    font-size: 0.95rem;
    text-decoration: none;
    transition: transform 0.2s, opacity 0.2s, box-shadow 0.2s;
    border: 2px solid transparent;
    cursor: pointer;
}

.lp-btn:hover {
    transform: translateY(-2px);
}

.lp-btn-primary {
    background: linear-gradient(135deg, #3ac8b1, #299a8a);
    color: #031410;
    border-color: #2aa18f;
}

.lp-btn-primary:hover {
    opacity: 0.88;
    color: #031410;
    box-shadow: 0 8px 24px rgba(52, 201, 176, 0.35);
}

.lp-btn-ghost {
    background: rgba(255, 255, 255, 0.08);
    color: var(--text);
    border-color: rgba(139, 177, 203, 0.22);
}

.lp-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.13);
    color: var(--text);
}

.lp-btn-outline {
    background: transparent;
    color: var(--accent-2);
    border-color: var(--accent-2);
}

.lp-btn-outline:hover {
    background: rgba(52, 201, 176, 0.1);
    color: var(--accent-2);
}

.lp-btn-lg {
    padding: 0.85rem 2rem;
    font-size: 1rem;
}

/* ── Games Grid ── */
.lp-games-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}

.lp-game-card {
    padding: 1.3rem;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
    transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
    box-shadow: 0 8px 24px rgba(0,0,0,0.18);
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.lp-game-card:hover {
    transform: translateY(-4px);
    border-color: rgba(52, 201, 176, 0.35);
    box-shadow: 0 16px 36px rgba(0,0,0,0.25);
}

.lp-game-icon {
    font-size: 2.2rem;
    line-height: 1;
    margin-bottom: 0.2rem;
}

.lp-game-card h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
}

.lp-game-card p {
    margin: 0;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.55;
    flex: 1;
}

.lp-game-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.3rem;
}

.lp-tag {
    padding: 0.22rem 0.6rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 700;
    border: 1px solid rgba(139, 177, 203, 0.15);
}

.lp-tag-players {
    background: rgba(52, 201, 176, 0.1);
    color: var(--accent-2);
    border-color: rgba(52, 201, 176, 0.2);
}

.lp-tag-special {
    background: rgba(228, 180, 95, 0.12);
    color: var(--accent);
    border-color: rgba(228, 180, 95, 0.2);
}

/* Accent colors per game type */
.lp-game-console { border-top: 3px solid #6eb5ff; }
.lp-game-pc      { border-top: 3px solid #34c9b0; }
.lp-game-board   { border-top: 3px solid #e4b45f; }
.lp-game-mafia   { border-top: 3px solid #ef7a8f; }
.lp-game-billiard{ border-top: 3px solid #6ce0a8; }
.lp-game-vr      { border-top: 3px solid #bf83ff; }
.lp-game-sim     { border-top: 3px solid #f0bf68; }
.lp-game-airhockey{ border-top: 3px solid #7ebdff; }
.lp-game-chess   { border-top: 3px solid #bdf5d6; }
.lp-game-cards   { border-top: 3px solid #ffb347; }
.lp-game-tournament{ border-top: 3px solid #ffd700; }
.lp-game-arcade  { border-top: 3px solid #ff7eb3; }

/* ── Features grid ── */
.lp-features-grid {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 1fr;
}

.lp-feature-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.03);
    transition: border-color 0.22s;
}

.lp-feature-item:hover {
    border-color: rgba(52, 201, 176, 0.28);
}

.lp-feature-icon-wrap {
    flex-shrink: 0;
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
}

.lp-fi-blue   { background: rgba(110, 181, 255, 0.15); }
.lp-fi-gold   { background: rgba(228, 180, 95, 0.15); }
.lp-fi-green  { background: rgba(108, 224, 168, 0.15); }
.lp-fi-purple { background: rgba(191, 131, 255, 0.15); }
.lp-fi-teal   { background: rgba(52, 201, 176, 0.15); }
.lp-fi-orange { background: rgba(240, 191, 104, 0.15); }
.lp-fi-red    { background: rgba(239, 122, 143, 0.15); }

.lp-feature-item h3 {
    margin: 0 0 0.3rem;
    font-size: 1rem;
    font-weight: 800;
}

.lp-feature-item p {
    margin: 0;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.6;
}

/* ── Tech Stack ── */
.lp-tech-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
}

.lp-tech-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    padding: 1.25rem 1rem;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.04);
    text-align: center;
    transition: border-color 0.22s, transform 0.22s;
}

.lp-tech-card:hover {
    border-color: rgba(52, 201, 176, 0.3);
    transform: translateY(-3px);
}

.lp-tech-icon {
    font-size: 2rem;
    line-height: 1;
}

.lp-tech-card strong {
    font-size: 0.92rem;
    font-weight: 800;
}

.lp-tech-card span {
    font-size: 0.78rem;
    color: var(--muted);
}

/* ── Pricing ── */
.lp-pricing-section {
    position: relative;
    overflow: hidden;
}

.lp-pricing-section::before {
    content: '';
    position: absolute;
    top: -120px;
    left: 50%;
    transform: translateX(-50%);
    width: 700px;
    height: 700px;
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(52, 201, 176, 0.07) 0%, transparent 65%);
    pointer-events: none;
}

.lp-pricing-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: 1fr;
    align-items: start;
}

/* ── Plan Card (BEM: .lp-pc) ── */
.lp-pc {
    position: relative;
    padding: 2rem;
    border-radius: 24px;
    border: 1px solid var(--border);
    background: var(--surface);
    backdrop-filter: blur(10px);
    display: flex;
    flex-direction: column;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.lp-pc:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.28);
    border-color: rgba(52, 201, 176, 0.28);
}

/* Featured card — gradient border via mask trick */
.lp-pc--featured {
    border: 1.5px solid transparent;
    background-clip: padding-box;
    box-shadow: 0 0 0 1.5px rgba(52, 201, 176, 0.45), 0 24px 60px rgba(0, 0, 0, 0.32), 0 0 40px rgba(52, 201, 176, 0.08);
}

.lp-pc--featured:hover {
    transform: translateY(-6px);
    box-shadow: 0 0 0 1.5px rgba(52, 201, 176, 0.7), 0 28px 72px rgba(0, 0, 0, 0.36), 0 0 60px rgba(52, 201, 176, 0.12);
}

.subscription-plan-selected {
    border-color: rgba(52, 201, 176, 0.75) !important;
    box-shadow: 0 0 0 1.5px rgba(52, 201, 176, 0.65), 0 22px 56px rgba(0, 0, 0, 0.3);
}

/* Ribbon */
.lp-pc__ribbon {
    position: absolute;
    top: -14px;
    right: 1.5rem;
    padding: 0.28rem 1rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #34c9b0 0%, #1a9a8a 100%);
    color: #031410;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    box-shadow: 0 4px 14px rgba(52, 201, 176, 0.45);
    white-space: nowrap;
}

/* Head */
.lp-pc__head {
    margin-bottom: 1.5rem;
}

.lp-pc__name-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
}

.lp-pc__name {
    font-size: 1rem;
    font-weight: 700;
    color: var(--muted);
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.lp-pc__save-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.14rem 0.55rem;
    border-radius: 999px;
    background: rgba(228, 180, 95, 0.15);
    border: 1px solid rgba(228, 180, 95, 0.3);
    color: var(--accent);
    font-size: 0.71rem;
    font-weight: 700;
}

.lp-pc__price-row {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 0.6rem;
}

/* Original (strikethrough) price row */
.lp-pc__original-price-row {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
    margin-bottom: 0.25rem;
}

.lp-pc__original-amount {
    font-size: 1rem;
    font-weight: 600;
    color: var(--muted);
    text-decoration: line-through;
    text-decoration-color: var(--danger);
    opacity: 0.75;
}

.lp-pc__original-unit {
    font-size: 0.72rem;
    color: var(--muted);
    opacity: 0.7;
}

.lp-pc__total-original {
    text-decoration: line-through;
    text-decoration-color: var(--danger);
    opacity: 0.6;
    font-size: 0.72rem;
}

.lp-pc__amount {
    font-size: clamp(1.9rem, 5vw, 2.8rem);
    font-weight: 900;
    color: var(--text);
    line-height: 1;
    letter-spacing: -0.025em;
}

.lp-pc--featured .lp-pc__amount {
    background: linear-gradient(135deg, #34c9b0, #6eb5ff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.lp-pc__per-col {
    display: flex;
    flex-direction: column;
}

.lp-pc__per {
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.3;
}

.lp-pc__total {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.22rem 0.7rem;
    border-radius: 8px;
    background: var(--surface-2);
    font-size: 0.78rem;
    color: var(--muted);
}

.lp-pc__dot {
    opacity: 0.4;
}

/* Divider */
.toast-host {
    position: fixed;
    top: 1.25rem;
    right: 1.25rem;
    display: grid;
    gap: 0.75rem;
    width: min(360px, calc(100vw - 2rem));
    z-index: 1300;
}

html[dir="rtl"] .toast-host {
    right: auto;
    left: 1.25rem;
}

.toast-card {
    padding: 0.9rem 1rem;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 8%), var(--surface));
    box-shadow: var(--shadow);
}

.toast-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.45rem;
}

.toast-card p {
    margin: 0;
    color: var(--muted);
}

.toast-card-info {
    border-color: color-mix(in srgb, var(--info), transparent 55%);
}

.toast-card-success {
    border-color: color-mix(in srgb, var(--success), transparent 45%);
}

.toast-card-warning {
    border-color: color-mix(in srgb, var(--warning), transparent 40%);
}

.toast-card-error {
    border-color: color-mix(in srgb, var(--danger), transparent 35%);
}

.toast-close-btn,
.header-icon-btn {
    border: 0;
    background: transparent;
    color: inherit;
}

.toast-close-btn {
    font-size: 1.1rem;
    line-height: 1;
}

.notification-center {
    position: relative;
}

.header-icon-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--surface), #ffffff 6%);
    box-shadow: var(--shadow);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.header-icon-btn:hover,
.header-icon-btn.active {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--accent-3), transparent 45%);
}

.notification-badge {
    position: absolute;
    top: -0.35rem;
    right: -0.35rem;
    min-width: 1.2rem;
    height: 1.2rem;
    padding: 0 0.3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--danger);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 800;
}

.notification-popover {
    position: absolute;
    top: calc(100% + 0.75rem);
    right: 0;
    width: min(360px, calc(100vw - 2rem));
    border-radius: 18px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface), #ffffff 7%), var(--surface));
    box-shadow: var(--shadow);
    overflow: hidden;
    z-index: 1200;
}

html[dir="rtl"] .notification-popover {
    right: auto;
    left: 0;
}

.notification-popover-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem;
    border-bottom: 1px solid var(--border);
}

.notification-list {
    display: grid;
    max-height: 420px;
    overflow-y: auto;
}

.notification-item {
    width: 100%;
    padding: 0.95rem 1rem;
    border: 0;
    border-bottom: 1px solid var(--border);
    background: transparent;
    color: inherit;
    text-align: inherit;
}

.notification-item:last-child {
    border-bottom: 0;
}

.notification-item.unread {
    background: color-mix(in srgb, var(--warning), transparent 88%);
}

.notification-item-head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
}

.notification-item p,
.notification-empty {
    margin: 0;
    color: var(--muted);
}

.notification-item small {
    display: block;
    margin-top: 0.4rem;
    color: var(--muted);
}

.notification-empty {
    padding: 1.25rem 1rem;
    text-align: center;
}
.lp-pc__divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 0 0 1.25rem;
}

/* Features list */
.lp-pc__features {
    list-style: none;
    margin: 0 0 1.75rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    flex: 1;
}

.lp-pc__feature {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    font-size: 0.875rem;
    color: var(--text);
    line-height: 1.45;
}

.lp-pc__feature--no {
    color: var(--muted);
    opacity: 0.6;
}

.lp-pc__icon {
    flex-shrink: 0;
    width: 1rem;
    height: 1rem;
    margin-top: 0.18rem;
}

.lp-pc__icon--check {
    color: var(--success);
}

.lp-pc__icon--x {
    color: var(--muted);
}

/* Actions */
.lp-pc__actions {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.lp-btn-block {
    width: 100%;
}

/* Trust strip */
.lp-pricing-trust {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1.5rem 2.5rem;
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
    color: var(--muted);
    font-size: 0.84rem;
}

.lp-pricing-trust span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

/* ── CTA Banner ── */
.lp-cta-banner {
    padding: 5rem 0;
    background: radial-gradient(ellipse at center, rgba(52, 201, 176, 0.14) 0%, transparent 65%);
    text-align: center;
}

.lp-cta-inner h2 {
    margin: 0 0 0.75rem;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 900;
}

.lp-cta-inner p {
    margin: 0 auto 2rem;
    color: var(--muted);
    max-width: 46ch;
    font-size: 1rem;
}

.lp-cta-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

/* ── Footer ── */
.lp-footer {
    border-top: 1px solid rgba(139, 177, 203, 0.14);
    padding: 3rem 0 2rem;
}

.lp-footer-grid {
    display: grid;
    gap: 2rem;
    grid-template-columns: 1fr;
    margin-bottom: 2.5rem;
}

.lp-footer-brand p {
    margin: 0.6rem 0 0;
    color: var(--muted);
    font-size: 0.9rem;
    max-width: 36ch;
}

.lp-footer-col h4 {
    margin: 0 0 0.85rem;
    font-size: 0.9rem;
    font-weight: 800;
    color: var(--text);
}

.lp-footer-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.45rem;
}

.lp-footer-col ul li,
.lp-footer-col ul li a {
    color: var(--muted);
    font-size: 0.88rem;
    text-decoration: none;
    transition: color 0.2s;
}

.lp-footer-col ul li a:hover {
    color: var(--accent-2);
}

.lp-footer-bottom {
    border-top: 1px solid rgba(139, 177, 203, 0.1);
    padding-top: 1.5rem;
    text-align: center;
}

.lp-footer-bottom p {
    margin: 0;
    color: var(--muted);
    font-size: 0.85rem;
}

/* ── Responsive ── */
@media (min-width: 640px) {
    .lp-nav-links {
        display: flex;
    }

    .lp-hamburger {
        display: none;
    }

    .lp-footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .lp-pricing-grid {
        grid-template-columns: repeat(2, 1fr);
        align-items: start;
    }

    /* If 2 plans, center them nicely */
    .lp-pricing-grid:has(.lp-pc:nth-child(2):last-child) {
        max-width: 700px;
        margin-inline: auto;
    }

    .lp-features-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 900px) {
    .lp-footer-grid {
        grid-template-columns: 2fr 1fr 1fr 1fr;
    }

    .lp-pricing-grid {
        grid-template-columns: repeat(3, 1fr);
        align-items: start;
    }

    /* featured card is taller — nudge it up so it pops out */
    .lp-pricing-grid .lp-pc--featured {
        margin-top: -0.75rem;
        padding-top: 2.75rem;
    }

    .lp-features-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ── Light Mode Landing Page overrides ── */
html[data-theme="light"] .lp-nav {
    background: rgba(247, 250, 252, 0.92);
    border-bottom-color: rgba(19, 39, 58, 0.12);
}

html[data-theme="light"] .lp-brand-name,
html[data-theme="light"] .lp-nav-link {
    color: #13283b;
}

html[data-theme="light"] .lp-nav-link:hover {
    color: #10273a;
    background: rgba(19, 39, 58, 0.06);
}

html[data-theme="light"] .lp-hamburger span {
    background: #13283b;
}

html[data-theme="light"] .lp-hamburger {
    border-color: rgba(19, 39, 58, 0.18);
}

html[data-theme="light"] .lp-kicker {
    background: rgba(19, 39, 58, 0.06);
    color: #8f5f12;
}

html[data-theme="light"] .lp-game-card,
html[data-theme="light"] .lp-feature-item,
html[data-theme="light"] .lp-price-card,
html[data-theme="light"] .lp-pc,
html[data-theme="light"] .lp-tech-card {
    background: rgba(255, 255, 255, 0.82);
}

html[data-theme="light"] .lp-pc--featured {
    box-shadow: 0 0 0 1.5px rgba(30, 157, 137, 0.45), 0 24px 60px rgba(0, 0, 0, 0.1), 0 0 40px rgba(30, 157, 137, 0.07);
}

html[data-theme="light"] .lp-pc:hover {
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.1);
    border-color: rgba(30, 157, 137, 0.3);
}

html[data-theme="light"] .lp-pc__total {
    background: rgba(19, 39, 58, 0.06);
}

html[data-theme="light"] .lp-pricing-trust {
    border-top-color: rgba(19, 39, 58, 0.1);
}

html[data-theme="light"] .lp-section-alt {
    background: rgba(19, 39, 58, 0.03);
}

html[data-theme="light"] .lp-hero-stats {
    background: rgba(255, 255, 255, 0.6);
    border-color: rgba(19, 39, 58, 0.12);
}

/* ── Chart lock overlay ──────────────────────────────────── */
.chart-lock-overlay {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: .5rem;
    min-height: 200px;
    padding: 2rem 1.5rem;
    color: var(--muted);
}

.chart-lock-icon {
    font-size: 2.5rem;
    line-height: 1;
}

.chart-lock-msg {
    font-size: .9rem;
    font-weight: 600;
    color: var(--text);
}

.chart-lock-plan {
    font-size: .82rem;
    color: var(--muted);
}
