/* Modern Minimalist Tasarım */
:root {
    /* Spacing Tokens */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 2rem;
    --space-8: 2.5rem;

    --primary-color: #58d0c7;
    --primary-hover: #6ae1d8;
    --primary-light: #9aece6;
    --primary-soft: rgba(88, 208, 199, 0.16);
    --accent-color: #8fb2ff;

    --page-bg: #0d1216;
    --page-bg-alt: #11171d;
    --bg-dark: var(--page-bg);
    --bg-darker: #090d10;
    --bg-medium: #171f26;
    --bg-light: #202a33;
    --bg-elevated: #27323c;
    --card-bg: var(--bg-medium);
    --surface-muted: rgba(255, 255, 255, 0.045);

    --text-primary: #f6fbff;
    --text-secondary: #dce6ee;
    --text-muted: #aab8c5;
    --text-light: #83919d;
    --text-color: var(--text-secondary);
    --icon-default: #8ea0ad;
    --icon-active: #dffefd;

    --success-color: #4ade80;
    --success-bg: rgba(52, 211, 153, 0.12);
    --error-color: #ff7d91;
    --error-bg: rgba(251, 113, 133, 0.12);
    --warning-color: #f6c453;
    --warning-bg: rgba(251, 191, 36, 0.12);

    --border-color: rgba(173, 191, 208, 0.12);
    --border-light: rgba(211, 225, 236, 0.2);
    --divider-color: rgba(255, 255, 255, 0.08);

    --gradient-primary: linear-gradient(135deg, #58d0c7, #78bbff);
    --gradient-primary-strong: linear-gradient(135deg, #71e3da, #92c7ff);
    --btn-primary-text: #041013;
    --btn-secondary-bg: rgba(116, 141, 168, 0.18);
    --btn-secondary-border: rgba(148, 163, 184, 0.32);
    --btn-secondary-text: #f4f8fb;
    --btn-outline-bg: rgba(75, 184, 177, 0.1);
    --btn-outline-border: rgba(95, 214, 206, 0.42);
    --btn-outline-text: #cafdff;
    --btn-danger-bg: linear-gradient(135deg, #ff7b8d, #ef4444);
    --btn-danger-border: rgba(255, 120, 120, 0.42);
    --btn-danger-text: #fff6f6;
    --gradient-surface: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0));
    --shadow-light: 0 10px 30px rgba(0, 0, 0, 0.22);
    --shadow-medium: 0 18px 48px rgba(0, 0, 0, 0.34);
    --shadow-focus: 0 0 0 4px rgba(75, 184, 177, 0.16);
    --shadow-pressed: inset 0 1px 0 rgba(255, 255, 255, 0.05);
    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 22px;

    /* UI Primitive Tokens */
    --ui-btn-padding-y: 0.82rem;
    --ui-btn-padding-x: 1.2rem;
    --ui-btn-radius: 12px;
    --ui-card-radius: var(--radius-md);
    --ui-card-padding: 1.4rem;
    --ui-input-radius: 12px;
    --ui-badge-radius: 999px;

    /* Status Tokens */
    --status-yapildi-bg: rgba(34, 197, 94, 0.18);
    --status-yapildi-border: rgba(74, 222, 128, 0.38);
    --status-yapildi-text: #dcfce7;
    --status-tamamlandi-bg: rgba(56, 189, 248, 0.18);
    --status-tamamlandi-border: rgba(56, 189, 248, 0.38);
    --status-tamamlandi-text: #d8f3ff;
    --status-kapatildi-bg: rgba(239, 68, 68, 0.18);
    --status-kapatildi-border: rgba(248, 113, 113, 0.38);
    --status-kapatildi-text: #ffe1e1;
    --status-duzenleniyor-bg: rgba(245, 158, 11, 0.18);
    --status-duzenleniyor-border: rgba(251, 191, 36, 0.38);
    --status-duzenleniyor-text: #fff0b3;
    --status-beklemede-bg: rgba(148, 163, 184, 0.18);
    --status-beklemede-border: rgba(148, 163, 184, 0.38);
    --status-beklemede-text: #e2e8f0;
    --status-onemli-bg: rgba(168, 85, 247, 0.18);
    --status-onemli-border: rgba(192, 132, 252, 0.38);
    --status-onemli-text: #f3e8ff;

    /* Role Tokens */
    --role-yonetici-bg: rgba(239, 68, 68, 0.16);
    --role-yonetici-border: rgba(248, 113, 113, 0.35);
    --role-yonetici-text: #ffe1e1;
    --role-musteri-bg: rgba(59, 130, 246, 0.16);
    --role-musteri-border: rgba(96, 165, 250, 0.35);
    --role-musteri-text: #dbeafe;
    --role-sistem-bg: rgba(75, 184, 177, 0.16);
    --role-sistem-border: rgba(121, 211, 205, 0.35);
    --role-sistem-text: #d5fffb;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background-color: var(--page-bg);
    color: var(--text-secondary);
    line-height: 1.6;
    overflow-x: hidden;
    background-image:
        radial-gradient(circle at top left, rgba(88, 208, 199, 0.1), transparent 28%),
        radial-gradient(circle at top right, rgba(143, 178, 255, 0.08), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.014), rgba(255, 255, 255, 0)),
        linear-gradient(180deg, var(--page-bg), var(--page-bg-alt));
}

header,
nav,
main,
footer,
.container,
.container-fluid,
.card,
.ui-card,
.card-header,
.card-body,
.page-header,
.detail-header,
.detail-title,
.detail-actions,
.payment-item,
.payment-info,
.file-item,
.file-info,
.comment-item,
.comment-reply,
.note-item,
.note-header-main,
.thread-body {
    min-width: 0;
    max-width: 100%;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    width: 100%;
}

@media (min-width: 1366px) {
    .container {
        max-width: 1440px;
        padding: 0 24px;
    }
}

@media (min-width: 1600px) {
    .container {
        max-width: 1680px;
        padding: 0 32px;
    }
}

@media (min-width: 1920px) {
    .container {
        max-width: 1920px;
        padding: 0 48px;
    }
}

img,
svg,
canvas,
iframe,
video {
    max-width: 100%;
}

.logo,
.user-info span,
.note-title,
.note-content,
.comment-content,
.file-name,
.file-description,
.dashboard-thread-copy p,
.dashboard-activity-copy p,
.dashboard-file-copy p,
.dashboard-alert-copy p,
.customer-project-card__header p,
.customer-activity-item__content p,
td,
th {
    overflow-wrap: anywhere;
    word-break: break-word;
}

/* Main Content */
main {
    min-height: calc(100vh - 160px);
    padding: 2.4rem 0 3.2rem;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
    color: var(--text-primary);
    margin-bottom: 1rem;
}

h1 {
    font-size: clamp(2rem, 2.6vw, 2.8rem);
    font-weight: 800;
    letter-spacing: -0.03em;
}

h2 {
    font-size: clamp(1.4rem, 2vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.02em;
}

h3 {
    font-size: 1.06rem;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.ui-section-title {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
    color: var(--text-primary);
    font-size: 1.04rem;
    font-weight: 700;
    letter-spacing: -0.01em;
}

/* Links */
a {
    color: var(--primary-color);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover {
    color: var(--primary-light);
}

/* Header */
header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(9, 13, 16, 0.9);
    backdrop-filter: blur(18px);
    padding: 1rem 0;
    border-bottom: 1px solid var(--divider-color);
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.logo {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-primary);
    letter-spacing: -0.03em;
}

.user-info {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.user-info span {
    color: var(--text-secondary);
    font-weight: 500;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.055);
    border: 1px solid rgba(255, 255, 255, 0.09);
}

.user-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.nav-toggle {
    display: none;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    background: rgba(255, 255, 255, 0.06);
    color: var(--text-primary);
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 0;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.nav-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    background: currentColor;
    border-radius: 999px;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.nav-toggle.is-active span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.nav-toggle.is-active span:nth-child(2) {
    opacity: 0;
}

.nav-toggle.is-active span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* Navigation */
nav {
    background: rgba(16, 23, 29, 0.92);
    backdrop-filter: blur(14px);
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--divider-color);
}

/* Icons */
.nav-links i {
    margin-right: 0.5rem;
    width: 16px;
}

.btn i {
    margin-right: 0.5rem;
}

.card-header i {
    margin-right: 0.5rem;
}

.logo i {
    margin-right: 0.5rem;
    color: var(--icon-active);
}

.user-info i {
    margin-right: 0.3rem;
}

.nav-links {
    display: flex;
    list-style: none;
    gap: 2rem;
    flex-wrap: wrap;
}

.nav-mobile-only {
    display: none;
}

.nav-links a {
    color: #bcc9d4;
    text-decoration: none;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    transition: all 0.24s ease;
    font-weight: 600;
    position: relative;
    border: 1px solid transparent;
}

.nav-links a:hover {
    background-color: rgba(255, 255, 255, 0.06);
    color: var(--text-primary);
    border-color: var(--border-color);
    transform: translateY(-1px);
}

.nav-links a.active {
    background: var(--gradient-primary);
    color: #081114;
    border-color: transparent;
    box-shadow: 0 10px 24px rgba(75, 184, 177, 0.2);
}

/* Projects page: corporate header + filter shell */
.page-projeler header {
    background:
        linear-gradient(180deg, rgba(6, 12, 18, 0.95), rgba(9, 15, 22, 0.92)),
        radial-gradient(circle at 12% 20%, rgba(74, 222, 128, 0.08), transparent 35%);
    border-bottom-color: rgba(170, 192, 210, 0.18);
}

.page-projeler nav {
    background:
        linear-gradient(180deg, rgba(12, 20, 29, 0.95), rgba(12, 20, 29, 0.88)),
        radial-gradient(circle at 85% 0%, rgba(143, 178, 255, 0.08), transparent 28%);
}

.page-projeler .header-content {
    border: 1px solid rgba(171, 196, 216, 0.16);
    border-radius: 18px;
    padding: 0.9rem 1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
}

.page-projeler .user-info span {
    border-color: rgba(183, 204, 222, 0.2);
    background: rgba(255, 255, 255, 0.06);
}

.page-projeler .projects-container .page-actions {
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid rgba(171, 196, 216, 0.14);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.026), rgba(255, 255, 255, 0.01)),
        rgba(11, 19, 27, 0.55);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.page-projeler .projects-container .filters-container {
    max-width: 980px;
}

@media (max-width: 768px) {
    .page-projeler .header-content {
        gap: 0.9rem;
        padding: 0.85rem;
        border-radius: 14px;
    }

    .page-projeler .logo {
        font-size: 1.05rem;
        letter-spacing: -0.02em;
    }

    .page-projeler .nav-toggle {
        width: 42px;
        height: 42px;
        border-radius: 12px;
    }

    .page-projeler .user-info {
        gap: 0.6rem;
    }

    .page-projeler .user-info span {
        min-height: 46px;
        display: flex;
        align-items: center;
        border-radius: 14px;
        font-weight: 600;
    }

    .page-projeler .user-actions .btn {
        min-height: 50px;
        border-radius: 14px;
        justify-content: center;
        font-weight: 700;
    }

    .page-projeler nav .container {
        padding-top: 0.5rem;
        padding-bottom: 0.7rem;
    }

    .page-projeler .nav-links {
        margin-top: 0.45rem;
        border: 1px solid rgba(171, 196, 216, 0.16);
        border-radius: 14px;
        padding: 0.5rem;
        background: rgba(255, 255, 255, 0.02);
    }

    .page-projeler .nav-links a {
        border-radius: 10px;
        min-height: 44px;
        display: flex;
        align-items: center;
    }

    .page-projeler .projects-container .page-actions {
        margin-top: 0.75rem;
        padding: 0.8rem;
        border-radius: 14px;
        gap: 0.8rem;
    }

    .page-projeler .projects-container .filters-container {
        max-width: 100%;
    }

    .page-projeler .projects-container .filter-group {
        display: grid;
        grid-template-columns: 1fr auto auto;
        gap: 0.55rem;
        align-items: stretch;
    }

    .page-projeler .projects-container .search-input,
    .page-projeler .projects-container .filter-select {
        min-height: 46px;
        border-radius: 12px;
        border-color: rgba(171, 196, 216, 0.2);
        background: rgba(255, 255, 255, 0.025);
    }

    .page-projeler .projects-container .search-input {
        grid-column: 1 / -1;
    }

    .page-projeler .projects-container .filter-select {
        grid-column: 1 / -1;
    }

    .page-projeler .projects-container .filters-form .btn {
        min-height: 46px;
        min-width: 46px;
        width: 46px !important;
        border-radius: 12px;
        justify-content: center;
        padding: 0;
    }

    .page-projeler .projects-container .page-actions > .btn.btn-primary {
        width: 100%;
        min-height: 52px;
        border-radius: 14px;
        justify-content: center;
        font-weight: 700;
    }
}

/* Forms */
.form-container {
    max-width: 400px;
    margin: 5rem auto;
    padding: 2rem;
    background:
        var(--gradient-surface),
        var(--bg-medium);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-medium);
}

.form-group,
.ui-form-group {
    margin-bottom: 1.5rem;
}

label {
    display: block;
    margin-bottom: 0.55rem;
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.92rem;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
select,
textarea,
.ui-input,
.ui-select,
.ui-textarea {
    width: 100%;
    padding: 0.9rem 1rem;
    background-color: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border-color);
    border-radius: var(--ui-input-radius);
    color: var(--text-secondary);
    font-size: 1rem;
    transition: border-color 0.24s ease, box-shadow 0.24s ease, background-color 0.24s ease, transform 0.24s ease;
}

input:focus,
select:focus,
textarea:focus,
.ui-input:focus,
.ui-select:focus,
.ui-textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: var(--shadow-focus);
    background-color: rgba(255, 255, 255, 0.05);
}

/* Design System: Buttons */
.btn,
.ui-btn,
.ui-btn-primary,
.ui-btn-secondary {
    padding: var(--ui-btn-padding-y) var(--ui-btn-padding-x);
    background: var(--gradient-primary-strong);
    color: var(--btn-primary-text);
    border: 1px solid transparent;
    border-radius: var(--ui-btn-radius);
    cursor: pointer;
    font-size: 0.96rem;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, background 0.24s ease, color 0.24s ease;
    font-weight: 700;
    text-align: center;
    max-width: 100%;
    white-space: normal;
    box-shadow: 0 12px 28px rgba(75, 184, 177, 0.22);
}

.btn:hover,
.ui-btn:hover,
.ui-btn-primary:hover,
.ui-btn-secondary:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 34px rgba(75, 184, 177, 0.28);
}

.btn:focus-visible,
.ui-btn:focus-visible,
.ui-btn-primary:focus-visible,
.ui-btn-secondary:focus-visible,
.btn-outline:focus-visible,
.ui-btn-outline:focus-visible {
    outline: none;
    box-shadow: var(--shadow-focus);
}

.btn:active,
.ui-btn:active,
.ui-btn-primary:active,
.ui-btn-secondary:active,
.btn-outline:active,
.ui-btn-outline:active {
    transform: translateY(0);
    box-shadow: var(--shadow-pressed);
}

.btn-secondary,
.ui-btn-secondary {
    background: var(--btn-secondary-bg);
    border: 1px solid var(--btn-secondary-border);
    color: var(--btn-secondary-text);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

.btn-secondary:hover,
.ui-btn-secondary:hover {
    background: rgba(116, 141, 168, 0.26);
    border-color: rgba(191, 207, 224, 0.4);
    color: #fff;
}

.btn-danger {
    background: var(--btn-danger-bg);
    border-color: var(--btn-danger-border);
    color: var(--btn-danger-text);
}

.btn-danger:hover {
    background: linear-gradient(135deg, #ff8a9a, #f05252);
}

.btn-outline,
.ui-btn-outline {
    background-color: var(--btn-outline-bg);
    border: 1px solid var(--btn-outline-border);
    color: var(--btn-outline-text);
    box-shadow: 0 8px 20px rgba(20, 78, 78, 0.16);
}

.btn-outline:hover,
.ui-btn-outline:hover {
    background-color: rgba(75, 184, 177, 0.18);
    color: #f6ffff;
    border-color: rgba(111, 226, 218, 0.62);
}

.btn[disabled],
.ui-btn[disabled],
.ui-btn-primary[disabled],
.ui-btn-secondary[disabled],
.btn-secondary[disabled],
.btn-outline[disabled],
.btn-danger[disabled] {
    opacity: 0.58;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Design System: Cards */
.card,
.ui-card {
    background:
        var(--gradient-surface),
        var(--bg-medium);
    border: 1px solid var(--border-color);
    padding: var(--ui-card-padding);
    margin-bottom: 1.15rem;
    border-radius: var(--ui-card-radius);
    min-width: 0;
    box-shadow: var(--shadow-light);
    transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.card:hover,
.ui-card:hover {
    border-color: var(--border-light);
    box-shadow: var(--shadow-medium);
}

.card-body,
.ui-card-body {
    min-width: 0;
}

.card-header,
.ui-card-header {
    font-size: 1.04rem;
    font-weight: 700;
    margin-bottom: 1.1rem;
    color: var(--text-primary);
    border-bottom: 1px solid var(--divider-color);
    padding-bottom: 0.95rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    min-width: 0;
}

/* Design System: Tables */
.table-responsive,
.ui-table-wrap {
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

.table,
.ui-table {
    width: 100%;
    border-collapse: collapse;
    background-color: transparent;
    border-radius: 14px;
    overflow: hidden;
    min-width: 0;
}

@media (min-width: 1600px) {
    .table,
    .ui-table {
        min-width: 780px;
    }
}

.table th,
.table td,
.ui-table th,
.ui-table td {
    padding: 0.95rem 0.85rem;
    text-align: left;
    border-bottom: 1px solid var(--divider-color);
}

.table th,
.ui-table th {
    background-color: rgba(255, 255, 255, 0.045);
    color: var(--text-primary);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.table tr:hover,
.ui-table tr:hover {
    background-color: rgba(255, 255, 255, 0.045);
}

/* Dashboard */
.dashboard-shell {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.dashboard-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1.5rem;
    padding: 1.7rem;
    background:
        radial-gradient(circle at top right, rgba(88, 208, 199, 0.18), transparent 28%),
        radial-gradient(circle at bottom left, rgba(143, 178, 255, 0.12), transparent 24%),
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0)),
        var(--bg-medium);
}

.dashboard-kicker {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0.28rem 0.72rem;
    border-radius: 999px;
    background: rgba(75, 184, 177, 0.14);
    border: 1px solid rgba(75, 184, 177, 0.22);
    color: var(--primary-light);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.dashboard-title {
    margin: 0.65rem 0 0.45rem;
}

.dashboard-subtitle,
.dashboard-panel-copy {
    color: var(--text-muted);
    margin: 0;
}

.dashboard-kpis {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 1rem;
}

@media (min-width: 1600px) {
    .dashboard-kpis {
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
        gap: 1.25rem;
    }
}

.dashboard-kpi-card {
    position: relative;
    overflow: hidden;
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    border: 1px solid transparent;
    border-radius: 18px;
    background:
        linear-gradient(165deg, rgba(10, 19, 45, 0.76), rgba(12, 16, 37, 0.66)) padding-box,
        linear-gradient(140deg, rgba(88, 214, 255, 0.38), rgba(124, 120, 255, 0.3), rgba(211, 95, 255, 0.38)) border-box;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        inset 0 0 0 1px rgba(255, 255, 255, 0.02),
        0 14px 30px rgba(3, 10, 30, 0.36);
    backdrop-filter: blur(12px);
    transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.dashboard-kpi-card::after {
    content: "";
    position: absolute;
    inset: -30% -15% auto;
    height: 65%;
    background: radial-gradient(circle, rgba(108, 213, 255, 0.2), rgba(108, 213, 255, 0));
    opacity: 0.75;
    pointer-events: none;
    transform: translateY(-20%);
    transition: opacity 0.28s ease;
}

a.dashboard-kpi-card {
    color: inherit;
    text-decoration: none;
}

a.dashboard-kpi-card:hover {
    transform: translateY(-4px) scale(1.01);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 20px 40px rgba(8, 24, 58, 0.44),
        0 0 0 1px rgba(128, 201, 255, 0.32),
        0 0 24px rgba(108, 182, 255, 0.3);
}

a.dashboard-kpi-card:hover::after {
    opacity: 1;
}

a.dashboard-kpi-card:focus-visible {
    outline: none;
    box-shadow: var(--shadow-focus);
}

.dashboard-kpi-icon {
    width: 2.85rem;
    height: 2.85rem;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: linear-gradient(155deg, rgba(20, 39, 89, 0.9), rgba(18, 24, 66, 0.82));
    border: 1px solid rgba(149, 193, 255, 0.2);
    color: #bde8ff;
    box-shadow: 0 0 0 1px rgba(140, 188, 255, 0.08), 0 8px 20px rgba(7, 17, 47, 0.4);
}

.dashboard-kpi-icon::before {
    content: "";
    position: absolute;
    inset: -9px;
    border-radius: 18px;
    background: radial-gradient(circle, rgba(80, 214, 255, 0.45), rgba(102, 154, 255, 0.18) 45%, rgba(81, 127, 255, 0));
    opacity: 0.72;
    filter: blur(6px);
    transition: opacity 0.28s ease, transform 0.28s ease;
}

.dashboard-kpi-icon i {
    position: relative;
    z-index: 1;
}

.dashboard-kpi-icon.is-success { color: var(--success-color); background: linear-gradient(160deg, rgba(19, 98, 74, 0.9), rgba(13, 54, 44, 0.82)); }
.dashboard-kpi-icon.is-warning { color: var(--warning-color); background: linear-gradient(160deg, rgba(110, 72, 20, 0.9), rgba(67, 45, 13, 0.82)); }
.dashboard-kpi-icon.is-accent { color: #a5bbff; background: linear-gradient(160deg, rgba(50, 67, 144, 0.9), rgba(29, 40, 95, 0.82)); }
.dashboard-kpi-icon.is-money { color: #f5cc7a; background: linear-gradient(160deg, rgba(108, 79, 30, 0.9), rgba(63, 46, 18, 0.82)); }
.dashboard-kpi-icon.is-teal { color: var(--primary-light); background: linear-gradient(160deg, rgba(23, 89, 86, 0.9), rgba(14, 54, 52, 0.82)); }

.dashboard-kpi-icon.is-warning::before {
    background: radial-gradient(circle, rgba(255, 202, 109, 0.5), rgba(205, 145, 42, 0.18) 45%, rgba(205, 145, 42, 0));
}

.dashboard-kpi-icon.is-accent::before {
    background: radial-gradient(circle, rgba(154, 173, 255, 0.52), rgba(110, 129, 255, 0.2) 45%, rgba(110, 129, 255, 0));
}

.dashboard-kpi-icon.is-money::before {
    background: radial-gradient(circle, rgba(255, 220, 147, 0.52), rgba(240, 184, 84, 0.2) 45%, rgba(240, 184, 84, 0));
}

.dashboard-kpi-icon.is-teal::before {
    background: radial-gradient(circle, rgba(118, 248, 235, 0.52), rgba(74, 192, 181, 0.2) 45%, rgba(74, 192, 181, 0));
}

.dashboard-kpi-label {
    color: var(--text-muted);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.dashboard-kpi-value {
    color: var(--text-primary);
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.dashboard-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(360px, 1fr);
    gap: 1.25rem;
    align-items: start;
}

.dashboard-main-grid--customer {
    grid-template-columns: minmax(0, 1.9fr) minmax(320px, 1fr);
}

@media (min-width: 1600px) {
    .dashboard-main-grid {
        grid-template-columns: minmax(0, 2fr) minmax(420px, 1fr);
    }
}

@media (max-width: 1199px) {
    .dashboard-main-grid {
        grid-template-columns: minmax(0, 1.45fr) minmax(280px, 1fr);
    }

    .dashboard-main-grid--customer {
        grid-template-columns: minmax(0, 1.6fr) minmax(280px, 1fr);
    }
}

@media (max-width: 992px) {
    .dashboard-main-grid,
    .dashboard-main-grid--customer {
        grid-template-columns: 1fr;
    }
}

.dashboard-column {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    min-width: 0;
}

.dashboard-panel-header {
    margin-bottom: 0.8rem;
}

.dashboard-panel--full {
    grid-column: 1 / -1;
}

.page-dashboard .dashboard-panel {
    min-height: 0;
}

.dashboard-activity-list,
.dashboard-thread-preview,
.dashboard-file-list,
.dashboard-alert-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

/* Keep right column lists compact so the page doesn't feel overly tall */
.dashboard-file-list,
.dashboard-alert-list {
    max-height: 360px;
    overflow-y: auto;
    padding-right: 0.2rem;
}

.dashboard-activity-item,
.dashboard-thread-row,
.dashboard-file-item,
.dashboard-alert-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.9rem;
    align-items: center;
    padding: 0.85rem 0.95rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: inherit;
}

.dashboard-activity-icon,
.dashboard-file-icon {
    width: 2.4rem;
    height: 2.4rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: rgba(88, 208, 199, 0.14);
    color: var(--icon-active);
}

.dashboard-activity-copy,
.dashboard-thread-copy,
.dashboard-file-copy,
.dashboard-alert-copy {
    min-width: 0;
}

.dashboard-activity-title,
.dashboard-thread-copy strong,
.dashboard-file-copy strong,
.dashboard-alert-copy strong {
    color: var(--text-primary);
    display: block;
    margin-bottom: 0.18rem;
}

.dashboard-activity-copy p,
.dashboard-thread-copy p,
.dashboard-file-copy p,
.dashboard-alert-copy p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.88rem;
}

.dashboard-activity-time,
.dashboard-thread-date,
.dashboard-file-time {
    color: var(--text-light);
    font-size: 0.8rem;
    white-space: nowrap;
}

.dashboard-domain-stack {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
}

.dashboard-domain-stack--horizontal {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 0.95rem;
}

.dashboard-domain-card {
    padding: 1rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.dashboard-domain-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.dashboard-domain-card__header strong {
    color: var(--text-primary);
}

.dashboard-domain-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.8rem;
}

.dashboard-domain-box {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 0.9rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.07);
    color: inherit;
    min-width: 0;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.dashboard-domain-box:hover,
.dashboard-domain-box:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(88, 208, 199, 0.32);
    background: rgba(88, 208, 199, 0.09);
}

.dashboard-domain-box__label {
    color: var(--text-light);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dashboard-domain-box__value {
    color: var(--text-primary);
    font-size: 1rem;
    line-height: 1.3;
}

.dashboard-domain-box small {
    color: var(--text-muted);
    line-height: 1.45;
}

.dashboard-domain-box--total {
    background: rgba(88, 208, 199, 0.08);
    border-color: rgba(88, 208, 199, 0.18);
}

.dashboard-domain-box--debt {
    background: rgba(246, 196, 83, 0.08);
    border-color: rgba(246, 196, 83, 0.2);
}

.dashboard-domain-box.is-disabled {
    opacity: 0.68;
}

.dashboard-domain-box.is-disabled:hover,
.dashboard-domain-box.is-disabled:focus-visible {
    transform: none;
    border-color: rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.04);
}

.dashboard-empty-state {
    padding: 1.15rem;
    border-radius: 14px;
    color: var(--text-muted);
    text-align: center;
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed rgba(255, 255, 255, 0.08);
}

.dashboard-link-inline {
    color: var(--primary-light);
    font-weight: 600;
}

.dashboard-summary-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.dashboard-summary-strip--column {
    flex-direction: column;
}

.dashboard-summary-chip {
    flex: 1 1 180px;
    padding: 0.85rem 0.95rem;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.035);
}

.dashboard-summary-chip span {
    display: block;
    color: var(--text-light);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.3rem;
}

.dashboard-summary-chip strong {
    color: var(--text-primary);
    font-size: 1rem;
}

.dashboard-summary-chip--warning {
    border-color: rgba(246, 196, 83, 0.24);
    background: rgba(246, 196, 83, 0.08);
}

.dashboard-finance-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.services-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.service-detail-card {
    padding: 1.15rem;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top right, rgba(88, 208, 199, 0.08), transparent 28%),
        rgba(255, 255, 255, 0.03);
}

.service-detail-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.service-detail-card__header h3 {
    margin: 0 0 0.3rem;
    color: var(--text-primary);
}

.service-detail-card__header p {
    margin: 0;
    color: var(--text-muted);
}

.service-detail-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.service-detail-box {
    padding: 0.9rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.service-detail-box--highlight {
    background: rgba(246, 196, 83, 0.08);
    border-color: rgba(246, 196, 83, 0.24);
}

.service-detail-box__label {
    display: block;
    color: var(--text-light);
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.35rem;
}

.service-detail-box strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 0.3rem;
}

.service-detail-box small {
    color: var(--text-muted);
    line-height: 1.45;
}

.service-provider-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 0.95rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.finance-main-grid {
    align-items: start;
}

.finance-schedule-list {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.finance-schedule-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.95rem 1rem;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.035);
    color: inherit;
}

.finance-schedule-item.is-urgent {
    border-color: rgba(246, 196, 83, 0.24);
    background: rgba(246, 196, 83, 0.08);
}

.finance-schedule-item.is-overdue {
    border-color: rgba(248, 113, 113, 0.26);
    background: rgba(248, 113, 113, 0.08);
}

.finance-schedule-item__copy,
.finance-schedule-item__meta {
    min-width: 0;
}

.finance-schedule-item__copy strong,
.finance-schedule-item__meta strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 0.2rem;
}

.finance-schedule-item__copy p,
.finance-schedule-item__copy small,
.finance-schedule-item__meta small {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.45;
}

.finance-schedule-item__meta {
    text-align: right;
}

.renewal-alert-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-bottom: 0.9rem;
}

.renewal-alert-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.72rem;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.78rem;
    font-weight: 700;
}

.renewal-alert-chip--90 {
    background: rgba(251, 191, 36, 0.18);
    border-color: rgba(251, 191, 36, 0.4);
    color: #ffe9a8;
}

.renewal-alert-chip--60 {
    background: rgba(249, 115, 22, 0.2);
    border-color: rgba(249, 115, 22, 0.42);
    color: #ffd6b0;
}

.renewal-alert-chip--30 {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.42);
    color: #ffd6d6;
}

.renewal-lifebar {
    width: 100%;
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
    margin: 0.45rem 0 0.4rem;
}

.renewal-lifebar__fill {
    display: block;
    height: 100%;
    transition: width 0.25s ease;
}

.renewal-lifebar__fill.lifebar--90 {
    background: linear-gradient(90deg, #facc15, #f59e0b);
}

.renewal-lifebar__fill.lifebar--60 {
    background: linear-gradient(90deg, #fb923c, #f97316);
}

.renewal-lifebar__fill.lifebar--30 {
    background: linear-gradient(90deg, #fb7185, #ef4444);
}

.renewal-lifebar__fill.lifebar--green {
    background: linear-gradient(90deg, #4ade80, #16a34a);
}

.dashboard-project-status {
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.78rem;
    font-weight: 700;
}

.dashboard-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.stat-card {
    background:
        radial-gradient(circle at top right, rgba(75, 184, 177, 0.14), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0)),
        var(--bg-medium);
    border: 1px solid var(--border-color);
    padding: 2rem 1.5rem;
    text-align: center;
    border-radius: 18px;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-light);
}

.stat-card:hover {
    transform: translateY(-4px);
    border-color: var(--border-light);
    box-shadow: var(--shadow-medium);
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background-color: var(--border-light);
}

.stat-number {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
    letter-spacing: -0.04em;
}

.stat-label {
    color: var(--text-muted);
    font-size: 0.9rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Alerts */
.alert {
    padding: 1rem 1.05rem;
    margin-bottom: 1rem;
    border: 1px solid;
    border-radius: 14px;
    font-weight: 600;
    backdrop-filter: blur(10px);
}

.alert-success {
    background-color: var(--success-bg);
    border-color: var(--success-color);
    color: var(--success-color);
}

.alert-error {
    background-color: var(--error-bg);
    border-color: var(--error-color);
    color: var(--error-color);
}

.alert-warning {
    background-color: var(--warning-bg);
    border-color: var(--warning-color);
    color: var(--warning-color);
}

/* Link Buttons */
.link-button {
    color: var(--primary-color) !important;
    text-decoration: none !important;
    font-weight: 500;
    padding: 0.5rem 1rem;
    border: 1px solid var(--primary-color);
    border-radius: 12px;
    transition: all 0.3s ease;
    display: inline-block;
}

.badge,
.status-badge,
.priority-badge,
.ui-badge,
.ui-status-badge,
.ui-role-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 30px;
    padding: 0.3rem 0.78rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.05);
    color: var(--text-secondary);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.badge,
.ui-badge {
    background: rgba(75, 184, 177, 0.12);
    border-color: rgba(75, 184, 177, 0.22);
    color: var(--primary-light);
}

.ui-status-badge,
.status-badge {
    --ui-badge-bg: rgba(255, 255, 255, 0.05);
    --ui-badge-border: rgba(255, 255, 255, 0.08);
    --ui-badge-text: var(--text-secondary);
    background: var(--ui-badge-bg);
    border-color: var(--ui-badge-border);
    color: var(--ui-badge-text);
}

.ui-role-badge,
.role-badge,
.note-role-badge {
    --ui-role-bg: rgba(255, 255, 255, 0.08);
    --ui-role-border: rgba(255, 255, 255, 0.1);
    --ui-role-text: #d8e1e8;
    background: var(--ui-role-bg);
    border: 1px solid var(--ui-role-border);
    color: var(--ui-role-text);
}

.status-yapildi,
.ui-status-yapildi {
    --ui-badge-bg: var(--status-yapildi-bg);
    --ui-badge-border: var(--status-yapildi-border);
    --ui-badge-text: var(--status-yapildi-text);
}

.status-tamamlandi,
.ui-status-tamamlandi {
    --ui-badge-bg: var(--status-tamamlandi-bg);
    --ui-badge-border: var(--status-tamamlandi-border);
    --ui-badge-text: var(--status-tamamlandi-text);
}

.status-kapatildi,
.ui-status-kapatildi {
    --ui-badge-bg: var(--status-kapatildi-bg);
    --ui-badge-border: var(--status-kapatildi-border);
    --ui-badge-text: var(--status-kapatildi-text);
}

.status-duzenleniyor,
.ui-status-duzenleniyor {
    --ui-badge-bg: var(--status-duzenleniyor-bg);
    --ui-badge-border: var(--status-duzenleniyor-border);
    --ui-badge-text: var(--status-duzenleniyor-text);
}

.status-beklemede,
.ui-status-beklemede,
.status-pending {
    --ui-badge-bg: var(--status-beklemede-bg);
    --ui-badge-border: var(--status-beklemede-border);
    --ui-badge-text: var(--status-beklemede-text);
}

.status-onemli,
.ui-status-onemli,
.status-important {
    --ui-badge-bg: var(--status-onemli-bg);
    --ui-badge-border: var(--status-onemli-border);
    --ui-badge-text: var(--status-onemli-text);
}

.role-admin,
.role-yonetici,
.ui-role-yonetici {
    --ui-role-bg: var(--role-yonetici-bg);
    --ui-role-border: var(--role-yonetici-border);
    --ui-role-text: var(--role-yonetici-text);
}

.role-partner,
.role-customer,
.role-musteri,
.ui-role-musteri {
    --ui-role-bg: var(--role-musteri-bg);
    --ui-role-border: var(--role-musteri-border);
    --ui-role-text: var(--role-musteri-text);
}

.role-system,
.role-sistem,
.ui-role-sistem {
    --ui-role-bg: var(--role-sistem-bg);
    --ui-role-border: var(--role-sistem-border);
    --ui-role-text: var(--role-sistem-text);
}

.link-button:hover {
    background-color: var(--primary-color);
    color: var(--text-primary) !important;
    transform: translateY(-1px);
}

.projects-container {
    max-width: 1800px;
    margin: 2rem auto 0;
    padding: 2rem;
}

.form-container-wide {
    max-width: 1200px;
    margin: 0 auto;
}

.page-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.filters-container {
    flex: 1;
    max-width: 600px;
}

.filters-form,
.filter-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.filter-group {
    flex: 1;
}

.search-input,
.filter-select {
    height: 2.75rem;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    background-color: var(--card-bg);
    color: var(--text-color);
}

.search-input {
    flex: 1;
    min-width: 200px;
    max-width: 100%;
}

.filter-select {
    min-width: 150px;
    max-width: 100%;
}

.disabled-input {
    background-color: var(--card-bg) !important;
    color: var(--text-muted) !important;
    cursor: not-allowed;
    opacity: 0.7;
}

.form-help {
    display: block;
    margin-top: 0.45rem;
    color: var(--text-light);
    font-size: 0.78rem;
    line-height: 1.45;
}

.payment-status-helper {
    margin-top: 0.75rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid rgba(88, 208, 199, 0.2);
    border-radius: 12px;
    background: rgba(88, 208, 199, 0.08);
    color: var(--text-secondary);
    font-size: 0.82rem;
    line-height: 1.5;
}

.payment-status-helper.is-warning {
    border-color: rgba(246, 196, 83, 0.3);
    background: rgba(246, 196, 83, 0.12);
    color: #ffe7aa;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.form-actions {
    display: flex;
    gap: 1rem;
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border-color);
}

.project-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-muted);
}

.project-name {
    font-weight: 500;
    color: var(--primary-color);
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
    font-size: 0.95rem;
    color: var(--text-color);
}

.checkbox-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary-color);
}

.text-muted {
    color: var(--text-muted) !important;
}

.text-danger {
    color: #dc3545 !important;
}

.text-warning {
    color: #ffc107 !important;
}

.action-buttons {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
}

.action-buttons--icons,
.file-actions,
.payment-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
}

.action-buttons .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.icon-button {
    width: 2.8rem;
    height: 2.8rem;
    min-width: 2.8rem;
    min-height: 2.8rem;
    padding: 0 !important;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    line-height: 1;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
    color: var(--icon-active) !important;
}

.icon-button i {
    font-size: 0.98rem;
    line-height: 1;
}

.icon-button:hover {
    transform: translateY(-1px);
}

.icon-button:focus-visible {
    outline: none;
    box-shadow: var(--shadow-focus);
}

.icon-button:active {
    transform: translateY(0);
    box-shadow: var(--shadow-pressed);
}

.icon-button-danger {
    color: #ffb4b4 !important;
    border-color: rgba(248, 113, 113, 0.34) !important;
    background: rgba(239, 68, 68, 0.08) !important;
}

.icon-button-danger:hover {
    color: #ffe3e3 !important;
    border-color: rgba(248, 113, 113, 0.5) !important;
    background: rgba(239, 68, 68, 0.14) !important;
}

.icon-button-view {
    color: #d9f6ff !important;
    border-color: rgba(96, 165, 250, 0.4) !important;
    background: rgba(59, 130, 246, 0.14) !important;
}

.icon-button-view:hover {
    color: #ffffff !important;
    border-color: rgba(96, 165, 250, 0.58) !important;
    background: rgba(59, 130, 246, 0.22) !important;
}

.icon-button-edit,
.icon-button-primary {
    color: #d9fffc !important;
    border-color: rgba(75, 184, 177, 0.3) !important;
    background: rgba(75, 184, 177, 0.12) !important;
}

.icon-button-edit:hover,
.icon-button-primary:hover {
    border-color: rgba(75, 184, 177, 0.48) !important;
    background: rgba(75, 184, 177, 0.18) !important;
}

.btn-delete:hover {
    background-color: #dc3545 !important;
    border-color: #dc3545 !important;
    color: white !important;
}

.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-muted);
}

.empty-state i {
    font-size: 4rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.empty-state h3 {
    margin-bottom: 0.5rem;
    color: var(--text-color);
}

.empty-state p {
    margin-bottom: 2rem;
}

/* Responsive */
@media (max-width: 1200px) {
    .dashboard-kpis {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .container {
        padding: 0 14px;
    }

    .header-content {
        flex-wrap: wrap;
        align-items: center;
        gap: 0.75rem;
    }

    .logo {
        flex: 1 1 auto;
        min-width: 0;
        font-size: 1.2rem;
    }

    .user-info {
        display: none !important;
    }

    .nav-toggle {
        display: inline-flex;
        order: 2;
    }

    nav {
        display: none;
        position: fixed;
        inset: 0;
        z-index: 1040;
        padding: 0;
        background: transparent;
        border: 0;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        pointer-events: none;
    }

    nav .container {
        position: relative;
        height: 100%;
        padding: 0 14px;
    }

    nav::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(5, 10, 15, 0.48);
        display: none;
        opacity: 0;
        transition: opacity 0.24s ease;
        pointer-events: none;
    }
    
    .nav-links {
        display: none;
        flex-direction: column;
        gap: 0.55rem;
        position: absolute;
        top: 82px;
        left: 14px;
        right: 14px;
        margin: 0;
        padding: 0.75rem;
        border: 1px solid rgba(171, 196, 216, 0.2);
        border-radius: 16px;
        background:
            linear-gradient(180deg, rgba(17, 28, 38, 0.98), rgba(12, 20, 29, 0.98)),
            radial-gradient(circle at 90% 5%, rgba(120, 190, 255, 0.12), transparent 40%);
        box-shadow: 0 18px 44px rgba(0, 0, 0, 0.42);
        max-height: calc(100vh - 96px);
        overflow-y: auto;
        opacity: 0;
        transform: translateY(-10px) scale(0.985);
        transition: opacity 0.22s ease, transform 0.22s ease;
        pointer-events: none;
    }

    nav.is-open {
        display: block;
        pointer-events: auto;
    }

    .page-projeler nav {
        background: transparent !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    nav.is-open::before {
        display: block;
        opacity: 1;
        pointer-events: auto;
    }

    nav.is-open .nav-links {
        display: flex;
        opacity: 1;
        transform: translateY(0) scale(1);
        pointer-events: auto;
    }

    .nav-links a {
        width: 100%;
        min-height: 48px;
        padding: 0.78rem 0.95rem;
        border-radius: 12px;
        display: flex;
        align-items: center;
        font-weight: 700;
        background: rgba(255, 255, 255, 0.02);
        border: 1px solid rgba(171, 196, 216, 0.1);
    }

    .nav-links a.active {
        box-shadow: 0 8px 22px rgba(75, 184, 177, 0.28);
    }

    .nav-mobile-only {
        display: block;
    }

    body.nav-open {
        overflow: hidden;
    }
    
    .dashboard-stats {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .dashboard-hero {
        flex-direction: column;
        align-items: stretch;
        padding: 1.2rem;
    }

    .dashboard-actions {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 0.75rem;
    }

    .dashboard-kpis {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.85rem;
    }

    .dashboard-kpi-card {
        align-items: center;
        text-align: center;
        padding: 1rem 0.85rem;
    }

    .dashboard-kpi-icon {
        margin: 0 auto;
    }

    .dashboard-activity-item,
    .dashboard-thread-row,
    .dashboard-file-item,
    .dashboard-alert-item {
        grid-template-columns: 1fr;
        align-items: flex-start;
    }

    .dashboard-domain-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-domain-box {
        padding: 0.72rem;
        gap: 0.28rem;
    }

    .dashboard-domain-box__label {
        font-size: 0.7rem;
    }

    .dashboard-domain-box__value {
        font-size: 0.92rem;
    }

    .dashboard-domain-box small {
        font-size: 0.8rem;
    }

    .dashboard-finance-grid,
    .service-detail-grid {
        grid-template-columns: 1fr;
    }

    .service-detail-card__header,
    .finance-schedule-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .finance-schedule-item__meta {
        text-align: left;
    }

    .dashboard-activity-time,
    .dashboard-thread-date,
    .dashboard-file-time {
        white-space: normal;
    }
    
    .card {
        padding: 1rem;
    }

    .card-header {
        align-items: flex-start;
    }

    .table {
        min-width: 620px;
    }

    .stat-card {
        padding: 1.5rem 1rem;
    }
} /* Note thread display */
.note-item {
  background-color: #303030;
  border: 1px solid #484848;
  border-radius: 12px;
  margin-bottom: 12px;
  padding: 18px;
  overflow: hidden;
}
.note-item.note-reply {
  background: linear-gradient(180deg, rgba(34, 34, 34, 0.98), rgba(24, 24, 24, 0.99)) !important;
  border-color: rgba(74, 222, 128, 0.32) !important;
  color: #f0fff4 !important;
  margin-top: 12px;
  padding: 18px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03), 0 12px 28px rgba(0, 0, 0, 0.24);
  transition: border-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease, background 0.24s ease;
}
.note-item.note-reply .note-title {
  color: #f6f7fb;
  font-weight: 700;
  margin-bottom: 10px;
}
.note-item.note-reply .note-content {
  color: #f3f6f8;
}
.notes-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.thread-ticket-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.08);
}
.thread-ticket-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
}
.thread-ticket-id,
.thread-ticket-count {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0.25rem 0.72rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #dde6ee;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.thread-ticket-updated {
  color: var(--text-muted);
  font-size: 0.82rem;
}
.thread-ticket-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.thread-close-form {
  margin: 0;
}
.thread-close-ticket-btn {
  min-height: 34px;
  padding: 0.42rem 0.9rem !important;
  box-shadow: 0 10px 24px rgba(239, 68, 68, 0.2);
}
.thread-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--text-secondary);
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.thread-toggle-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
  transform: translateY(-1px);
}
.thread-body[hidden] {
  display: none !important;
}
.note-thread {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.note-item.note-reply .note-footer {
  color: #cfd6dc;
}
.note-item .note-header {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  margin-bottom: 10px;
}
.note-header-main {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.note-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.admin-reply-header {
  gap: 10px;
}
.note-role-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.08);
  color: #d8d8d8;
}
.customer-note-card .note-role-badge {
  background: rgba(148, 163, 184, 0.18);
  color: #e5e7eb;
}
.admin-reply-card .note-role-badge {
  background: rgba(255, 255, 255, 0.06);
  color: #eff4f8;
}
.customer-note-card {
  border-left: 4px solid rgba(148, 163, 184, 0.42);
  background: linear-gradient(180deg, rgba(34, 39, 45, 0.98), rgba(28, 33, 39, 0.98));
}
.admin-reply-card {
  --status-bg: rgba(74, 222, 128, 0.18);
  --status-border: rgba(74, 222, 128, 0.38);
  --status-text: #dcfce7;
  --status-accent: #4ade80;
  position: relative;
  border-left: 4px solid var(--status-accent);
  border-color: var(--status-border) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0)),
    linear-gradient(180deg, rgba(25, 34, 31, 0.98), rgba(19, 25, 23, 0.99)) !important;
}
.admin-reply-card:hover {
  border-color: color-mix(in srgb, var(--status-accent) 52%, rgba(255, 255, 255, 0.2)) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04), 0 14px 30px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(255, 255, 255, 0.02);
  transform: translateY(-1px);
}
.admin-reply-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 999px;
  background: var(--status-bg);
  border: 1px solid var(--status-border);
  color: var(--status-text);
  flex-shrink: 0;
}
.admin-reply-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--status-accent), rgba(255, 255, 255, 0));
  opacity: 0.9;
}
.admin-reply-card::after {
  content: "";
  position: absolute;
  top: 18px;
  right: 18px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--status-accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--status-accent) 18%, transparent);
}
.admin-reply-card.status-yapildi {
  --status-bg: rgba(34, 197, 94, 0.18);
  --status-border: rgba(74, 222, 128, 0.38);
  --status-text: #dcfce7;
  --status-accent: #4ade80;
}
.admin-reply-card.status-tamamlandi {
  --status-bg: rgba(56, 189, 248, 0.18);
  --status-border: rgba(56, 189, 248, 0.38);
  --status-text: #d8f3ff;
  --status-accent: #38bdf8;
}
.admin-reply-card.status-kapatildi {
  --status-bg: rgba(239, 68, 68, 0.18);
  --status-border: rgba(248, 113, 113, 0.38);
  --status-text: #ffe1e1;
  --status-accent: #ef4444;
}
.admin-reply-card.status-duzenleniyor {
  --status-bg: rgba(245, 158, 11, 0.18);
  --status-border: rgba(251, 191, 36, 0.38);
  --status-text: #fff0b3;
  --status-accent: #f59e0b;
}
.note-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.note-item.note-customer {
  background-color: #353535;
  border-color: #4a4a4a;
}
.note-item.note-reply {
  margin-bottom: 0;
}
.reply-thread {
  position: relative;
  padding-left: 22px;
}
.customer-detail-header {
  padding: 1.4rem;
  border: 1px solid rgba(75, 184, 177, 0.18);
  border-radius: 18px;
  background:
    radial-gradient(circle at top right, rgba(75, 184, 177, 0.12), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0)),
    rgba(29, 29, 29, 0.94);
}
.customer-portal-summary {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  padding: 1.35rem;
  border: 1px solid rgba(75, 184, 177, 0.18);
  background:
    radial-gradient(circle at top right, rgba(56, 189, 248, 0.12), transparent 24%),
    radial-gradient(circle at bottom left, rgba(74, 222, 128, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0)),
    rgba(30, 30, 30, 0.96);
}
.customer-portal-summary__intro h3 {
  margin: 0 0 0.35rem;
  font-size: 1.2rem;
}
.customer-portal-summary__intro p {
  margin: 0;
  color: var(--text-muted);
}
.customer-portal-kicker {
  display: inline-flex;
  align-items: center;
  padding: 0.32rem 0.7rem;
  margin-bottom: 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(75, 184, 177, 0.22);
  background: rgba(75, 184, 177, 0.12);
  color: var(--primary-light);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.customer-portal-summary__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}
.customer-portal-pill {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 0.95rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
}
.customer-portal-pill--link {
  color: inherit;
  text-decoration: none;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}
.customer-portal-pill--link:hover {
  transform: translateY(-1px);
  border-color: rgba(95, 214, 206, 0.24);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.14);
}
.customer-portal-pill--link.is-disabled {
  pointer-events: none;
  opacity: 0.72;
}
.customer-portal-pill span {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}
.customer-portal-pill strong {
  font-size: 1rem;
  color: var(--text-light);
}
.customer-section-intro {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 1rem;
  margin-bottom: 1rem;
  border-radius: 12px;
  border: 1px solid rgba(75, 184, 177, 0.16);
  background: rgba(75, 184, 177, 0.08);
  color: #d7ece9;
  font-size: 0.92rem;
}
.customer-activity-timeline {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.customer-activity-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
  padding: 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.025);
}
.customer-activity-item__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: rgba(75, 184, 177, 0.12);
  border: 1px solid rgba(75, 184, 177, 0.2);
  color: var(--primary-light);
}
.customer-activity-item.type-admin_reply .customer-activity-item__icon {
  background: rgba(74, 222, 128, 0.14);
  border-color: rgba(74, 222, 128, 0.28);
  color: #bbf7d0;
}
.customer-activity-item.type-file .customer-activity-item__icon {
  background: rgba(56, 189, 248, 0.14);
  border-color: rgba(56, 189, 248, 0.24);
  color: #bae6fd;
}
.customer-activity-item__meta {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
  margin-bottom: 0.35rem;
}
.customer-activity-item__meta span,
.customer-activity-item__content small {
  color: var(--text-muted);
}
.customer-activity-item__content p {
  margin: 0 0 0.35rem;
  color: var(--text-light);
}
.customer-project-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}
.customer-project-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.1rem;
}
.customer-project-card__header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}
.customer-project-card__header h4 {
  margin: 0 0 0.35rem;
}
.customer-project-card__header p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.92rem;
}
.customer-project-card__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}
.customer-project-card__stats div {
  padding: 0.8rem;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.customer-project-card__stats span {
  display: block;
  margin-bottom: 0.28rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}
.customer-project-card__stats .is-overdue strong {
  color: #fca5a5;
}
.customer-project-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}
.reply-thread::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 2px;
  width: 2px;
  height: calc(100% + 2px);
  background: linear-gradient(180deg, rgba(128, 139, 160, 0.42), rgba(74, 222, 128, 0.45));
}
.reply-thread::after {
  content: "";
  position: absolute;
  top: 36px;
  left: 2px;
  width: 18px;
  height: 2px;
  background: linear-gradient(90deg, rgba(128, 139, 160, 0.7), rgba(74, 222, 128, 0.34));
}
.note-item .note-title {
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 5px;
}
.note-item.note-reply .note-title {
  font-size: 1rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.note-item .note-content {
  margin-bottom: 8px;
}
.admin-reply-meta-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: #b9c5cf;
  font-size: 0.78rem;
}
.admin-reply-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.admin-reply-meta-item i {
  color: var(--status-accent);
  opacity: 0.9;
}
.note-item .status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 0.28rem 0.72rem;
  border-radius: 999px;
  border: 1px solid var(--status-border, rgba(255, 255, 255, 0.1));
  background: var(--status-bg, rgba(255, 255, 255, 0.04));
  color: var(--status-text, #e5e7eb);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.note-item .status-badge i {
  font-size: 0.78rem;
}
.note-item .note-footer {
  font-size: 0.82rem;
  color: #a8a8a8;
}
.thread-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.admin-note-footer .note-author,
.admin-note-footer .note-date {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.inline-reply-toggle.is-active {
  background-color: var(--primary-color);
  color: var(--text-primary) !important;
  border-color: var(--primary-color);
}
.inline-reply-form {
  margin-top: 14px;
  padding: 16px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(22, 22, 22, 0.94), rgba(27, 27, 27, 0.98));
  border: 1px solid rgba(82, 82, 82, 0.9);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}
.quick-reply-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}
.quick-status-btn {
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0.5rem 0.95rem;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  min-height: 38px;
  transition: transform 0.2s ease, border-color 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.quick-status-btn:hover {
  transform: translateY(-1px);
  opacity: 1;
}
.quick-status-btn.is-selected {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.08), 0 8px 18px rgba(0, 0, 0, 0.18);
  transform: translateY(-1px);
}
.inline-reply-content-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.selected-status-indicator {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.28rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: #e5e7eb;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.selected-status-indicator.status-yapildi {
  background: rgba(34, 197, 94, 0.18);
  border-color: rgba(74, 222, 128, 0.38);
  color: #dcfce7;
}
.selected-status-indicator.status-tamamlandi {
  background: rgba(56, 189, 248, 0.18);
  border-color: rgba(56, 189, 248, 0.38);
  color: #d8f3ff;
}
.selected-status-indicator.status-kapatildi {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(248, 113, 113, 0.38);
  color: #ffe1e1;
}
.selected-status-indicator.status-duzenleniyor {
  background: rgba(245, 158, 11, 0.18);
  border-color: rgba(251, 191, 36, 0.38);
  color: #fff0b3;
}
.status-yapildi {
  --status-bg: rgba(34, 197, 94, 0.24);
  --status-border: rgba(74, 222, 128, 0.68);
  --status-text: #dcfce7;
  --status-accent: #4ade80;
  background: rgba(34, 197, 94, 0.24);
  border-color: rgba(74, 222, 128, 0.68);
  color: #dcfce7;
}
.status-tamamlandi {
  --status-bg: rgba(56, 189, 248, 0.22);
  --status-border: rgba(56, 189, 248, 0.64);
  --status-text: #d8f3ff;
  --status-accent: #38bdf8;
  background: rgba(56, 189, 248, 0.22);
  border-color: rgba(56, 189, 248, 0.64);
  color: #d8f3ff;
}
.status-kapatildi {
  --status-bg: rgba(239, 68, 68, 0.22);
  --status-border: rgba(248, 113, 113, 0.64);
  --status-text: #ffe1e1;
  --status-accent: #ef4444;
  background: rgba(239, 68, 68, 0.22);
  border-color: rgba(248, 113, 113, 0.64);
  color: #ffe1e1;
}
.status-duzenleniyor {
  --status-bg: rgba(245, 158, 11, 0.22);
  --status-border: rgba(251, 191, 36, 0.64);
  --status-text: #fff0b3;
  --status-accent: #f59e0b;
  background: rgba(245, 158, 11, 0.22);
  border-color: rgba(251, 191, 36, 0.64);
  color: #fff0b3;
}
.note-replies {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 8px 0 0 22px;
  margin-left: 8px;
  border-left: 2px solid rgba(128, 139, 160, 0.34);
  position: relative;
}
.note-replies::before {
  content: "";
  position: absolute;
  top: 0;
  left: -2px;
  width: 2px;
  height: 100%;
  background: linear-gradient(180deg, rgba(128, 139, 160, 0.55), rgba(74, 222, 128, 0.2));
}
.note-replies .admin-reply-card {
  margin-left: 6px;
}
.inline-reply-form-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.inline-reply-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.inline-reply-private {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.inline-reply-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.inline-reply-actions .btn-primary {
  box-shadow: 0 8px 18px rgba(45, 125, 125, 0.28);
}
.inline-reply-cancel {
  cursor: pointer;
}
.note-content {
  font-size: 0.97rem;
}
.note-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
@media (max-width: 768px) {
  .thread-ticket-bar,
  .note-item .note-header,
  .note-header-main,
  .inline-reply-form-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .thread-ticket-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .note-actions,
  .inline-reply-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .inline-reply-grid {
    grid-template-columns: 1fr;
  }

  .note-replies {
    padding-left: 12px;
    margin-left: 0;
  }

  .reply-thread {
    padding-left: 12px;
  }

  .reply-thread::after {
    width: 10px;
    top: 34px;
  }

  .admin-reply-card::after {
    top: 14px;
    right: 14px;
    width: 8px;
    height: 8px;
  }

  .note-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .quick-reply-buttons {
    gap: 8px;
  }

  .inline-reply-content-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-reply-meta-line,
  .admin-reply-header {
    width: 100%;
  }

  .status-badge,
  .selected-status-indicator {
    white-space: normal;
  }

  .note-item.note-reply {
    padding: 15px;
  }
}

/* Login Page: Neo AI / Neon UI */
body.login-page {
    min-height: 100vh;
    margin: 0;
    display: block;
    background:
        radial-gradient(circle at 10% 8%, rgba(0, 183, 255, 0.18), transparent 34%),
        radial-gradient(circle at 88% 16%, rgba(188, 61, 255, 0.16), transparent 32%),
        linear-gradient(165deg, #020a1c 0%, #061439 38%, #090824 100%);
    color: #dce8ff;
    font-family: "Segoe UI", "Inter", sans-serif;
}

.login-shell {
    min-height: 100vh;
    padding: 2rem 1rem;
    display: grid;
    place-items: center;
    position: relative;
    overflow: hidden;
}

.login-shell::before,
.login-shell::after {
    content: "";
    position: absolute;
    pointer-events: none;
    width: 480px;
    height: 480px;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.4;
}

.login-shell::before {
    top: -210px;
    left: -130px;
    background: rgba(0, 174, 255, 0.46);
}

.login-shell::after {
    bottom: -260px;
    right: -110px;
    background: rgba(153, 81, 255, 0.52);
}

.login-layout {
    width: min(1540px, 100%);
    display: grid;
    grid-template-columns: 1.18fr 0.92fr;
    border: 1px solid rgba(117, 180, 255, 0.44);
    border-radius: 26px;
    overflow: hidden;
    position: relative;
    z-index: 1;
    backdrop-filter: blur(20px);
    box-shadow: 0 30px 95px rgba(2, 7, 25, 0.72), inset 0 0 0 1px rgba(202, 154, 255, 0.22);
    background: linear-gradient(120deg, rgba(3, 14, 44, 0.86), rgba(6, 10, 36, 0.86));
}

.login-brand-panel,
.login-form-panel {
    padding: 2rem 2.2rem;
}

.login-brand-panel {
    border-right: 1px solid rgba(123, 159, 255, 0.26);
    background:
        radial-gradient(circle at 16% 12%, rgba(0, 179, 255, 0.18), transparent 40%),
        radial-gradient(circle at 74% 72%, rgba(138, 63, 255, 0.19), transparent 42%),
        rgba(2, 14, 50, 0.64);
}

.login-brand-card,
.login-form-card {
    height: 100%;
    border-radius: 22px;
    border: 1px solid rgba(123, 172, 255, 0.22);
    background: linear-gradient(155deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015));
    backdrop-filter: blur(16px);
}

.login-brand-card {
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}

.login-brand-top {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.login-brand-logo {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border: 1px solid rgba(135, 210, 255, 0.38);
    background: linear-gradient(145deg, rgba(0, 200, 255, 0.34), rgba(134, 68, 255, 0.34));
    box-shadow: 0 0 24px rgba(45, 170, 255, 0.33);
    font-size: 1.2rem;
    font-weight: 700;
}

.login-brand-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.login-brand-label {
    margin: 0;
    font-size: 0.78rem;
    letter-spacing: 0.02em;
    color: #a8b8de;
}

.login-brand-card h1 {
    margin: 0;
    font-size: clamp(1.5rem, 2vw, 2rem);
    color: #f4f7ff;
}

.login-brand-card h2 {
    margin: 1.3rem 0 0.35rem;
    font-size: clamp(2.5rem, 4vw, 4rem);
    font-weight: 800;
    line-height: 1.03;
    letter-spacing: -0.03em;
    color: transparent;
    background: linear-gradient(90deg, #24d2ff 0%, #7f8cff 52%, #e873ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
}

.login-brand-description {
    margin: 0;
    max-width: 570px;
    color: rgba(203, 218, 247, 0.9);
    font-size: 1.04rem;
    line-height: 1.55;
}

.login-visual-stage {
    margin-top: 0.75rem;
    margin-bottom: 0.45rem;
    border-radius: 22px;
    min-height: 280px;
    border: 1px solid rgba(121, 174, 255, 0.26);
    background:
        radial-gradient(circle at 72% 74%, rgba(181, 67, 255, 0.3), transparent 48%),
        radial-gradient(circle at 28% 18%, rgba(0, 154, 255, 0.24), transparent 44%),
        linear-gradient(150deg, rgba(7, 24, 66, 0.86), rgba(11, 12, 43, 0.74));
    position: relative;
    overflow: hidden;
}

.login-visual-device {
    position: absolute;
    width: 54%;
    aspect-ratio: 1.45;
    left: 50%;
    top: 55%;
    transform: translate(-50%, -50%) rotate(-13deg);
    border-radius: 20px;
    border: 1px solid rgba(117, 182, 255, 0.4);
    background:
        linear-gradient(145deg, rgba(26, 37, 120, 0.8), rgba(36, 17, 100, 0.8)),
        radial-gradient(circle at 34% 52%, rgba(41, 222, 255, 0.4), transparent 40%);
    box-shadow: 0 26px 70px rgba(2, 11, 37, 0.8), 0 0 30px rgba(108, 89, 255, 0.34);
}

.login-visual-chip {
    position: absolute;
    width: 78px;
    height: 78px;
    border-radius: 16px;
    border: 1px solid rgba(122, 186, 255, 0.38);
    background: linear-gradient(155deg, rgba(14, 59, 125, 0.68), rgba(22, 31, 96, 0.65));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}

.login-visual-chip::before {
    content: "";
    position: absolute;
    inset: 20%;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(43, 200, 255, 0.95), rgba(155, 74, 255, 0.92));
}

.login-visual-chip-check {
    left: 8%;
    top: 58%;
}

.login-visual-chip-chart {
    left: 18%;
    bottom: 12%;
}

.login-visual-chip-user {
    right: 12%;
    bottom: 16%;
}

.login-feature-grid {
    margin-top: 0.7rem;
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.login-feature-card {
    padding: 0.95rem 0.85rem;
    border-radius: 16px;
    border: 1px solid rgba(117, 171, 255, 0.25);
    background: linear-gradient(140deg, rgba(9, 27, 78, 0.64), rgba(13, 19, 58, 0.62));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.login-feature-icon {
    width: 26px;
    height: 26px;
    border-radius: 8px;
    display: inline-grid;
    place-items: center;
    margin-bottom: 0.5rem;
    font-size: 0.8rem;
    font-weight: 700;
    color: #f1f6ff;
    background: linear-gradient(135deg, rgba(22, 192, 255, 0.95), rgba(137, 78, 255, 0.95));
}

.login-feature-card strong {
    display: block;
    color: #f2f8ff;
    font-size: 1rem;
    letter-spacing: 0.01em;
}

.login-feature-card p {
    margin: 0.32rem 0 0;
    font-size: 0.9rem;
    line-height: 1.5;
    color: rgba(174, 197, 239, 0.88);
}

.login-form-card {
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.login-form-header {
    margin-bottom: 1.2rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

.login-form-header h2 {
    margin: 0;
    width: 100%;
    font-size: clamp(2.2rem, 2.8vw, 3.2rem);
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: #f4f8ff;
}

.login-subtitle {
    margin: 0;
    width: 100%;
    font-size: 1.1rem;
    color: rgba(172, 190, 227, 0.92);
}

.login-security-badge {
    margin-top: 0.15rem;
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(64, 232, 206, 0.4);
    background: rgba(4, 104, 101, 0.22);
    color: #69ffe3;
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.login-security-badge::before {
    content: "O";
    font-size: 0.8rem;
    line-height: 1;
}

.login-alert {
    margin-bottom: 1rem;
    border-radius: 12px;
    font-size: 0.88rem;
}

.login-form {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
}

.login-input-group {
    margin-bottom: 0;
}

.login-input-group label {
    margin-bottom: 0.5rem;
    color: #f0f6ff;
    font-size: 0.92rem;
    font-weight: 700;
}

.login-input-wrap,
.login-password-field {
    position: relative;
}

.login-input-group input[type="text"],
.login-input-group input[type="email"],
.login-input-group input[type="password"] {
    height: 4.2rem;
    border-radius: 14px;
    border: 1px solid rgba(107, 149, 238, 0.34);
    background: rgba(4, 14, 48, 0.85);
    color: #eef5ff;
    padding-left: 3.8rem;
    font-size: 1.12rem;
    font-weight: 500;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease, background-color 0.25s ease;
}

.login-input-group input::placeholder {
    color: rgba(154, 178, 229, 0.65);
}

.login-input-group input:focus {
    border-color: rgba(110, 209, 255, 0.92);
    box-shadow: 0 0 0 4px rgba(57, 121, 255, 0.18), 0 0 20px rgba(100, 84, 255, 0.25);
    transform: translateY(-1px);
    background-color: rgba(5, 18, 56, 0.9);
}

.login-input-group.is-focused label {
    color: #bdf6ff;
}

.login-input-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    width: 2rem;
    height: 2rem;
    border-radius: 10px;
    display: grid;
    place-items: center;
    font-size: 0.82rem;
    font-weight: 700;
    color: #dff1ff;
    background: linear-gradient(135deg, rgba(22, 176, 255, 0.9), rgba(140, 72, 255, 0.9));
}

.login-password-field input {
    padding-right: 4rem;
}

.login-password-toggle {
    position: absolute;
    top: 50%;
    right: 0.8rem;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    color: rgba(187, 201, 232, 0.88);
    border-radius: 10px;
    padding: 0.3rem;
    font-size: 0.88rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.login-password-toggle:hover {
    color: #f0fbff;
}

.login-password-toggle .hide-icon {
    display: none;
}

.login-password-toggle.is-visible .show-icon {
    display: none;
}

.login-password-toggle.is-visible .hide-icon {
    display: inline;
}

.login-row-options {
    margin-top: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.login-remember {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: rgba(196, 214, 248, 0.92);
    font-size: 0.9rem;
    cursor: pointer;
}

.login-remember input {
    accent-color: #5ec4ff;
}

.login-forgot-link,
.login-alt-link {
    color: #65a7ff;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    transition: color 0.2s ease, text-shadow 0.2s ease;
}

.login-forgot-link:hover,
.login-alt-link:hover {
    color: #d3f5ff;
    text-shadow: 0 0 12px rgba(79, 229, 255, 0.42);
}

.login-submit-btn {
    width: 100%;
    min-height: 4.25rem;
    margin-top: 0.5rem;
    border-radius: 14px;
    border: 1px solid rgba(121, 188, 255, 0.5);
    background: linear-gradient(95deg, #2099ff 0%, #3552ff 48%, #a735ff 100%);
    color: #eef4ff;
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    box-shadow: 0 20px 46px rgba(53, 107, 255, 0.4);
}

.login-submit-btn:hover {
    transform: translateY(-2px) scale(1.004);
    box-shadow: 0 24px 50px rgba(85, 77, 255, 0.46);
}

.login-divider {
    margin-top: 0.8rem;
    margin-bottom: 0.1rem;
    position: relative;
    text-align: center;
    color: rgba(159, 178, 217, 0.88);
    font-size: 0.9rem;
    font-weight: 600;
}

.login-divider::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    border-top: 1px solid rgba(98, 130, 201, 0.28);
}

.login-divider span {
    position: relative;
    padding: 0 0.9rem;
    background: rgba(8, 17, 53, 0.9);
}

.login-alt-actions {
    margin-top: 0.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.login-alt-btn {
    width: 100%;
    min-height: 4rem;
    border-radius: 14px;
    border: 1px solid rgba(109, 145, 223, 0.35);
    background: rgba(4, 16, 55, 0.68);
    color: #eff4ff;
    font-size: 1.06rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.login-alt-btn:hover {
    border-color: rgba(139, 189, 255, 0.56);
    color: #fafdff;
    box-shadow: 0 0 0 3px rgba(49, 126, 255, 0.14);
}

.login-alt-actions-inline {
    justify-content: flex-end;
}

.login-reset-btn {
    border: 0;
    padding: 0;
    background: transparent;
    cursor: pointer;
}

.login-copyright {
    margin-top: 1.1rem;
    text-align: center;
    font-size: 0.85rem;
    color: rgba(151, 169, 209, 0.78);
}

.login-form-card,
.login-brand-card {
    animation: loginRiseIn 0.55s ease;
}

@keyframes loginRiseIn {
    from {
        opacity: 0;
        transform: translateY(8px) scale(0.99);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@media (max-width: 1080px) {
    .login-layout {
        grid-template-columns: 1fr;
        max-width: 760px;
    }

    .login-brand-panel {
        border-right: 0;
        border-bottom: 1px solid rgba(157, 189, 255, 0.22);
    }

    .login-brand-card h2 {
        font-size: clamp(2rem, 8vw, 2.8rem);
    }

    .login-visual-stage {
        min-height: 220px;
    }

    .login-feature-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .login-shell {
        padding: 1rem 0.75rem;
    }

    .login-brand-panel,
    .login-form-panel {
        padding: 1rem;
    }

    .login-brand-card,
    .login-form-card {
        padding: 1.2rem;
    }

    .login-form-header h2 {
        font-size: clamp(1.9rem, 8vw, 2.4rem);
    }

    .login-feature-grid {
        grid-template-columns: 1fr;
    }

    .login-row-options {
        align-items: flex-start;
        flex-direction: column;
    }

    .login-submit-btn,
    .login-alt-btn {
        font-size: 1rem;
    }

    .login-alt-actions-inline {
        justify-content: flex-start;
    }
}

/* Login sayfasında global header/main/typography çakışmalarını engelle */
body.login-page main.login-shell {
    min-height: 100vh;
    padding: 2rem 1rem;
}

body.login-page .login-form-header {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    backdrop-filter: none !important;
}

body.login-page .login-brand-card h1,
body.login-page .login-brand-card h2,
body.login-page .login-form-header h2,
body.login-page .login-subtitle,
body.login-page .login-brand-description {
    text-shadow: none !important;
}

body.login-page .login-brand-card h1 {
    color: #f4f7ff !important;
}

body.login-page .login-brand-card h2 {
    color: #8fd2ff !important; /* gradient desteklemeyen tarayıcı fallback */
    background: linear-gradient(90deg, #24d2ff 0%, #7f8cff 52%, #e873ff 100%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

body.login-page .login-form-header h2 {
    color: #f4f8ff !important;
}

body.login-page .login-subtitle {
    color: rgba(172, 190, 227, 0.92) !important;
}

/* Dashboard Neo / AI Refresh */
.nav-links-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.nav-ai-badge {
    display: none;
}

.ai-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 28px;
    padding: 0.28rem 0.7rem;
    border-radius: 999px;
    border: 1px solid rgba(99, 240, 255, 0.4);
    background: linear-gradient(120deg, rgba(18, 112, 163, 0.34), rgba(83, 63, 182, 0.34));
    color: #d2f8ff;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    box-shadow: 0 0 14px rgba(66, 210, 255, 0.26);
}

.ai-badge::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #65f9ff;
    box-shadow: 0 0 10px rgba(101, 249, 255, 0.85);
}

.live-pulse::before {
    animation: livePulseDot 1.7s ease-in-out infinite;
}

@keyframes livePulseDot {
    0% { transform: scale(0.88); opacity: 0.7; }
    50% { transform: scale(1.12); opacity: 1; }
    100% { transform: scale(0.88); opacity: 0.7; }
}

.neo-card {
    position: relative;
    border: 1px solid rgba(140, 177, 255, 0.16);
    background:
        linear-gradient(160deg, rgba(8, 18, 48, 0.86), rgba(11, 14, 35, 0.84)),
        radial-gradient(circle at 100% 0%, rgba(71, 202, 255, 0.14), transparent 38%);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.36), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.neo-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    pointer-events: none;
    background: linear-gradient(130deg, rgba(100, 244, 255, 0.32), rgba(142, 99, 255, 0.2));
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

.neo-glow {
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.neo-glow:hover {
    transform: translateY(-2px);
    border-color: rgba(102, 231, 255, 0.38);
    box-shadow: 0 18px 38px rgba(16, 70, 140, 0.32);
}

.page-dashboard {
    background:
        radial-gradient(circle at 8% 10%, rgba(73, 206, 255, 0.13), transparent 32%),
        radial-gradient(circle at 88% 12%, rgba(158, 102, 255, 0.13), transparent 30%),
        radial-gradient(circle at 50% 100%, rgba(76, 255, 227, 0.08), transparent 40%),
        linear-gradient(150deg, #090f23 0%, #0b1228 42%, #0f1030 100%);
    position: relative;
}

.page-dashboard::before {
    content: "";
    position: fixed;
    inset: -20% -20%;
    pointer-events: none;
    background:
        radial-gradient(circle at 18% 24%, rgba(96, 220, 255, 0.1), transparent 28%),
        radial-gradient(circle at 82% 68%, rgba(164, 98, 255, 0.1), transparent 26%);
    animation: dashboardGlowShift 13s ease-in-out infinite alternate;
    z-index: 0;
}

@keyframes dashboardGlowShift {
    from { transform: translate3d(0, 0, 0) scale(1); }
    to { transform: translate3d(-1.5%, 1.5%, 0) scale(1.03); }
}

.page-dashboard main,
.page-dashboard header,
.page-dashboard nav {
    position: relative;
    z-index: 1;
}

.page-dashboard .nav-links a.active {
    background: linear-gradient(135deg, rgba(66, 238, 255, 0.9), rgba(118, 102, 255, 0.9));
    box-shadow: 0 0 0 1px rgba(146, 238, 255, 0.36), 0 12px 28px rgba(73, 148, 255, 0.32);
}

.page-dashboard .nav-ai-badge {
    display: inline-flex;
}

.page-dashboard .nav-links a:hover {
    border-color: rgba(100, 224, 255, 0.28);
    box-shadow: 0 10px 22px rgba(15, 44, 95, 0.24);
}

.page-dashboard .dashboard-hero {
    border-radius: 20px;
    overflow: hidden;
    background:
        radial-gradient(circle at 92% 8%, rgba(88, 229, 255, 0.18), transparent 35%),
        radial-gradient(circle at 16% 86%, rgba(169, 103, 255, 0.14), transparent 42%),
        linear-gradient(150deg, rgba(8, 23, 54, 0.92), rgba(18, 14, 48, 0.9));
}

.page-dashboard .dashboard-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.page-dashboard .dashboard-kpi-card {
    border-radius: 18px;
    background:
        linear-gradient(160deg, rgba(8, 25, 67, 0.78), rgba(14, 14, 48, 0.72)) padding-box,
        linear-gradient(125deg, rgba(103, 231, 255, 0.42), rgba(121, 121, 255, 0.36), rgba(230, 106, 255, 0.44)) border-box;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 14px 36px rgba(4, 12, 36, 0.44);
}

.page-dashboard a.dashboard-kpi-card:hover .dashboard-kpi-icon::before {
    opacity: 1;
    transform: scale(1.08);
}

.page-dashboard .dashboard-kpi-icon {
    box-shadow: 0 0 0 1px rgba(139, 212, 255, 0.18), 0 10px 24px rgba(8, 18, 50, 0.48);
}

.page-dashboard .dashboard-kpi-value {
    font-size: clamp(1.65rem, 2.4vw, 2rem);
    font-weight: 800;
}

.activity-stream {
    position: relative;
    padding-left: 0.35rem;
}

.activity-stream::before {
    content: "";
    position: absolute;
    top: 0.45rem;
    bottom: 0.45rem;
    left: 1.1rem;
    width: 2px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(107, 241, 255, 0.72), rgba(144, 104, 255, 0.38));
    opacity: 0.6;
}

.page-dashboard .dashboard-activity-item {
    position: relative;
    border-color: rgba(143, 179, 255, 0.17);
    background: linear-gradient(150deg, rgba(16, 28, 68, 0.62), rgba(13, 16, 47, 0.58));
}

.page-dashboard .dashboard-activity-item .dashboard-activity-icon {
    position: relative;
    z-index: 1;
}

.page-dashboard .dashboard-thread-row,
.page-dashboard .dashboard-file-item,
.page-dashboard .dashboard-alert-item {
    border-color: rgba(143, 179, 255, 0.17);
    background: linear-gradient(150deg, rgba(15, 27, 63, 0.58), rgba(12, 15, 44, 0.54));
}

.page-dashboard .dashboard-alert-item .ui-status-badge {
    justify-self: start;
}

.risk-badge {
    border-width: 1px;
    box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}

.risk-badge--critical {
    border-color: rgba(255, 123, 149, 0.75) !important;
    background: rgba(255, 82, 117, 0.16) !important;
    color: #ffd2dd !important;
    box-shadow: 0 0 18px rgba(255, 87, 124, 0.32);
}

.risk-badge--upcoming {
    border-color: rgba(255, 186, 103, 0.65) !important;
    background: rgba(255, 159, 67, 0.13) !important;
    color: #ffe5c3 !important;
}

.risk-badge--payment {
    border-color: rgba(112, 230, 255, 0.65) !important;
    background: rgba(82, 183, 255, 0.13) !important;
    color: #d5efff !important;
}

.page-dashboard .ui-role-badge.ai-badge {
    min-height: 30px;
    padding-left: 0.68rem;
    padding-right: 0.68rem;
    font-size: 0.68rem;
}

.page-dashboard .ui-role-badge.ai-badge.ui-role-yonetici {
    border-color: rgba(255, 116, 131, 0.45);
    background: rgba(241, 79, 103, 0.18);
    color: #ffdbe1;
}

.page-dashboard .ui-role-badge.ai-badge.ui-role-musteri {
    border-color: rgba(101, 210, 255, 0.45);
    background: rgba(56, 149, 255, 0.17);
    color: #d7e9ff;
}

.page-dashboard .neo-glass-table-wrap {
    border: 1px solid rgba(145, 184, 255, 0.18);
    border-radius: 16px;
    overflow: hidden;
    background: linear-gradient(160deg, rgba(15, 29, 67, 0.62), rgba(11, 13, 43, 0.65));
}

.page-dashboard .neo-glass-table {
    background: transparent;
}

.page-dashboard .neo-glass-table thead th {
    background: rgba(143, 185, 255, 0.11);
    border-bottom-color: rgba(145, 184, 255, 0.24);
}

.page-dashboard .neo-glass-table tbody tr {
    transition: background-color 0.2s ease;
}

.page-dashboard .neo-glass-table tbody tr:hover {
    background: rgba(98, 183, 255, 0.1);
}

.page-dashboard .dashboard-project-status {
    box-shadow: 0 0 12px rgba(140, 188, 255, 0.22);
}

@media (max-width: 768px) {
    .nav-links-wrap {
        width: 100%;
    }

    .nav-ai-badge {
        display: none;
    }

    .page-dashboard .dashboard-actions {
        justify-content: flex-start;
    }

    .page-dashboard .dashboard-actions .ai-badge {
        order: -1;
    }

    .activity-stream::before {
        display: none;
    }
}
