/* CardAxis Web Styles */
:root {
    --primary-color: #3b82f6;
    --primary-dark: #2563eb;
    --secondary-color: #64748b;
    --success-color: #22c55e;
    --warning-color: #f59e0b;
    --danger-color: #ef4444;
    --info-color: #06b6d4;
    --background-color: #f8fafc;
    --sidebar-bg: #1e293b;
    --sidebar-text: #e2e8f0;
    --card-bg: #ffffff;
    --text-primary: #1e293b;
    --text-secondary: #64748b;
    --border-color: #e2e8f0;
}

* {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, 'Roboto', sans-serif;
    background-color: var(--background-color);
    color: var(--text-primary);
    line-height: 1.5;
}

/* Page Layout */
.page {
    display: flex;
    min-height: 100vh;
}

.sidebar {
    width: 260px;
    background-color: var(--sidebar-bg);
    position: fixed;
    height: 100vh;
    overflow-y: auto;
    z-index: 100;
}

main {
    flex: 1;
    margin-left: 260px;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.top-row {
    background-color: var(--card-bg);
    border-bottom: 1px solid var(--border-color);
    padding: 0.75rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 50;
}

.top-row-right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.app-name {
    font-weight: 600;
    font-size: 1.1rem;
}

.content {
    flex: 1;
    padding: 1.5rem;
}

/* Navigation Menu */
.nav-menu {
    padding: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.nav-brand {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.nav-brand a {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
}

.brand-icon {
    color: var(--primary-color);
    display: flex;
    align-items: center;
}

.brand-text {
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
}

.nav-items {
    display: flex;
    flex-direction: column;
    padding: 1rem 0;
    flex: 1;
}

.nav-section {
    padding: 0.5rem 0;
}

.nav-section-title {
    display: block;
    padding: 0.5rem 1.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.4);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.nav-section-bottom {
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1rem;
}

/* Pinned navigation section (quick access) */
.nav-section-pinned {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding-bottom: 0.5rem;
    margin-bottom: 0.5rem;
}

/* Scrollable area for collapsible sections */
.nav-scrollable {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Collapsible section styles */
.nav-section-collapsible {
    padding: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.nav-section-collapsible:last-child {
    border-bottom: none;
}

/* Reset button defaults and apply navigation header styles */
.nav-menu .nav-section-collapsible > button,
.nav-menu button.nav-section-header,
button.nav-section-header {
    /* Nuclear reset - removes ALL inherited/default styles */
    all: unset;
    box-sizing: border-box;

    /* Required button behaviors */
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;

    /* Apply our styles */
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.75rem 1.5rem;
    background-color: transparent !important;
    background: transparent !important;
    color: rgba(255, 255, 255, 0.5) !important;
    transition: all 0.2s ease;
    text-align: left;
    font-size: 0.875rem;
    font-family: inherit;
    font-weight: normal;
    line-height: 1.5;
}

.nav-menu .nav-section-collapsible > button:hover,
.nav-menu button.nav-section-header:hover,
button.nav-section-header:hover {
    background-color: rgba(255, 255, 255, 0.05) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: rgba(255, 255, 255, 0.8) !important;
}

.nav-menu .nav-section-collapsible > button:focus,
.nav-menu button.nav-section-header:focus,
button.nav-section-header:focus {
    outline: none !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    background: rgba(255, 255, 255, 0.05) !important;
}

.nav-menu .nav-section-collapsible > button.expanded,
.nav-menu button.nav-section-header.expanded,
button.nav-section-header.expanded {
    color: rgba(255, 255, 255, 0.9) !important;
    background-color: rgba(255, 255, 255, 0.03) !important;
    background: rgba(255, 255, 255, 0.03) !important;
}

.nav-section-header .nav-section-title {
    display: block;
    padding: 0;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: inherit;
}

.nav-section-chevron {
    display: flex;
    align-items: center;
    transition: transform 0.25s ease;
    opacity: 0.6;
    color: inherit;
}

.nav-menu .nav-section-collapsible > button:hover .nav-section-chevron,
.nav-section-header:hover .nav-section-chevron {
    opacity: 1;
}

.nav-menu .nav-section-collapsible > button.expanded .nav-section-chevron,
.nav-section-header.expanded .nav-section-chevron {
    transform: rotate(180deg);
    opacity: 1;
}

/* Collapsible content - hidden by default */
.nav-section-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.25s ease-out;
    background-color: rgba(0, 0, 0, 0.15);
}

/* Expanded state - show content */
.nav-section-content.expanded {
    max-height: 600px;
    transition: max-height 0.35s ease-in;
}

/* Indent links inside collapsible sections */
.nav-section-content .nav-link {
    padding-left: 2.25rem;
    font-size: 0.9rem;
}

.nav-section-content .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

.nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.5rem;
    color: var(--sidebar-text);
    text-decoration: none;
    transition: all 0.2s;
}

.nav-link:hover {
    background-color: rgba(255, 255, 255, 0.05);
    color: #fff;
}

.nav-link.active {
    background-color: var(--primary-color);
    color: #fff;
}

.nav-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.5rem;
}

/* User Menu */
.user-menu {
    position: relative;
}

.user-menu-button {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem;
    background: none;
    border: none;
    cursor: pointer;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
}

.user-menu-button:hover {
    background-color: var(--background-color);
}

.user-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background-color: var(--primary-color);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 600;
}

.user-name {
    font-weight: 500;
    font-size: 0.875rem;
}

.dropdown-arrow {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.user-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    background-color: var(--card-bg);
    border-radius: 0.5rem;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
    border: 1px solid var(--border-color);
    min-width: 200px;
    overflow: hidden;
    z-index: 100;
}

.user-dropdown hr {
    margin: 0;
    border: none;
    border-top: 1px solid var(--border-color);
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    text-decoration: none;
    color: var(--text-primary);
    background: none;
    border: none;
    width: 100%;
    cursor: pointer;
    font-size: 0.875rem;
    transition: background-color 0.2s;
}

.dropdown-item:hover {
    background-color: var(--background-color);
}

.dropdown-item.logout {
    color: var(--danger-color);
}

.dropdown-icon {
    width: 1.25rem;
    text-align: center;
}

/* Headings */
h1 {
    margin-bottom: 1.5rem;
    font-size: 1.75rem;
    font-weight: 700;
}

h2 {
    margin-bottom: 1rem;
    font-size: 1.25rem;
    font-weight: 600;
}

h3 {
    margin-bottom: 0.75rem;
    font-size: 1rem;
    font-weight: 600;
}

/* Dashboard Styles */
.dashboard {

}

.dashboard-header {
    margin-bottom: 2rem;
}

.welcome-message {
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* KPI Grid */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.kpi-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.kpi-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.kpi-icon.articles { background-color: #dbeafe; color: #2563eb; }
.kpi-icon.inventory { background-color: #dcfce7; color: #16a34a; }
.kpi-icon.offers { background-color: #fef3c7; color: #d97706; }
.kpi-icon.connectors { background-color: #e0e7ff; color: #4f46e5; }

.kpi-content {
    flex: 1;
}

.kpi-value {
    display: block;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
}

.kpi-label {
    display: block;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Stats Row */
.stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 2rem;
}

.stat-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.25rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border-left: 4px solid var(--border-color);
}

.stat-card.warning { border-left-color: var(--warning-color); }
.stat-card.info { border-left-color: var(--info-color); }
.stat-card.success { border-left-color: var(--success-color); }

.stat-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.stat-title {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.stat-badge {
    font-size: 0.625rem;
    padding: 0.25rem 0.5rem;
    border-radius: 1rem;
    background-color: var(--warning-color);
    color: #fff;
    font-weight: 600;
    text-transform: uppercase;
}

.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
}

.stat-description {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Quick Actions */
.quick-actions-section {
    margin-bottom: 2rem;
}

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

.action-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    text-align: center;
    text-decoration: none;
    color: var(--text-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: all 0.2s;
    border: 2px solid transparent;
}

.action-card:hover {
    border-color: var(--primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.action-icon {
    width: 3rem;
    height: 3rem;
    margin: 0 auto 0.75rem;
    background-color: var(--background-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: var(--primary-color);
}

/* Activity Section */
.activity-section {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    margin-bottom: 2rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.activity-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.activity-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

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

.activity-text {
    font-size: 0.875rem;
}

.activity-time {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.activity-empty {
    text-align: center;
    padding: 2rem;
    color: var(--text-secondary);
}

/* License Section */
.license-section {
    margin-bottom: 2rem;
}

.license-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

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

.license-type {
    font-weight: 700;
    font-size: 1.125rem;
}

.license-status {
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.license-status.active {
    background-color: #dcfce7;
    color: #16a34a;
}

.license-usage {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.usage-item {
    display: grid;
    grid-template-columns: 80px 1fr 60px;
    align-items: center;
    gap: 1rem;
}

.usage-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.usage-bar {
    height: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
    overflow: hidden;
}

.usage-fill {
    height: 100%;
    background-color: var(--primary-color);
    border-radius: 0.25rem;
    transition: width 0.3s;
}

.usage-text {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-align: right;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 0.5rem;
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: all 0.2s;
}

.btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
}

.btn-lg {
    padding: 0.875rem 1.75rem;
    font-size: 1rem;
}

.btn-block {
    width: 100%;
}

.btn-primary {
    background-color: var(--primary-color);
    color: #fff;
}

.btn-primary:hover:not(:disabled) {
    background-color: var(--primary-dark);
}

.btn-outline {
    background-color: transparent;
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.btn-outline:hover:not(:disabled) {
    background-color: var(--background-color);
}

.btn-success {
    background-color: var(--success-color);
    color: #fff;
}

.btn-info {
    background-color: var(--info-color);
    color: #fff;
}

/* Forms */
.form-group {
    margin-bottom: 1.25rem;
}

.form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    font-size: 0.875rem;
}

.form-control {
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: #fff;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.form-control:disabled {
    background-color: var(--background-color);
    cursor: not-allowed;
}

.form-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.form-row .form-group {
    flex: 1;
    margin-bottom: 0;
}

.form-row .col {
    flex: 1;
}

.form-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.form-check-input {
    width: 1rem;
    height: 1rem;
    cursor: pointer;
}

.form-check-label {
    font-size: 0.875rem;
    cursor: pointer;
}

.password-requirements {
    margin-bottom: 1rem;
}

/* Alerts */
.alert {
    padding: 1rem;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    font-size: 0.875rem;
}

.alert-danger {
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.alert-success {
    background-color: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

/* Auth Pages */
.auth-layout {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
}

.auth-background {
    width: 100%;
    padding: 2rem;
}

.auth-content {
    margin: 0 auto;
}

.auth-container {
    display: flex;
    justify-content: center;
    align-items: center;
}

.auth-card {
    background-color: var(--card-bg);
    border-radius: 1rem;
    padding: 2.5rem;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.auth-card-wide {
    max-width: 500px;
}

.auth-header {
    text-align: center;
    margin-bottom: 2rem;
}

.auth-header h1 {
    font-size: 2rem;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
}

.auth-header p {
    color: var(--text-secondary);
    margin: 0;
}

.auth-form {
    margin-bottom: 1.5rem;
}

.auth-footer {
    text-align: center;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.auth-footer p {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.auth-footer a {
    color: var(--primary-color);
    font-weight: 500;
}

.license-info {
    margin-top: 1.5rem;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.license-info h4 {
    margin: 0 0 0.75rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.license-info ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.license-info li {
    padding: 0.25rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.license-info li::before {
    content: "✓";
    color: var(--success-color);
    margin-right: 0.5rem;
}

.spinner {
    width: 1rem;
    height: 1rem;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-right: 0.5rem;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ========================================
   Modern Landing Page Styles
   ======================================== */

.landing-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #0f172a 100%);
    overflow-x: hidden;
}

/* Landing Header */
.landing-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 3rem;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: rgba(15, 23, 42, 0.8);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    transition: all 0.3s ease;
}

.landing-header .logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.landing-header .logo-icon {
    color: var(--primary-color);
    display: flex;
    align-items: center;
}

.landing-header .logo-text h1 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
}

.landing-header .tagline {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.5);
    display: block;
    letter-spacing: 0.05em;
}

.landing-nav {
    display: flex;
    align-items: center;
    gap: 2rem;
}

.nav-link-landing {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    transition: color 0.2s;
}

.nav-link-landing:hover {
    color: #fff;
}

.nav-buttons {
    display: flex;
    gap: 0.75rem;
    margin-left: 1rem;
}

.landing-nav .btn-outline {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.2);
    background: transparent;
}

.landing-nav .btn-outline:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.3);
}

/* Hero Section */
.hero-section {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 4rem;
    padding: 8rem 4rem 4rem;
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
    width: 100%;
}

.hero-background {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}

.hero-gradient {
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle at 30% 30%, rgba(59, 130, 246, 0.15) 0%, transparent 50%),
                radial-gradient(circle at 70% 70%, rgba(139, 92, 246, 0.1) 0%, transparent 50%);
    animation: gradientMove 20s ease-in-out infinite;
}

@keyframes gradientMove {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    50% { transform: translate(-5%, -5%) rotate(5deg); }
}

.hero-particles {
    position: absolute;
    inset: 0;
}

.particle {
    position: absolute;
    width: 4px;
    height: 4px;
    background: rgba(59, 130, 246, 0.5);
    border-radius: 50%;
    animation: particleFloat 15s ease-in-out infinite;
}

.particle-1 { top: 20%; left: 10%; animation-delay: 0s; }
.particle-2 { top: 40%; left: 80%; animation-delay: -3s; }
.particle-3 { top: 70%; left: 20%; animation-delay: -6s; }
.particle-4 { top: 60%; left: 70%; animation-delay: -9s; }

@keyframes particleFloat {
    0%, 100% { transform: translateY(0) scale(1); opacity: 0.5; }
    50% { transform: translateY(-30px) scale(1.5); opacity: 1; }
}

.hero-content {
    position: relative;
    z-index: 1;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.2);
    border-radius: 2rem;
    color: #60a5fa;
    font-size: 0.875rem;
    margin-bottom: 1.5rem;
}

.badge-icon {
    font-size: 1rem;
}

.hero-title {
    font-size: 3.5rem;
    font-weight: 800;
    color: #fff;
    line-height: 1.1;
    margin: 0 0 1.5rem;
}

.hero-title .highlight {
    background: linear-gradient(135deg, #60a5fa, #a78bfa);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero-subtitle {
    font-size: 1.25rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.7;
    margin-bottom: 2rem;
}

.hero-cta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 3rem;
}

.btn-xl {
    padding: 1rem 2rem;
    font-size: 1rem;
    font-weight: 600;
}

.btn-xl svg {
    transition: transform 0.2s;
}

.btn-xl:hover svg {
    transform: translateX(4px);
}

.cta-note {
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.5);
}

.hero-stats {
    display: flex;
    align-items: center;
    gap: 2rem;
}

.hero-stats .stat-item {
    text-align: left;
}

.hero-stats .stat-number {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    color: #fff;
}

.hero-stats .stat-label {
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.5);
}

.stat-divider {
    width: 1px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
}

/* Hero Visual / Dashboard Preview */
.hero-visual {
    position: relative;
    z-index: 1;
}

.dashboard-preview {
    background: #1e293b;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5),
                0 0 0 1px rgba(255, 255, 255, 0.05);
    transform: perspective(1000px) rotateY(-5deg) rotateX(5deg);
    transition: transform 0.5s ease;
}

.dashboard-preview:hover {
    transform: perspective(1000px) rotateY(0deg) rotateX(0deg);
}

.preview-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 1rem;
    background: #0f172a;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.preview-dots {
    display: flex;
    gap: 0.375rem;
}

.preview-dots span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
}

.preview-dots span:first-child { background: #ef4444; }
.preview-dots span:nth-child(2) { background: #f59e0b; }
.preview-dots span:last-child { background: #22c55e; }

.preview-title {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.5);
}

.preview-content {
    display: flex;
    min-height: 280px;
}

.preview-sidebar {
    width: 60px;
    background: #0f172a;
    padding: 1rem 0.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.preview-menu-item {
    height: 36px;
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.05);
}

.preview-menu-item.active {
    background: var(--primary-color);
}

.preview-main {
    flex: 1;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.preview-cards {
    display: flex;
    gap: 0.75rem;
}

.preview-card {
    flex: 1;
    height: 60px;
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.05);
}

.preview-card.blue { background: linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%); }
.preview-card.green { background: linear-gradient(135deg, #22c55e 0%, #4ade80 100%); }
.preview-card.orange { background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%); }

.preview-chart {
    flex: 1;
    border-radius: 0.5rem;
    background: linear-gradient(180deg, rgba(59, 130, 246, 0.2) 0%, rgba(59, 130, 246, 0.05) 100%);
    position: relative;
    overflow: hidden;
}

.preview-chart::after {
    content: '';
    position: absolute;
    bottom: 20%;
    left: 5%;
    right: 5%;
    height: 2px;
    background: linear-gradient(90deg,
        transparent,
        rgba(59, 130, 246, 0.3) 10%,
        rgba(59, 130, 246, 0.8) 30%,
        rgba(59, 130, 246, 0.5) 60%,
        rgba(59, 130, 246, 0.9) 80%,
        transparent
    );
    border-radius: 1rem;
}

/* Animations */
.animate-fade-in {
    animation: fadeIn 0.6s ease-out forwards;
}

.animate-slide-up {
    animation: slideUp 0.8s ease-out forwards;
}

.animate-slide-up-delay {
    animation: slideUp 0.8s ease-out 0.2s forwards;
    opacity: 0;
}

.animate-fade-in-delay {
    animation: fadeIn 0.6s ease-out 0.4s forwards;
    opacity: 0;
}

.animate-fade-in-delay-2 {
    animation: fadeIn 0.6s ease-out 0.6s forwards;
    opacity: 0;
}

.animate-float {
    animation: float 6s ease-in-out infinite;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes float {
    0%, 100% { transform: translateY(0) perspective(1000px) rotateY(-5deg) rotateX(5deg); }
    50% { transform: translateY(-10px) perspective(1000px) rotateY(-5deg) rotateX(5deg); }
}

/* Trusted Section */
.trusted-section {
    background: rgba(255, 255, 255, 0.02);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding: 2rem 0;
}

.trusted-text {
    text-align: center;
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.8125rem;
    margin-bottom: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.trusted-logos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    flex-wrap: wrap;
}

.logo-item {
    color: rgba(255, 255, 255, 0.3);
    font-size: 0.875rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    transition: color 0.2s;
}

.logo-item:hover {
    color: rgba(255, 255, 255, 0.6);
}

/* Section Styling */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 2rem;
}

.section-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 4rem;
}

.section-badge {
    display: inline-block;
    padding: 0.375rem 1rem;
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.2);
    border-radius: 2rem;
    color: #60a5fa;
    font-size: 0.8125rem;
    font-weight: 600;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.section-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0 0 1rem;
    line-height: 1.2;
}

.section-subtitle {
    font-size: 1.125rem;
    color: var(--text-secondary);
    line-height: 1.7;
    margin: 0;
}

/* Features Section */
.features-section {
    background: #fff;
    padding: 6rem 0;
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

.feature-card-new {
    background: var(--background-color);
    border-radius: 1rem;
    padding: 2rem;
    transition: all 0.3s ease;
    border: 1px solid transparent;
}

.feature-card-new:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px -12px rgba(0, 0, 0, 0.1);
    border-color: var(--primary-color);
}

.feature-icon-wrapper {
    width: 56px;
    height: 56px;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.25rem;
}

.feature-icon-wrapper.blue { background: #dbeafe; color: #2563eb; }
.feature-icon-wrapper.green { background: #dcfce7; color: #16a34a; }
.feature-icon-wrapper.purple { background: #ede9fe; color: #7c3aed; }
.feature-icon-wrapper.orange { background: #fef3c7; color: #d97706; }
.feature-icon-wrapper.cyan { background: #cffafe; color: #0891b2; }
.feature-icon-wrapper.red { background: #fef2f2; color: #dc2626; }

.feature-card-new h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 0.75rem;
}

.feature-card-new p {
    color: var(--text-secondary);
    margin: 0 0 1.25rem;
    line-height: 1.6;
}

.feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.feature-list li {
    font-size: 0.875rem;
    color: var(--text-secondary);
    padding: 0.375rem 0;
    padding-left: 1.25rem;
    position: relative;
}

.feature-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.75rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--primary-color);
}

/* All-in-One Section */
.allinone-section {
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
    padding: 6rem 0;
}

.allinone-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.allinone-text .section-badge {
    margin-bottom: 1rem;
}

.allinone-text .section-title {
    text-align: left;
}

.allinone-text .section-subtitle {
    text-align: left;
    margin-bottom: 2rem;
}

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

.benefit-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1rem;
    color: var(--text-primary);
}

.benefit-check {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #dcfce7;
    color: #16a34a;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.allinone-visual {
    display: flex;
    justify-content: center;
    align-items: center;
}

.connection-diagram {
    position: relative;
    width: 350px;
    height: 350px;
}

.center-hub {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 0.875rem;
    box-shadow: 0 10px 40px rgba(59, 130, 246, 0.4);
    z-index: 2;
}

.connection-line {
    position: absolute;
    background: linear-gradient(90deg, rgba(59, 130, 246, 0.2), rgba(59, 130, 246, 0.5));
    height: 3px;
    border-radius: 2px;
    top: 50%;
    left: 50%;
    transform-origin: left center;
    z-index: 1;
}

.connection-line.line-1 { width: 100px; transform: translateY(-50%) rotate(-45deg); }
.connection-line.line-2 { width: 100px; transform: translateY(-50%) rotate(45deg); }
.connection-line.line-3 { width: 100px; transform: translateY(-50%) rotate(135deg); }
.connection-line.line-4 { width: 100px; transform: translateY(-50%) rotate(225deg); }

.connected-item {
    position: absolute;
    padding: 0.75rem 1.25rem;
    background: #fff;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    z-index: 2;
}

.connected-item.item-1 { top: 10%; left: 60%; }
.connected-item.item-2 { top: 60%; left: 75%; }
.connected-item.item-3 { top: 75%; left: 25%; }
.connected-item.item-4 { top: 15%; left: 5%; }

/* Integrations Section */
.integrations-section {
    background: #fff;
    padding: 6rem 0;
}

.integrations-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-bottom: 3rem;
}

.integration-card {
    background: var(--background-color);
    border-radius: 1rem;
    padding: 2rem;
    text-align: center;
    position: relative;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.integration-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px -12px rgba(0, 0, 0, 0.1);
}

.integration-card.active {
    border-color: #dcfce7;
}

.integration-card.active:hover {
    border-color: #22c55e;
}

.integration-card.coming-soon {
    opacity: 0.7;
}

.integration-status {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    background: #dcfce7;
    color: #16a34a;
}

.integration-status.soon {
    background: #fef3c7;
    color: #d97706;
}

.integration-logo {
    color: var(--text-secondary);
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
}

.integration-card h3 {
    font-size: 1.125rem;
    margin: 0 0 0.5rem;
}

.integration-card p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0;
    line-height: 1.6;
}

.integrations-cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
}

.integrations-cta p {
    color: var(--text-secondary);
    margin: 0;
}

/* How It Works Section */
.howitworks-section {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    padding: 6rem 0;
}

.howitworks-section .section-badge {
    background: rgba(59, 130, 246, 0.2);
    border-color: rgba(59, 130, 246, 0.3);
}

.howitworks-section .section-title {
    color: #fff;
}

.steps-grid {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
}

.step-card {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1rem;
    padding: 2rem;
    text-align: center;
    max-width: 280px;
}

.step-number {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 auto 1rem;
}

.step-card h3 {
    color: #fff;
    font-size: 1.125rem;
    margin: 0 0 0.75rem;
}

.step-card p {
    color: rgba(255, 255, 255, 0.6);
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.6;
}

.step-connector {
    color: rgba(255, 255, 255, 0.2);
}

/* Pricing Section */
.pricing-section {
    background: #fff;
    padding: 6rem 0;
}

.pricing-grid-new {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}

.pricing-card-new {
    background: var(--background-color);
    border-radius: 1rem;
    padding: 2rem;
    position: relative;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.pricing-card-new:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px -12px rgba(0, 0, 0, 0.1);
}

.pricing-card-new.featured {
    border-color: var(--primary-color);
    background: #fff;
    box-shadow: 0 20px 40px -12px rgba(59, 130, 246, 0.2);
}

.popular-badge-new {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    color: #fff;
    padding: 0.375rem 1rem;
    border-radius: 2rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.pricing-header-new {
    text-align: center;
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.pricing-header-new h3 {
    font-size: 1.25rem;
    margin: 0 0 0.75rem;
}

.pricing-price {
    margin-bottom: 0.5rem;
}

.price-amount {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.price-period {
    font-size: 1rem;
    color: var(--text-secondary);
}

.pricing-description {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0;
}

.pricing-features-new {
    margin-bottom: 1.5rem;
}

.feature-item-price {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.feature-item-price svg {
    color: #22c55e;
    flex-shrink: 0;
}

.feature-item-price.disabled {
    color: var(--text-secondary);
}

.feature-item-price.disabled svg {
    color: var(--text-secondary);
}

/* CTA Section */
.cta-section {
    background: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);
    padding: 5rem 0;
}

.cta-content {
    text-align: center;
    max-width: 700px;
    margin: 0 auto;
}

.cta-content h2 {
    font-size: 2.5rem;
    font-weight: 700;
    color: #fff;
    margin: 0 0 1rem;
}

.cta-content p {
    font-size: 1.125rem;
    color: rgba(255, 255, 255, 0.9);
    margin: 0 0 2rem;
}

.cta-buttons {
    display: flex;
    justify-content: center;
    gap: 1rem;
}

.btn-outline-white {
    background: transparent;
    color: #fff;
    border: 2px solid rgba(255, 255, 255, 0.3);
    padding: 1rem 2rem;
    font-size: 1rem;
    font-weight: 600;
}

.btn-outline-white:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.5);
}

.cta-section .btn-primary {
    background: #fff;
    color: #3b82f6;
}

.cta-section .btn-primary:hover {
    background: #f8fafc;
}

/* Footer */
.landing-footer-new {
    background: #0f172a;
    color: #fff;
    padding: 4rem 0 2rem;
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 3rem;
    margin-bottom: 3rem;
}

.footer-brand .footer-logo {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    color: #fff;
}

.footer-brand .footer-logo span {
    font-size: 1.25rem;
    font-weight: 700;
}

.footer-brand p {
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.875rem;
    line-height: 1.7;
    margin: 0;
}

.footer-links-section h4 {
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    margin: 0 0 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.footer-links-section ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links-section li {
    margin-bottom: 0.5rem;
}

.footer-links-section a {
    color: rgba(255, 255, 255, 0.5);
    text-decoration: none;
    font-size: 0.875rem;
    transition: color 0.2s;
}

.footer-links-section a:hover {
    color: #fff;
}

.footer-bottom {
    padding-top: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer-bottom p {
    margin: 0;
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.4);
}

.footer-tagline {
    font-style: italic;
}

/* Landing Page Responsive */
@media (max-width: 1200px) {
    .pricing-grid-new {
        grid-template-columns: repeat(2, 1fr);
    }

    .integrations-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 992px) {
    .hero-section {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 7rem 2rem 4rem;
    }

    .hero-title {
        font-size: 2.5rem;
    }

    .hero-cta {
        align-items: center;
    }

    .hero-stats {
        justify-content: center;
    }

    .hero-visual {
        display: none;
    }

    .features-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .allinone-content {
        grid-template-columns: 1fr;
        gap: 3rem;
    }

    .allinone-text .section-title,
    .allinone-text .section-subtitle {
        text-align: center;
    }

    .benefit-list {
        align-items: center;
    }

    .steps-grid {
        flex-direction: column;
    }

    .step-connector {
        transform: rotate(90deg);
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .landing-header {
        padding: 1rem 1.5rem;
    }

    .nav-link-landing {
        display: none;
    }

    .nav-buttons {
        margin-left: 0;
    }

    .hero-section {
        padding: 6rem 1.5rem 3rem;
    }

    .hero-title {
        font-size: 2rem;
    }

    .hero-stats {
        flex-direction: column;
        gap: 1rem;
    }

    .stat-divider {
        display: none;
    }

    .features-grid,
    .pricing-grid-new,
    .integrations-grid {
        grid-template-columns: 1fr;
    }

    .section-title {
        font-size: 2rem;
    }

    .cta-buttons {
        flex-direction: column;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 0.5rem;
        text-align: center;
    }
}

/* Loading */
.loading-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4rem;
}

.loading-spinner {
    width: 3rem;
    height: 3rem;
    border: 3px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-bottom: 1rem;
}

/* Error Page */
.error-page {
    text-align: center;
    padding: 4rem 2rem;
}

.error-page h1 {
    font-size: 4rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

/* Validation */
.validation-message {
    color: var(--danger-color);
    font-size: 0.75rem;
    margin-top: 0.25rem;
}

/* Container */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1rem;
}

/* Text utilities */
.text-muted {
    color: var(--text-secondary);
}

/* Responsive */
@media (max-width: 768px) {
    .sidebar {
        display: none;
    }

    main {
        margin-left: 0;
    }

    .page {
        flex-direction: column;
    }

    .kpi-grid {
        grid-template-columns: 1fr;
    }

    .stats-row {
        grid-template-columns: 1fr;
    }

    .action-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .form-row {
        flex-direction: column;
    }

    .hero h2 {
        font-size: 2rem;
    }

    .pricing-grid {
        grid-template-columns: 1fr;
    }

    .footer-content {
        flex-direction: column;
        text-align: center;
    }

    .footer-links {
        flex-direction: column;
        gap: 1rem;
    }
}

/* ========================================
   Article Management Styles
   ======================================== */

/* Page Header */
.articles-page,
.article-form-page,
.article-detail-page {

}

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

.header-content h1 {
    margin: 0 0 0.25rem 0;
}

.page-subtitle {
    color: var(--text-secondary);
    margin: 0;
}

.header-actions {
    display: flex;
    gap: 0.75rem;
}

.btn-back {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: none;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    cursor: pointer;
    color: var(--text-secondary);
    font-size: 0.875rem;
    transition: all 0.2s;
}

.btn-back:hover {
    background-color: var(--background-color);
    color: var(--text-primary);
}

/* Secondary Button */
.btn-secondary {
    background-color: var(--background-color);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.btn-secondary:hover:not(:disabled) {
    background-color: #e2e8f0;
}

/* Danger Button */
.btn-danger {
    background-color: var(--danger-color);
    color: #fff;
}

.btn-danger:hover:not(:disabled) {
    background-color: #dc2626;
}

/* Button Icon */
.btn-icon {
    font-weight: 700;
}

/* Filter Bar */
.filter-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding: 1rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.search-box {
    display: flex;
    flex: 1;
    max-width: 400px;
}

.search-box input {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem 0 0 0.5rem;
    font-size: 0.875rem;
}

.search-box input:focus {
    outline: none;
    border-color: var(--primary-color);
}

.search-btn {
    padding: 0.75rem 1rem;
    background-color: var(--primary-color);
    color: #fff;
    border: none;
    border-radius: 0 0.5rem 0.5rem 0;
    cursor: pointer;
    display: flex;
    align-items: center;
}

.search-btn:hover {
    background-color: var(--primary-dark);
}

.filter-group {
    display: flex;
    gap: 0.75rem;
}

.filter-group select {
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    background-color: #fff;
    cursor: pointer;
}

/* Articles Grid */
.articles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}

.article-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s;
    border: 2px solid transparent;
}

.article-card:hover {
    border-color: var(--primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.article-image {
    height: 160px;
    background-color: var(--background-color);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.article-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.placeholder-image {
    color: var(--border-color);
}

.article-badge {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    padding: 0.25rem 0.75rem;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 1rem;
}

.article-badge.standalone {
    background-color: #dbeafe;
    color: #2563eb;
}

.article-badge.linked {
    background-color: #dcfce7;
    color: #16a34a;
}

.article-content {
    padding: 1rem;
}

.article-sku {
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-family: monospace;
}

.article-name {
    margin: 0.25rem 0 0.75rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.article-prices {
    display: flex;
    gap: 1rem;
    font-size: 0.875rem;
    margin-bottom: 0.5rem;
}

.price-label {
    color: var(--text-secondary);
}

.price-value {
    font-weight: 600;
}

.price-value.selling {
    color: var(--success-color);
}

.article-location {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.article-actions {
    display: flex;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--border-color);
    background-color: var(--background-color);
}

.btn-icon-only {
    padding: 0.5rem;
    background: none;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all 0.2s;
}

.btn-icon-only:hover {
    background-color: var(--card-bg);
    color: var(--text-primary);
}

.btn-icon-only.danger:hover {
    background-color: #fef2f2;
    color: var(--danger-color);
    border-color: var(--danger-color);
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 4rem 2rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
}

.empty-icon {
    color: var(--border-color);
    margin-bottom: 1.5rem;
}

.empty-state h3 {
    margin-bottom: 0.5rem;
}

.empty-state p {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.empty-actions {
    display: flex;
    gap: 1rem;
    justify-content: center;
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    margin-top: 2rem;
    padding: 1rem;
}

.pagination-info {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Modal */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 1rem;
}

.modal-content {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    max-width: 400px;
    width: 100%;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.25);
}

.modal-content.modal-large {
    max-width: 600px;
}

.modal-content h3 {
    margin-top: 0;
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

/* Form Styles for Article Pages */
.form-container {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 2rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.form-section {
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--border-color);
}

.form-section:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
}

.form-section h2 {
    font-size: 1.125rem;
    margin-bottom: 1.25rem;
}

.form-hint {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-bottom: 1rem;
}

.input-group {
    display: flex;
}

.input-group input {
    flex: 1;
    border-radius: 0.5rem 0 0 0.5rem;
}

.input-suffix {
    padding: 0.75rem 1rem;
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
    border-left: none;
    border-radius: 0 0.5rem 0.5rem 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.price-info {
    display: flex;
    gap: 1rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.5rem;
}

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

.alert-error {
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
    padding: 1rem;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
}

/* Detail Page */
.detail-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.5rem;
}

.detail-main {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.detail-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.detail-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.detail-card h3 {
    margin-top: 0;
    font-size: 1rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.price-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 1.5rem;
}

.price-item {
    text-align: center;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.price-item.highlight {
    background-color: #dcfce7;
}

.price-item.margin {
    background-color: #dbeafe;
}

.price-item .price-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.price-item .price-value {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
}

.price-item .price-value.positive {
    color: var(--success-color);
}

.price-item .price-value.negative {
    color: var(--danger-color);
}

.info-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.info-item {
    display: flex;
    justify-content: space-between;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

.info-item:last-child {
    border-bottom: none;
}

.info-label {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.info-value {
    font-weight: 500;
    font-size: 0.875rem;
}

.visibility-private { color: var(--text-secondary); }
.visibility-shared { color: var(--info-color); }
.visibility-public { color: var(--success-color); }

.article-sku-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.linked-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background-color: #dcfce7;
    color: #16a34a;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 500;
}

.notes-content {
    white-space: pre-wrap;
    background-color: var(--background-color);
    padding: 1rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
}

.linked-article-content {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.linked-image {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 0.5rem;
}

.linked-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.linked-sku {
    font-family: monospace;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.linked-name {
    font-weight: 600;
}

.linked-category {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.linked-price {
    font-size: 0.875rem;
    color: var(--success-color);
    font-weight: 500;
}

.card-details {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.card-details span {
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
}

.badge.foil {
    background-color: #fef3c7;
    color: #d97706;
}

.info-banner {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background-color: #dbeafe;
    color: #2563eb;
    border-radius: 0.5rem;
    margin-bottom: 1.5rem;
    font-size: 0.875rem;
}

.original-value {
    color: var(--text-secondary);
    font-weight: 400;
    font-size: 0.75rem;
}

.edit-sku {
    font-family: monospace;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Global Articles List in Modal */
.global-articles-list {
    max-height: 300px;
    overflow-y: auto;
    margin: 1rem 0;
}

.global-article-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
    cursor: pointer;
    transition: all 0.2s;
}

.global-article-item:hover {
    background-color: var(--background-color);
    border-color: var(--primary-color);
}

.global-article-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.global-article-sku {
    font-family: monospace;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.global-article-name {
    font-weight: 500;
}

.global-article-price {
    font-weight: 600;
    color: var(--success-color);
}

.empty-message {
    text-align: center;
    color: var(--text-secondary);
    padding: 2rem;
}

.loading-container.small {
    padding: 2rem;
}

.loading-container.small .loading-spinner {
    width: 2rem;
    height: 2rem;
}

.loading-spinner-small {
    display: inline-block;
    width: 1rem;
    height: 1rem;
    border: 2px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.error-container {
    text-align: center;
    padding: 4rem 2rem;
}

.error-container h2 {
    margin-bottom: 0.5rem;
}

.error-container p {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

/* Responsive */
@media (max-width: 992px) {
    .detail-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .page-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .header-actions {
        width: 100%;
    }

    .header-actions .btn {
        flex: 1;
    }

    .filter-bar {
        flex-direction: column;
    }

    .search-box {
        max-width: none;
        width: 100%;
    }

    .filter-group {
        width: 100%;
    }

    .filter-group select {
        flex: 1;
    }

    .articles-grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   Category Management Styles
   ======================================== */

.categories-page,
.category-form-page {
    max-width: 1200px;
}

/* Category Tree Container */
.category-tree-container {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.category-tree {
    padding: 0.5rem 0;
}

/* Category Tree Item */
.category-tree-item {
    border-bottom: 1px solid var(--border-color);
}

.category-tree-item:last-child {
    border-bottom: none;
}

.category-tree-item.inactive {
    opacity: 0.6;
}

.category-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    transition: background-color 0.2s;
}

.category-item:hover {
    background-color: var(--background-color);
}

.category-toggle {
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--text-secondary);
    border-radius: 0.25rem;
    transition: all 0.2s;
}

.category-toggle:hover {
    background-color: var(--border-color);
    color: var(--text-primary);
}

.toggle-placeholder {
    width: 1rem;
    height: 1rem;
}

.category-icon {
    color: var(--primary-color);
    display: flex;
    align-items: center;
}

.category-info {
    flex: 1;
    min-width: 0;
}

.category-name {
    font-weight: 500;
    display: block;
}

.category-description {
    font-size: 0.75rem;
    color: var(--text-secondary);
    display: block;
    margin-top: 0.125rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.category-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-right: 1rem;
}

.children-count {
    font-size: 0.75rem;
    color: var(--text-secondary);
    background-color: var(--background-color);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
}

.status-badge {
    font-size: 0.625rem;
    padding: 0.25rem 0.5rem;
    border-radius: 1rem;
    font-weight: 600;
    text-transform: uppercase;
}

.status-badge.inactive {
    background-color: #fef2f2;
    color: #991b1b;
}

.article-badge.active {
    background-color: #dcfce7;
    color: #16a34a;
}

.article-badge.inactive {
    background-color: #fef2f2;
    color: #991b1b;
}

.category-actions {
    display: flex;
    gap: 0.375rem;
}

.category-children {
    border-top: 1px solid var(--border-color);
    background-color: rgba(0, 0, 0, 0.02);
}

/* Category Form Page */
.category-form-page .page-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.category-form-page .page-header h1 {
    margin: 0;
}

.category-path-display {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    margin-bottom: 1.5rem;
}

.path-label {
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.path-value {
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-primary);
}

/* Category Stats */
.category-stats {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.category-stats h2 {
    margin-top: 0;
    margin-bottom: 1rem;
    font-size: 1rem;
}

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

.stat-item {
    text-align: center;
    padding: 1rem;
    border-radius: 0.5rem;
}

.stat-item .stat-value {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

.stat-item .stat-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Unauthorized Container */
.unauthorized-container {
    text-align: center;
    padding: 4rem 2rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
}

.unauthorized-container h2 {
    margin-bottom: 0.5rem;
}

.unauthorized-container p {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

/* Warning Text */
.warning-text {
    color: var(--warning-color);
    font-size: 0.875rem;
    margin-top: 0.5rem;
}

/* Section Hint */
.section-hint {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-top: -0.5rem;
    margin-bottom: 1.25rem;
}

/* Checkbox Row */
.checkbox-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
}

/* Article Category in List */
.article-category {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.5rem;
}

/* Responsive for Categories */
@media (max-width: 768px) {
    .category-item {
        flex-wrap: wrap;
    }

    .category-meta {
        width: 100%;
        margin-top: 0.5rem;
        margin-right: 0;
        padding-left: calc(24px + 0.75rem);
    }

    .category-actions {
        width: 100%;
        justify-content: flex-end;
        margin-top: 0.5rem;
        padding-left: calc(24px + 0.75rem);
    }
}

/* ========================================
   Admin Pages Styles (Users, Roles, Licenses)
   ======================================== */

.users-page,
.user-form-page,
.user-details-page,
.roles-page,
.role-form-page,
.role-details-page,
.licenses-page,
.license-form-page,
.license-details-page {

}

/* Filter Section */
.filter-section {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.25rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-end;
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    min-width: 150px;
}

.filter-group label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.form-input,
.form-select {
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    background-color: #fff;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-input:focus,
.form-select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Data Table */
.table-container {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.data-table {
    width: 100%;
    border-collapse: collapse;
}

.data-table thead {
    background-color: var(--background-color);
}

.data-table th {
    padding: 0.875rem 1rem;
    text-align: left;
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}

.data-table th.sortable {
    cursor: pointer;
    user-select: none;
}

.data-table th.sortable:hover {
    background-color: #e2e8f0;
}

.sort-indicator {
    margin-left: 0.25rem;
    font-size: 0.625rem;
}

.data-table td {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.875rem;
}

.data-table tbody tr:hover {
    background-color: rgba(59, 130, 246, 0.02);
}

.data-table tbody tr:last-child td {
    border-bottom: none;
}

.actions-col {
    width: 120px;
    text-align: right;
}

.action-buttons {
    display: flex;
    gap: 0.375rem;
    justify-content: flex-end;
}

/* User Info in Table */
.user-info {
    display: flex;
    flex-direction: column;
}

.user-name {
    font-weight: 500;
}

/* License Key */
.license-key {
    font-family: monospace;
    font-size: 0.8125rem;
    padding: 0.25rem 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
}

/* Badge Styles */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    font-size: 0.6875rem;
    font-weight: 600;
    border-radius: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.badge-primary {
    background-color: #dbeafe;
    color: #2563eb;
}

.badge-secondary {
    background-color: #f1f5f9;
    color: #64748b;
}

.badge-success {
    background-color: #dcfce7;
    color: #16a34a;
}

.badge-warning {
    background-color: #fef3c7;
    color: #d97706;
}

.badge-danger {
    background-color: #fef2f2;
    color: #dc2626;
}

.badge-info {
    background-color: #cffafe;
    color: #0891b2;
}

/* Roles Grid */
.roles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
}

.role-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border: 2px solid transparent;
    transition: all 0.2s;
}

.role-card:hover {
    border-color: var(--primary-color);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.role-card.system-role {
    background-color: #f8fafc;
    border-color: var(--border-color);
}

.role-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.role-header h3 {
    margin: 0;
    font-size: 1.125rem;
}

.role-description {
    color: var(--text-secondary);
    font-size: 0.875rem;
    margin-bottom: 1rem;
    line-height: 1.5;
}

.role-stats {
    display: flex;
    gap: 1.5rem;
    margin-bottom: 1.25rem;
    padding: 0.875rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.role-stats .stat {
    text-align: center;
}

.role-stats .stat-value {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary-color);
}

.role-stats .stat-label {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
}

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

/* Permissions Section */
.permissions-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.permission-module {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    overflow: hidden;
}

.module-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 1rem;
    background-color: #f1f5f9;
    border-bottom: 1px solid var(--border-color);
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.module-checkbox .module-name {
    font-weight: 600;
    font-size: 0.9375rem;
}

.module-count {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.permission-list {
    padding: 0.5rem;
}

.permission-checkbox {
    padding: 0.625rem 0.75rem;
    border-radius: 0.375rem;
    transition: background-color 0.2s;
}

.permission-checkbox:hover {
    background-color: var(--card-bg);
}

.permission-info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.permission-name {
    font-size: 0.875rem;
}

.permission-description {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Details Grid */
.details-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

.details-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.details-card.span-2 {
    grid-column: span 2;
}

.details-card h3 {
    margin: 0 0 1.25rem;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
}

.details-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.details-list dt {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.125rem;
}

.details-list dd {
    margin: 0;
    font-size: 0.9375rem;
}

.details-list.horizontal {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

/* Status Section */
.status-section {
    text-align: center;
    margin-bottom: 1.25rem;
}

.status-badge-large {
    display: inline-block;
    padding: 0.5rem 1.25rem;
    font-size: 0.875rem;
    font-weight: 700;
    border-radius: 0.5rem;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

.status-badge-large.badge-success {
    background-color: #dcfce7;
    color: #16a34a;
}

.status-badge-large.badge-danger {
    background-color: #fef2f2;
    color: #dc2626;
}

.status-badge-large.badge-warning {
    background-color: #fef3c7;
    color: #d97706;
}

.status-info {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

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

/* Status Indicators */
.status-indicators {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.status-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.625rem;
    background-color: var(--background-color);
    border-radius: 0.375rem;
}

.status-label {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
}

/* Role List in User Details */
.role-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.role-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.role-item .role-name {
    font-weight: 500;
}

.role-meta {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Permissions by Module in Role Details */
.permissions-by-module {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.module-group {
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.module-title {
    margin: 0 0 0.75rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.permission-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.badge-permission {
    background-color: var(--card-bg);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
    font-size: 0.6875rem;
}

/* Feature and Connector Tags */
.feature-tags,
.connector-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.badge-feature {
    background-color: #dbeafe;
    color: #2563eb;
}

.badge-connector {
    background-color: #e0e7ff;
    color: #4f46e5;
}

/* Form Enhancements */
.form-section h3 {
    margin-top: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* License Type Selection */
.license-type-selection {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.license-type-card {
    padding: 1.25rem;
    background-color: var(--background-color);
    border: 2px solid transparent;
    border-radius: 0.75rem;
    cursor: pointer;
    transition: all 0.2s;
}

.license-type-card:hover {
    border-color: var(--border-color);
}

.license-type-card.selected {
    border-color: var(--primary-color);
    background-color: #eff6ff;
}

.license-type-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.license-type-header h4 {
    margin: 0;
    font-size: 1rem;
}

.checkmark {
    color: var(--primary-color);
    font-weight: 700;
}

.license-type-description {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
}

.license-features {
    list-style: none;
    padding: 0;
    margin: 0;
}

.license-features li {
    font-size: 0.75rem;
    color: var(--text-secondary);
    padding: 0.25rem 0;
    padding-left: 1rem;
    position: relative;
}

.license-features li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--success-color);
}

/* Quick Duration Buttons */
.quick-duration-buttons {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.75rem;
    flex-wrap: wrap;
}

.quick-duration-buttons .label {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

/* Role Selection */
.role-selection {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.role-checkbox {
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    transition: background-color 0.2s;
}

.role-checkbox:hover {
    background-color: #e2e8f0;
}

.role-info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.role-info .role-name {
    font-weight: 500;
}

.role-info .badge {
    margin-left: 0.5rem;
}

.role-info .role-description {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin: 0;
}

/* Checkbox Group */
.checkbox-group {
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

/* Not Found Container */
.not-found-container {
    text-align: center;
    padding: 4rem 2rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
}

.not-found-container h2 {
    margin-bottom: 0.5rem;
}

.not-found-container p {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

/* Info Row */
.info-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.info-row .info-item {
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.info-row .info-label {
    display: block;
    font-size: 0.6875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}

.info-row .info-value {
    display: block;
    font-weight: 500;
}

/* Status Actions */
.status-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

/* Warning Button */
.btn-warning {
    background-color: var(--warning-color);
    color: #fff;
}

.btn-warning:hover:not(:disabled) {
    background-color: #d97706;
}

/* Success Button */
.btn-success {
    background-color: var(--success-color);
    color: #fff;
}

.btn-success:hover:not(:disabled) {
    background-color: #16a34a;
}

/* Text Colors */
.text-warning {
    color: var(--warning-color);
}

.text-danger {
    color: var(--danger-color);
}

/* Stat Card Enhancements for License Stats */
.stat-card.danger {
    border-left-color: var(--danger-color);
}

/* Responsive Admin Pages */
@media (max-width: 992px) {
    .details-grid {
        grid-template-columns: 1fr;
    }

    .details-card.span-2 {
        grid-column: span 1;
    }
}

@media (max-width: 768px) {
    .filter-row {
        flex-direction: column;
    }

    .filter-group {
        width: 100%;
    }

    .data-table {
        font-size: 0.8125rem;
    }

    .data-table th,
    .data-table td {
        padding: 0.625rem 0.75rem;
    }

    .roles-grid {
        grid-template-columns: 1fr;
    }

    .license-type-selection {
        grid-template-columns: 1fr;
    }

    .status-indicators {
        grid-template-columns: 1fr;
    }
}

/* ================================
   Profile Page Styles
   ================================ */

.profile-page,
.profile-edit-page {
    max-width: 1200px;
    margin: 0 auto;
}

.profile-content {
    margin-top: 1.5rem;
}

.profile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 1.5rem;
}

.profile-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.profile-card .card-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background-color: #f8fafc;
}

.profile-card .card-header h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
}

.profile-card .card-body {
    padding: 1.5rem;
}

.profile-card.license-card {
    grid-column: span 2;
}

.info-grid {
    display: grid;
    gap: 1rem;
}

.info-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.info-label {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.info-value {
    font-size: 0.9375rem;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.role-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.no-license {
    text-align: center;
    padding: 2rem;
}

.no-license p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.license-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.license-type {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--primary-color);
}

.license-limits {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.license-limits h4 {
    margin: 0 0 1rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.limit-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.limit-item {
    text-align: center;
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.limit-item span {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.limit-item strong {
    display: block;
    font-size: 1rem;
    color: var(--text-primary);
}

/* Password Section */
.password-section {
    margin-top: 2rem;
}

/* ================================
   Settings Page Styles
   ================================ */

.settings-page {
    max-width: 1000px;
    margin: 0 auto;
}

.settings-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
    background-color: var(--card-bg);
    padding: 0.75rem;
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.tab-btn {
    padding: 0.625rem 1rem;
    border: none;
    background-color: transparent;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.tab-btn:hover {
    background-color: var(--background-color);
    color: var(--text-primary);
}

.tab-btn.active {
    background-color: var(--primary-color);
    color: white;
}

.settings-content {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    padding: 1.5rem;
}

.settings-section {
    max-width: 700px;
}

.section-header {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.section-header h3 {
    margin: 0 0 0.5rem;
    font-size: 1.125rem;
    font-weight: 600;
}

.section-header p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.highlight-box {
    background-color: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 0.5rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

.highlight-box .form-hint {
    margin-top: 0.5rem;
    margin-bottom: 0;
}

/* License Activation Styles */
.license-input {
    font-family: monospace;
    font-size: 1.125rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.license-active-info {
    background-color: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 0.75rem;
    padding: 1.5rem;
}

.license-badge {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.license-type-badge {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

.license-info-box {
    margin-top: 2rem;
    padding: 1.5rem;
    background-color: var(--background-color);
    border-radius: 0.75rem;
}

.license-info-box h4 {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    color: var(--text-primary);
}

.license-info-box p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Responsive Settings */
@media (max-width: 768px) {
    .settings-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
    }

    .tab-btn {
        white-space: nowrap;
        flex-shrink: 0;
    }

    .profile-card.license-card {
        grid-column: span 1;
    }

    .limit-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .profile-grid {
        grid-template-columns: 1fr;
    }
}

/* =====================================================
   PURCHASING MODULE STYLES
   ===================================================== */

/* Mail Accounts Grid */
.accounts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
    gap: 1.5rem;
}

.account-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border: 2px solid transparent;
    transition: all 0.2s;
    overflow: hidden;
}

.account-card:hover {
    border-color: var(--primary-color);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.account-card.inactive {
    background-color: #f8fafc;
    opacity: 0.8;
}

.account-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.25rem;
    background-color: #f8fafc;
    border-bottom: 1px solid var(--border-color);
}

.account-status {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 1rem;
    text-transform: uppercase;
}

.account-status.active {
    background-color: #dcfce7;
    color: #16a34a;
}

.account-status.inactive {
    background-color: #f1f5f9;
    color: #64748b;
}

.account-actions {
    display: flex;
    gap: 0.25rem;
}

.account-content {
    padding: 1.25rem;
}

.account-name {
    margin: 0 0 1rem;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
}

.account-details {
    display: grid;
    gap: 0.625rem;
}

.detail-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.875rem;
}

.detail-label {
    color: var(--text-secondary);
}

.detail-value {
    font-weight: 500;
    color: var(--text-primary);
}

.error-message {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-top: 1rem;
    padding: 0.75rem;
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 0.5rem;
    font-size: 0.8125rem;
    color: #dc2626;
}

.error-message svg {
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.account-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
    background-color: #f8fafc;
    border-top: 1px solid var(--border-color);
}

/* Stats Grid for Invoice Candidates */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.stat-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.25rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    text-align: center;
    border-left: 4px solid var(--border-color);
}

.stat-card.pending {
    border-left-color: #f59e0b;
}

.stat-card.success {
    border-left-color: #22c55e;
}

.stat-card.warning {
    border-left-color: #ef4444;
}

.stat-card.info {
    border-left-color: #3b82f6;
}

.stat-value {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
}

.stat-label {
    display: block;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* Summary Cards for Invoices */
.summary-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.summary-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.25rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    text-align: center;
}

.summary-card.highlight {
    background-color: #eff6ff;
    border: 1px solid #bfdbfe;
}

.summary-card .card-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.summary-card .card-label {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Filter Bar */
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    margin-bottom: 1.5rem;
}

.filter-bar .search-box {
    flex: 1;
    min-width: 250px;
    display: flex;
    gap: 0.5rem;
}

.filter-bar .search-box input {
    flex: 1;
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
}

.filter-bar .search-box input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.filter-bar .search-btn {
    padding: 0.625rem 0.875rem;
    background-color: var(--primary-color);
    color: white;
    border: none;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background-color 0.2s;
}

.filter-bar .search-btn:hover {
    background-color: var(--primary-dark);
}

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

.filter-bar .filter-group select,
.filter-bar .filter-group input[type="date"] {
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    background-color: white;
}

.filter-bar .filter-group select:focus,
.filter-bar .filter-group input[type="date"]:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* Bulk Actions Bar */
.bulk-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 1rem;
    background-color: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
}

.bulk-actions span {
    font-weight: 500;
    color: var(--primary-color);
}

/* Candidates Table */
.candidates-table {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.candidates-table table {
    width: 100%;
    border-collapse: collapse;
}

.candidates-table thead {
    background-color: var(--background-color);
}

.candidates-table th {
    padding: 0.875rem 1rem;
    text-align: left;
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}

.candidates-table td {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.875rem;
}

.candidates-table tbody tr:hover {
    background-color: rgba(59, 130, 246, 0.02);
}

.candidates-table .checkbox-col {
    width: 40px;
    text-align: center;
}

.candidates-table .row-pending {
    background-color: rgba(245, 158, 11, 0.05);
}

.candidates-table .row-processed {
    background-color: rgba(34, 197, 94, 0.05);
}

.candidates-table .row-rejected {
    background-color: rgba(239, 68, 68, 0.05);
}

.candidates-table .row-duplicate {
    background-color: rgba(59, 130, 246, 0.05);
}

/* File Info */
.file-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.file-icon {
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
}

.file-icon.icon-pdf {
    background-color: #fef2f2;
    color: #dc2626;
}

.file-icon.icon-pdf::before {
    content: "PDF";
}

.file-icon.icon-xml {
    background-color: #f0fdf4;
    color: #16a34a;
}

.file-icon.icon-xml::before {
    content: "XML";
}

.file-icon.icon-image {
    background-color: #eff6ff;
    color: #3b82f6;
}

.file-icon.icon-image::before {
    content: "IMG";
}

.file-icon.icon-file {
    background-color: #f1f5f9;
    color: #64748b;
}

.file-icon.icon-file::before {
    content: "FILE";
}

.file-name {
    font-weight: 500;
}

.file-size {
    color: var(--text-secondary);
    font-size: 0.8125rem;
}

/* Status Badges for Purchasing */
.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    font-size: 0.6875rem;
    font-weight: 600;
    border-radius: 1rem;
    text-transform: uppercase;
}

.status-badge.active,
.status-badge.status-success {
    background-color: #dcfce7;
    color: #16a34a;
}

.status-badge.inactive {
    background-color: #f1f5f9;
    color: #64748b;
}

.status-badge.status-pending {
    background-color: #fef3c7;
    color: #d97706;
}

.status-badge.status-warning {
    background-color: #fef2f2;
    color: #dc2626;
}

.status-badge.status-info {
    background-color: #cffafe;
    color: #0891b2;
}

.status-badge.draft {
    background-color: #f1f5f9;
    color: #64748b;
}

.status-badge.verified {
    background-color: #dbeafe;
    color: #2563eb;
}

.status-badge.transferred {
    background-color: #f0fdf4;
    color: #16a34a;
}

.status-badge.paid {
    background-color: #dcfce7;
    color: #15803d;
}

.status-badge.cancelled {
    background-color: #fef2f2;
    color: #dc2626;
}

/* Sync Badge for Lexoffice */
.sync-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    font-size: 0.625rem;
    font-weight: 700;
    border-radius: 0.375rem;
}

.sync-badge.synced {
    background-color: #dcfce7;
    color: #16a34a;
}

.sync-badge.not-synced {
    background-color: #f1f5f9;
    color: #94a3b8;
}

/* Table Row States */
.data-table .cancelled-row {
    opacity: 0.6;
    background-color: #fef2f2;
}

.data-table .paid-row {
    background-color: rgba(34, 197, 94, 0.05);
}

.data-table .inactive-row {
    opacity: 0.7;
    background-color: #f8fafc;
}

.data-table .overdue {
    color: #dc2626;
    font-weight: 600;
}

.data-table .mono {
    font-family: monospace;
    font-size: 0.8125rem;
}

.data-table .number-col {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.data-table .company-name,
.data-table .supplier-name {
    font-weight: 500;
}

/* Form Grid in Modals */
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.form-grid .form-group {
    margin-bottom: 0;
}

.form-grid .form-group.full-width {
    grid-column: span 2;
}

.form-grid .form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.form-grid .form-group input,
.form-grid .form-group select,
.form-grid .form-group textarea {
    width: 100%;
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    background-color: white;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-grid .form-group input:focus,
.form-grid .form-group select:focus,
.form-grid .form-group textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.form-grid .form-group small {
    display: block;
    margin-top: 0.375rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.form-grid .checkbox-group label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    font-weight: 400;
}

.form-grid .checkbox-group input[type="checkbox"] {
    width: auto;
}

/* Form Tabs in Modals */
.form-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.form-tabs .tab-btn {
    padding: 0.5rem 1rem;
    border: none;
    background-color: transparent;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 0.375rem;
    cursor: pointer;
    transition: all 0.2s;
}

.form-tabs .tab-btn:hover {
    background-color: white;
    color: var(--text-primary);
}

.form-tabs .tab-btn.active {
    background-color: white;
    color: var(--primary-color);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Form Row */
.form-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
}

.form-row .form-group {
    flex: 1;
    margin-bottom: 0;
}

/* Process Form Styling */
.process-form {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.process-form .form-group {
    margin-bottom: 1rem;
}

.process-form .form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    font-size: 0.875rem;
}

.process-form .form-group input,
.process-form .form-group select,
.process-form .form-group textarea {
    width: 100%;
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    font-size: 0.875rem;
}

.process-form .form-group input:focus,
.process-form .form-group select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Detail Layout for Invoice Candidates */
.detail-layout {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: 1.5rem;
    min-height: 600px;
}

.detail-preview {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    overflow: hidden;
}

.detail-preview .pdf-preview {
    width: 100%;
    height: 100%;
    min-height: 600px;
    border: none;
}

.detail-preview .preview-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 400px;
    color: var(--text-secondary);
}

.detail-form {
    display: flex;
    flex-direction: column;
}

.detail-form h3 {
    margin: 0 0 1rem;
    font-size: 1.125rem;
}

.detail-info {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

.info-row {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border-color);
}

.info-row:last-child {
    border-bottom: none;
}

.info-label {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.info-value {
    font-weight: 500;
    font-size: 0.875rem;
    text-align: right;
    word-break: break-all;
}

.rejection-info {
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 0.5rem;
    padding: 1rem;
    margin-top: 1rem;
}

.rejection-info strong {
    color: #dc2626;
}

/* Modal Enhancements */
.modal-content.modal-large {
    max-width: 700px;
    width: 90%;
}

.modal-content.modal-xlarge {
    max-width: 1100px;
    width: 95%;
}

.modal-content h3 {
    margin: 0 0 1.25rem;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* Test/Connection Result */
.test-result {
    padding: 1rem;
    border-radius: 0.5rem;
    margin: 1rem 0;
}

.test-result.success {
    background-color: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
}

.test-result.error {
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
}

.test-result p {
    margin: 0;
}

.test-result p + p {
    margin-top: 0.5rem;
}

/* Error Banner */
.error-banner {
    padding: 0.75rem 1rem;
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 0.5rem;
    color: #dc2626;
    font-size: 0.875rem;
    margin: 1rem 0;
}

/* Warning Text */
.warning-text {
    color: #d97706;
    font-size: 0.875rem;
    margin-top: 0.5rem;
}

/* Fetch Summary */
.fetch-summary {
    display: grid;
    gap: 0.75rem;
    margin: 1rem 0;
}

.summary-item {
    display: flex;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.summary-label {
    color: var(--text-secondary);
}

.summary-value {
    font-weight: 600;
}

.summary-value.success {
    color: #16a34a;
}

.fetch-errors {
    margin-top: 1rem;
    padding: 1rem;
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 0.5rem;
}

.fetch-errors ul {
    margin: 0.5rem 0 0;
    padding-left: 1.5rem;
}

.fetch-errors li {
    font-size: 0.875rem;
    color: #dc2626;
}

/* Invoice Detail */
.invoice-detail {
    max-height: 60vh;
    overflow-y: auto;
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.detail-section {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    padding: 1rem;
}

.detail-section h4 {
    margin: 0 0 0.75rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
}

.detail-section dl {
    margin: 0;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.5rem 1rem;
}

.detail-section dt {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.detail-section dd {
    margin: 0;
    font-size: 0.875rem;
    font-weight: 500;
    text-align: right;
}

/* Items Table in Invoice Detail */
.items-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 0.75rem;
    font-size: 0.875rem;
}

.items-table th {
    padding: 0.625rem;
    background-color: var(--background-color);
    font-weight: 600;
    text-align: left;
    font-size: 0.75rem;
    text-transform: uppercase;
}

.items-table td {
    padding: 0.625rem;
    border-bottom: 1px solid var(--border-color);
}

.items-table .number-col {
    text-align: right;
}

.notes-text {
    font-size: 0.875rem;
    color: var(--text-secondary);
    line-height: 1.6;
    white-space: pre-wrap;
}

/* Pagination */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 1rem;
    margin-top: 1rem;
}

.pagination-info,
.page-info {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

/* Data Table Container */
.data-table-container {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Button Icon Only Variations */
.btn-icon-only.warning {
    color: var(--warning-color);
}

.btn-icon-only.warning:hover {
    background-color: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.btn-icon-only.success {
    color: var(--success-color);
}

.btn-icon-only.success:hover {
    background-color: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}

/* Button Variations */
.btn-warning {
    background-color: var(--warning-color);
    color: white;
}

.btn-warning:hover:not(:disabled) {
    background-color: #d97706;
}

.btn-success {
    background-color: var(--success-color);
    color: white;
}

.btn-success:hover:not(:disabled) {
    background-color: #16a34a;
}

/* Responsive Purchasing */
@media (max-width: 1024px) {
    .detail-layout {
        grid-template-columns: 1fr;
    }

    .detail-preview {
        max-height: 400px;
    }
}

@media (max-width: 768px) {
    .accounts-grid {
        grid-template-columns: 1fr;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .summary-cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .filter-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-bar .search-box {
        min-width: auto;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .form-grid .form-group.full-width {
        grid-column: span 1;
    }

    .detail-grid {
        grid-template-columns: 1fr;
    }

    .modal-content.modal-large,
    .modal-content.modal-xlarge {
        width: 95%;
        max-height: 90vh;
        overflow-y: auto;
    }
}

/* ==================== Lexoffice Import Styles ==================== */

.import-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
    padding: 0.75rem 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.select-all-row {
    display: flex;
    align-items: center;
}

.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
    width: 100%;
}

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

.vendor-list {
    max-height: 400px;
    overflow-y: auto;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    margin-bottom: 1rem;
}

.vendor-item {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--border-color);
    transition: background-color 0.15s ease;
}

.vendor-item:last-child {
    border-bottom: none;
}

.vendor-item:hover {
    background-color: var(--background-color);
}

.vendor-item.selected {
    background-color: #eff6ff;
}

.vendor-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.vendor-info strong {
    color: var(--text-primary);
    font-size: 0.9375rem;
}

.vendor-info .contact-person {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.vendor-details {
    display: flex;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.success-banner {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background-color: #dcfce7;
    color: #16a34a;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    font-size: 0.875rem;
}

.info-banner p {
    margin: 0;
}

.info-banner p.text-muted {
    margin-top: 0.5rem;
    color: #64748b;
    font-size: 0.8125rem;
}

/* ==================== Inventory Module Styles ==================== */

/* Inventory Dashboard */
.inventory-page .summary-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.inventory-page .summary-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    gap: 1rem;
    border-left: 4px solid var(--primary-color);
}

.inventory-page .summary-card.warning {
    border-left-color: var(--warning-color);
}

.inventory-page .summary-card.danger {
    border-left-color: var(--danger-color);
}

.inventory-page .card-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.inventory-page .card-icon.articles { background-color: #dbeafe; color: #2563eb; }
.inventory-page .card-icon.quantity { background-color: #dcfce7; color: #16a34a; }
.inventory-page .card-icon.low-stock { background-color: #fef3c7; color: #d97706; }
.inventory-page .card-icon.out-of-stock { background-color: #fef2f2; color: #dc2626; }

.inventory-page .card-content {
    flex: 1;
}

.inventory-page .card-value {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--text-primary);
}

.inventory-page .card-label {
    display: block;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Quick Actions */
.inventory-page .quick-actions-section {
    margin-bottom: 2rem;
}

.inventory-page .quick-actions-section h2 {
    margin-bottom: 1rem;
}

.inventory-page .quick-actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.inventory-page .quick-action-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.25rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    text-decoration: none;
    color: var(--text-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: all 0.2s;
    border: 2px solid transparent;
}

.inventory-page .quick-action-card:hover {
    border-color: var(--primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.inventory-page .quick-action-card .action-icon {
    width: 3rem;
    height: 3rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-color);
    flex-shrink: 0;
}

.inventory-page .quick-action-card .action-content {
    flex: 1;
}

.inventory-page .quick-action-card .action-content h3 {
    margin: 0 0 0.25rem 0;
    font-size: 1rem;
    font-weight: 600;
}

.inventory-page .quick-action-card .action-content p {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.inventory-page .quick-action-card .badge {
    background-color: var(--primary-color);
    color: #fff;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
}

/* Operations Section */
.inventory-page .operations-section {
    margin-bottom: 2rem;
}

.inventory-page .operations-section h2 {
    margin-bottom: 1rem;
}

.inventory-page .operation-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.inventory-page .operation-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    text-align: center;
    text-decoration: none;
    color: var(--text-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: all 0.2s;
    border: 2px solid transparent;
}

.inventory-page .operation-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.inventory-page .operation-card.receipt:hover { border-color: #22c55e; }
.inventory-page .operation-card.issue:hover { border-color: #f59e0b; }
.inventory-page .operation-card.count:hover { border-color: #3b82f6; }
.inventory-page .operation-card.returns:hover { border-color: #8b5cf6; }

.inventory-page .operation-icon {
    width: 4rem;
    height: 4rem;
    margin: 0 auto 1rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.inventory-page .operation-card.receipt .operation-icon { background-color: #dcfce7; color: #16a34a; }
.inventory-page .operation-card.issue .operation-icon { background-color: #fef3c7; color: #d97706; }
.inventory-page .operation-card.count .operation-icon { background-color: #dbeafe; color: #2563eb; }
.inventory-page .operation-card.returns .operation-icon { background-color: #ede9fe; color: #7c3aed; }

.inventory-page .operation-content h3 {
    margin: 0 0 0.25rem 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.inventory-page .operation-content p {
    margin: 0 0 0.5rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.inventory-page .pending-badge {
    display: inline-block;
    background-color: var(--warning-color);
    color: #fff;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
}

/* Warehouses Section */
.inventory-page .warehouses-section {
    margin-bottom: 2rem;
}

.inventory-page .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.inventory-page .section-header h2 {
    margin: 0;
}

.inventory-page .warehouse-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
}

.inventory-page .warehouse-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.25rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    position: relative;
    border: 2px solid transparent;
    transition: all 0.2s;
}

.inventory-page .warehouse-card:hover {
    border-color: var(--primary-color);
}

.inventory-page .warehouse-card.default {
    border-color: var(--primary-color);
    background-color: #f0f9ff;
}

.inventory-page .warehouse-card.inactive {
    opacity: 0.7;
}

.inventory-page .warehouse-card .default-badge {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background-color: var(--primary-color);
    color: #fff;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
}

.inventory-page .warehouse-card h3 {
    margin: 0 0 0.25rem 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.inventory-page .warehouse-code {
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0 0 0.5rem 0;
}

.inventory-page .warehouse-address {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin: 0 0 0.75rem 0;
}

.inventory-page .warehouse-stats {
    display: flex;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
}

.inventory-page .warehouse-status {
    margin-top: auto;
}

/* DHL Section */
.inventory-page .dhl-section {
    margin-bottom: 2rem;
}

.inventory-page .dhl-info {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.inventory-page .dhl-icon {
    width: 5rem;
    height: 5rem;
    background: linear-gradient(135deg, #ffcc00 0%, #ffd633 100%);
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #cc0000;
    flex-shrink: 0;
}

.inventory-page .dhl-content {
    flex: 1;
}

.inventory-page .dhl-content h3 {
    margin: 0 0 0.5rem 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.inventory-page .dhl-content p {
    margin: 0 0 1rem 0;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Empty State Small */
.inventory-page .empty-state.small {
    text-align: center;
    padding: 2rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.inventory-page .empty-state.small p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

/* Warehouse Management Page */
.warehouses-page .warehouse-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
}

.warehouses-page .warehouse-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    position: relative;
    border: 2px solid transparent;
    transition: all 0.2s;
    cursor: pointer;
}

.warehouses-page .warehouse-card:hover {
    border-color: var(--primary-color);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.warehouses-page .warehouse-card.default {
    border-color: var(--primary-color);
}

.warehouses-page .warehouse-card.inactive {
    opacity: 0.7;
}

.warehouses-page .warehouse-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.warehouses-page .warehouse-card-header h3 {
    margin: 0;
    font-size: 1.125rem;
}

.warehouses-page .warehouse-badges {
    display: flex;
    gap: 0.5rem;
}

.warehouses-page .warehouse-code {
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
}

.warehouses-page .warehouse-address {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
    min-height: 2.5rem;
}

.warehouses-page .warehouse-stats {
    display: flex;
    gap: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.warehouses-page .warehouse-stat {
    text-align: center;
}

.warehouses-page .stat-value {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
}

.warehouses-page .stat-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.warehouses-page .warehouse-card-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

/* Warehouse Card Enhanced Styles */
.warehouses-page .warehouse-card .card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
    min-height: 1.5rem;
}

.warehouses-page .warehouse-card .default-badge {
    background-color: var(--primary-color);
    color: #fff;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
}

.warehouses-page .warehouse-card .card-actions {
    display: flex;
    gap: 0.25rem;
    margin-left: auto;
}

.warehouses-page .warehouse-card .card-body h3 {
    margin: 0 0 0.25rem 0;
    font-size: 1.125rem;
    font-weight: 600;
}

.warehouses-page .warehouse-card .warehouse-code {
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.warehouses-page .warehouse-card .warehouse-description {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.warehouses-page .warehouse-card .warehouse-address {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
}

.warehouses-page .warehouse-card .card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 1rem;
    margin-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.warehouses-page .warehouse-card .warehouse-stats {
    display: flex;
    gap: 1.5rem;
}

.warehouses-page .warehouse-card .stat {
    text-align: center;
}

.warehouses-page .warehouse-card .stat-value {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
}

.warehouses-page .warehouse-card .stat-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.warehouses-page .warehouse-card .card-expand {
    margin-top: 1rem;
}

.warehouses-page .warehouse-card .card-expand .btn {
    width: 100%;
    justify-content: center;
}

/* Checkbox Group */
.checkbox-group {
    margin-top: 0.5rem;
}

.checkbox-group .checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    font-size: 0.875rem;
}

.checkbox-group .checkbox-label input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
}

/* Warning Text */
.warning-text {
    color: var(--warning-color);
    font-size: 0.875rem;
}

/* Goods Receipt Detail Page */
.goods-receipt-detail-page .receipt-info-section {
    margin-bottom: 2rem;
}

.goods-receipt-detail-page .info-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    padding: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.goods-receipt-detail-page .info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 1.5rem;
}

.goods-receipt-detail-page .info-item {
    display: flex;
    flex-direction: column;
}

.goods-receipt-detail-page .info-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.25rem;
}

.goods-receipt-detail-page .info-value {
    font-size: 1rem;
    font-weight: 500;
}

.goods-receipt-detail-page .info-notes {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.goods-receipt-detail-page .info-notes p {
    margin: 0.5rem 0 0;
    color: var(--text-secondary);
}

.goods-receipt-detail-page .info-actions {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.goods-receipt-detail-page .items-section {
    margin-bottom: 2rem;
}

.goods-receipt-detail-page .items-section .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.goods-receipt-detail-page .items-section .section-header h2 {
    margin: 0;
    font-size: 1.25rem;
}

/* Article Search */
.article-search {
    position: relative;
}

.article-search .search-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 100;
    max-height: 200px;
    overflow-y: auto;
}

.article-search .search-result-item {
    padding: 0.75rem 1rem;
    cursor: pointer;
    display: flex;
    gap: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.article-search .search-result-item:last-child {
    border-bottom: none;
}

.article-search .search-result-item:hover {
    background-color: var(--background-color);
}

.selected-article {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
    font-size: 0.875rem;
}

.selected-article .btn-clear {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 1rem;
    padding: 0 0.25rem;
}

.selected-article .btn-clear:hover {
    color: var(--danger-color);
}

/* Table Footer */
.data-table tfoot tr {
    background-color: var(--background-color);
}

.data-table tfoot td {
    padding: 0.75rem 1rem;
    font-weight: 600;
}

/* Button Success */
.btn-success {
    background-color: #16a34a;
    color: #fff;
    border: none;
}

.btn-success:hover {
    background-color: #15803d;
}

.btn-success:disabled {
    background-color: #86efac;
    cursor: not-allowed;
}

/* Button Danger */
.btn-danger {
    background-color: var(--danger-color);
    color: #fff;
    border: none;
}

.btn-danger:hover {
    background-color: #b91c1c;
}

/* Button Warning */
.btn-warning {
    background-color: var(--warning-color);
    color: #fff;
    border: none;
}

.btn-warning:hover {
    background-color: #b45309;
}

/* DHL Config Page */
.dhl-config-page .config-sections {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.dhl-config-page .config-section {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.dhl-config-page .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    background-color: var(--background-color);
    border-bottom: 1px solid var(--border-color);
}

.dhl-config-page .section-header h2 {
    margin: 0;
    font-size: 1.125rem;
}

.dhl-config-page .status-indicator {
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.dhl-config-page .status-indicator.active {
    background-color: #dcfce7;
    color: #16a34a;
}

.dhl-config-page .status-indicator.inactive {
    background-color: #fef2f2;
    color: #dc2626;
}

.dhl-config-page .section-content {
    padding: 1.5rem;
}

.dhl-config-page .password-input {
    position: relative;
    display: flex;
}

.dhl-config-page .password-input input {
    flex: 1;
    padding-right: 3rem;
}

.dhl-config-page .toggle-password {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 0.25rem;
}

.dhl-config-page .toggle-password:hover {
    color: var(--text-primary);
}

.dhl-config-page .form-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-top: 1rem;
}

.dhl-config-page .checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    font-size: 0.875rem;
}

.dhl-config-page .checkbox-label input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
}

.dhl-config-page .page-actions {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    margin-top: 1.5rem;
}

/* General Inventory Styles */
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.form-grid .form-group {
    margin-bottom: 0;
}

.form-grid .form-group.full-width {
    grid-column: span 2;
}

.form-grid .form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    font-size: 0.875rem;
}

.form-grid input,
.form-grid select,
.form-grid textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: #fff;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-grid input:focus,
.form-grid select:focus,
.form-grid textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.form-grid input:disabled,
.form-grid select:disabled {
    background-color: var(--background-color);
    cursor: not-allowed;
}

/* Form Tabs */
.form-tabs {
    display: flex;
    gap: 0.25rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 0;
}

.form-tabs .tab-btn {
    padding: 0.75rem 1.25rem;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: all 0.2s;
}

.form-tabs .tab-btn:hover {
    color: var(--text-primary);
}

.form-tabs .tab-btn.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

/* Status Badges */
.status-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: capitalize;
}

.status-badge.active,
.status-badge.completed,
.status-badge.posted {
    background-color: #dcfce7;
    color: #16a34a;
}

.status-badge.inactive,
.status-badge.cancelled {
    background-color: #fef2f2;
    color: #dc2626;
}

.status-badge.pending,
.status-badge.draft {
    background-color: #fef3c7;
    color: #d97706;
}

.status-badge.processing,
.status-badge.inprogress,
.status-badge.received {
    background-color: #dbeafe;
    color: #2563eb;
}

.status-badge.planned {
    background-color: #e0e7ff;
    color: #4f46e5;
}

/* Data Table Container */
.data-table-container {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    margin-bottom: 1rem;
}

/* Button Icon Only */
.btn-icon-only {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0.375rem;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all 0.2s;
}

.btn-icon-only:hover {
    background-color: var(--background-color);
    color: var(--text-primary);
}

.btn-icon-only.success:hover {
    background-color: #dcfce7;
    color: #16a34a;
}

.btn-icon-only.danger:hover {
    background-color: #fef2f2;
    color: #dc2626;
}

.btn-icon-only.warning:hover {
    background-color: #fef3c7;
    color: #d97706;
}

/* Table Text Utilities */
.text-right {
    text-align: right;
}

.text-center {
    text-align: center;
}

.text-success {
    color: #16a34a;
}

.text-danger {
    color: #dc2626;
}

.text-warning {
    color: #d97706;
}

.font-bold {
    font-weight: 600;
}

.mono {
    font-family: monospace;
    font-size: 0.8125rem;
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
}

.page-info {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

/* Loading Container */
.loading-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    color: var(--text-secondary);
}

.loading-spinner {
    width: 2.5rem;
    height: 2.5rem;
    border: 3px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-bottom: 1rem;
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 4rem 2rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.empty-state .empty-icon {
    color: var(--border-color);
    margin-bottom: 1rem;
}

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

.empty-state p {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.empty-state .empty-actions {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
}

/* Error and Success Banners */
.error-banner {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background-color: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    font-size: 0.875rem;
}

/* Breadcrumb */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.breadcrumb a {
    color: var(--primary-color);
    text-decoration: none;
}

.breadcrumb a:hover {
    text-decoration: underline;
}

.breadcrumb span {
    color: var(--text-secondary);
}

/* Progress Bar */
.progress-bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.progress-bar .progress {
    height: 0.5rem;
    background-color: var(--primary-color);
    border-radius: 0.25rem;
}

/* Movement Type Badge */
.movement-type-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 500;
}

.movement-type-badge.goodsreceipt { background-color: #dcfce7; color: #16a34a; }
.movement-type-badge.goodsissue { background-color: #fef3c7; color: #d97706; }
.movement-type-badge.transfer { background-color: #dbeafe; color: #2563eb; }
.movement-type-badge.adjustment { background-color: #e0e7ff; color: #4f46e5; }
.movement-type-badge.inventorycount { background-color: #cffafe; color: #0891b2; }
.movement-type-badge.return { background-color: #fce7f3; color: #be185d; }

/* Article Info in Tables */
.article-info {
    display: flex;
    flex-direction: column;
}

.article-info .mono {
    color: var(--text-secondary);
}

/* Modal XLarge */
.modal-content.modal-xlarge {
    max-width: 900px;
}

/* Responsive adjustments for inventory pages */
@media (max-width: 768px) {
    .inventory-page .summary-cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .inventory-page .quick-actions,
    .inventory-page .operation-cards,
    .inventory-page .warehouse-cards {
        grid-template-columns: 1fr;
    }

    .inventory-page .dhl-info {
        flex-direction: column;
        text-align: center;
    }

    .warehouses-page .warehouse-grid {
        grid-template-columns: 1fr;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .form-grid .form-group.full-width {
        grid-column: span 1;
    }
}

/* ==============================================
   REPORTS PAGE STYLES
   ============================================== */

.reports-page {
    padding: 0;
}

.reports-page .page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}

.reports-page .header-content h1 {
    margin: 0 0 0.25rem 0;
    font-size: 1.75rem;
    font-weight: 600;
}

.reports-page .subtitle {
    color: var(--text-secondary);
    margin: 0;
}

.reports-page .date-filter {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.reports-page .date-filter label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.reports-page .date-filter input[type="date"] {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
}

/* Report Tabs */
.report-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 0;
    flex-wrap: wrap;
}

.report-tabs .tab-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    margin-bottom: -1px;
}

.report-tabs .tab-btn:hover {
    color: var(--primary-color);
    background-color: rgba(var(--primary-rgb), 0.05);
}

.report-tabs .tab-btn.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

.report-tabs .tab-btn svg {
    opacity: 0.7;
}

.report-tabs .tab-btn.active svg {
    opacity: 1;
}

/* Report Section */
.report-section {
    padding: 0;
}

.report-section h2 {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 1.5rem 0;
    color: var(--text-primary);
}

.report-section h3 {
    font-size: 1rem;
    font-weight: 600;
    margin: 2rem 0 1rem 0;
    color: var(--text-primary);
}

/* KPI Cards in Reports */
.report-section .kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.report-section .kpi-card {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    padding: 1.25rem;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.report-section .kpi-card.highlight {
    background: linear-gradient(135deg, var(--primary-color), #4f46e5);
    border-color: transparent;
    color: white;
}

.report-section .kpi-card.highlight .kpi-label,
.report-section .kpi-card.highlight .kpi-subtext {
    color: rgba(255, 255, 255, 0.8);
}

.report-section .kpi-icon {
    width: 48px;
    height: 48px;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.report-section .kpi-icon.articles { background: rgba(59, 130, 246, 0.1); color: #3b82f6; }
.report-section .kpi-icon.inventory { background: rgba(16, 185, 129, 0.1); color: #10b981; }
.report-section .kpi-icon.value { background: rgba(245, 158, 11, 0.1); color: #f59e0b; }
.report-section .kpi-icon.offers { background: rgba(139, 92, 246, 0.1); color: #8b5cf6; }
.report-section .kpi-icon.reserved { background: rgba(239, 68, 68, 0.1); color: #ef4444; }
.report-section .kpi-icon.available { background: rgba(16, 185, 129, 0.1); color: #10b981; }
.report-section .kpi-icon.suppliers { background: rgba(59, 130, 246, 0.1); color: #3b82f6; }
.report-section .kpi-icon.invoices { background: rgba(245, 158, 11, 0.1); color: #f59e0b; }
.report-section .kpi-icon.spending { background: rgba(239, 68, 68, 0.1); color: #ef4444; }
.report-section .kpi-icon.goods-receipt { background: rgba(16, 185, 129, 0.1); color: #10b981; }
.report-section .kpi-icon.orders { background: rgba(59, 130, 246, 0.1); color: #3b82f6; }
.report-section .kpi-icon.sold { background: rgba(16, 185, 129, 0.1); color: #10b981; }
.report-section .kpi-icon.revenue { background: rgba(255, 255, 255, 0.2); color: white; }

.report-section .kpi-content {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.report-section .kpi-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
}

.report-section .kpi-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.report-section .kpi-subtext {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Stats Row */
.report-section .stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.report-section .stat-card {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    padding: 1.25rem;
    border-left: 4px solid var(--border-color);
}

.report-section .stat-card.info { border-left-color: #3b82f6; }
.report-section .stat-card.success { border-left-color: #10b981; }
.report-section .stat-card.warning { border-left-color: #f59e0b; }
.report-section .stat-card.danger { border-left-color: #ef4444; }

.report-section .stat-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.report-section .stat-title {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.report-section .stat-badge {
    font-size: 0.65rem;
    padding: 0.2rem 0.5rem;
    border-radius: 1rem;
    font-weight: 600;
    text-transform: uppercase;
}

.report-section .stat-card.warning .stat-badge { background: rgba(245, 158, 11, 0.15); color: #f59e0b; }
.report-section .stat-card.danger .stat-badge { background: rgba(239, 68, 68, 0.15); color: #ef4444; }

.report-section .stat-value {
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.2;
}

.report-section .stat-description {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Revenue Section */
.revenue-section,
.movements-section,
.amounts-section {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.revenue-section h3,
.movements-section h3,
.amounts-section h3 {
    margin: 0 0 1rem 0;
}

.revenue-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.revenue-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

.revenue-card,
.movement-card,
.amount-card {
    background: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    text-align: center;
}

.revenue-card.highlight,
.amount-card.highlight {
    background: linear-gradient(135deg, var(--primary-color), #4f46e5);
    border-color: transparent;
    color: white;
}

.revenue-card.accent {
    background: linear-gradient(135deg, #10b981, #059669);
    border-color: transparent;
    color: white;
}

.revenue-period,
.movement-period,
.amount-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.revenue-card.highlight .revenue-period,
.revenue-card.accent .revenue-period,
.amount-card.highlight .amount-label {
    color: rgba(255, 255, 255, 0.8);
}

.revenue-value,
.movement-value,
.amount-value {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
}

.revenue-orders,
.amount-count {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.revenue-card.highlight .revenue-orders,
.revenue-card.accent .revenue-orders,
.amount-card.highlight .amount-count {
    color: rgba(255, 255, 255, 0.8);
}

.movement-details {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.amount-card.open { border-left: 3px solid #f59e0b; }
.amount-card.paid { border-left: 3px solid #10b981; }

.amounts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

/* Data Tables in Reports */
.report-section .data-table-container {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.report-section .data-table {
    width: 100%;
    border-collapse: collapse;
}

.report-section .data-table th,
.report-section .data-table td {
    padding: 0.75rem 1rem;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

.report-section .data-table th {
    background: var(--background-color);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
}

.report-section .data-table td {
    font-size: 0.875rem;
}

.report-section .data-table tbody tr:last-child td {
    border-bottom: none;
}

.report-section .data-table tbody tr:hover {
    background: rgba(var(--primary-rgb), 0.03);
}

.report-section .data-table .text-right {
    text-align: right;
}

.report-section .data-table code {
    background: var(--background-color);
    padding: 0.15rem 0.4rem;
    border-radius: 0.25rem;
    font-size: 0.8rem;
}

.report-section .data-table .row-warning {
    background: rgba(245, 158, 11, 0.05);
}

.report-section .data-table .row-danger {
    background: rgba(239, 68, 68, 0.05);
}

/* Report Columns Layout */
.report-columns {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.report-column h3 {
    margin-top: 0;
}

/* Bar Chart */
.chart-container {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.bar-chart {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    height: 200px;
    gap: 0.5rem;
    padding-top: 2rem;
}

.bar-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
}

.bar {
    width: 100%;
    max-width: 40px;
    background: linear-gradient(to top, var(--primary-color), #818cf8);
    border-radius: 0.25rem 0.25rem 0 0;
    position: relative;
    min-height: 4px;
    transition: height 0.3s ease;
}

.bar.bar-success {
    background: linear-gradient(to top, #10b981, #34d399);
}

.bar-value {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.65rem;
    font-weight: 600;
    white-space: nowrap;
    padding-bottom: 0.25rem;
    color: var(--text-secondary);
}

.bar-label {
    font-size: 0.7rem;
    color: var(--text-secondary);
    margin-top: 0.5rem;
    text-align: center;
}

.bar-count {
    font-size: 0.6rem;
    color: var(--text-tertiary, #9ca3af);
}

/* Report Footer */
.report-footer {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.generated-info {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-align: center;
}

/* Badges */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: 1rem;
}

.badge-success { background: rgba(16, 185, 129, 0.15); color: #10b981; }
.badge-warning { background: rgba(245, 158, 11, 0.15); color: #f59e0b; }
.badge-danger { background: rgba(239, 68, 68, 0.15); color: #ef4444; }
.badge-info { background: rgba(59, 130, 246, 0.15); color: #3b82f6; }

/* Responsive Reports */
@media (max-width: 768px) {
    .reports-page .page-header {
        flex-direction: column;
    }

    .reports-page .date-filter {
        width: 100%;
    }

    .report-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
    }

    .report-tabs .tab-btn {
        white-space: nowrap;
    }

    .report-section .kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .revenue-grid,
    .revenue-grid-4,
    .amounts-grid {
        grid-template-columns: 1fr;
    }

    .report-columns {
        grid-template-columns: 1fr;
    }

    .bar-chart {
        overflow-x: auto;
        justify-content: flex-start;
    }

    .bar-item {
        flex: 0 0 50px;
    }
}

/* ============================
   Customer Pages Styles
   ============================ */

/* Customer List - Name Cell */
.customer-name-cell {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.customer-name-cell strong {
    font-weight: 600;
    color: var(--text-primary);
}

.customer-name-cell small {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

/* Customer Detail - Title */
.customer-title {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 0.5rem;
}

/* Address Grid */
.address-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

.address-card {
    background: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 1rem;
    transition: box-shadow 0.2s;
}

.address-card:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.address-card.default-address {
    border-color: var(--success-color);
    background: #f0fdf4;
}

.address-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border-color);
}

.address-type {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.address-actions {
    display: flex;
    gap: 0.5rem;
}

.address-content {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.address-content strong {
    font-weight: 600;
}

/* Notes Section */
.notes-section {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.notes-section h4 {
    font-size: 0.9rem;
    font-weight: 600;
    margin: 0 0 0.5rem 0;
    color: var(--text-secondary);
}

.notes-text {
    margin: 0;
    padding: 0.75rem;
    background: var(--background-color);
    border-radius: 4px;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--text-primary);
}

/* Card Header with Action Button */
.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.card-header h3 {
    margin: 0;
}

/* Compact Table for Order History */
.data-table.compact {
    font-size: 0.9rem;
}

.data-table.compact th,
.data-table.compact td {
    padding: 0.5rem;
}

/* Loading Spinner Small */
.loading-spinner-sm {
    width: 24px;
    height: 24px;
    border: 3px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 1rem auto;
}

/* Modal Content Large */
.modal-content.large {
    max-width: 600px;
}

/* Form Row for Side-by-Side Inputs */
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

@media (max-width: 768px) {
    .form-row {
        grid-template-columns: 1fr;
    }

    .address-grid {
        grid-template-columns: 1fr;
    }

    .customer-title {
        flex-direction: column;
        align-items: flex-start;
    }

    .address-header {
        flex-direction: column;
        gap: 0.75rem;
    }

    .address-actions {
        width: 100%;
    }

    .address-actions .btn {
        flex: 1;
    }
}

/* =============================================================================
   INTEGRATION PAGES - Connector Overview, eBay, Cardmarket, WooCommerce, eBay Kleinanzeigen
   ============================================================================= */

/* Shared Integration Page Base Styles */
.connector-overview-page,
.ebay-config-page,
.cardmarket-config-page,
.woocommerce-config-page,
.ebay-kleinanzeigen-config-page {
    max-width: 1200px;
}

/* Config Tabs */
.config-tabs {
    display: flex;
    gap: 0.25rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--card-bg);
    border-radius: 0.75rem 0.75rem 0 0;
    padding: 0 0.5rem;
    overflow-x: auto;
}

.config-tabs .tab {
    padding: 1rem 1.5rem;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: all 0.2s;
    white-space: nowrap;
}

.config-tabs .tab:hover {
    color: var(--text-primary);
    background-color: rgba(59, 130, 246, 0.05);
}

.config-tabs .tab.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

/* Config Sections */
.config-sections {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.config-section {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.config-section .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    background-color: var(--background-color);
    border-bottom: 1px solid var(--border-color);
}

.config-section .section-header h2 {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
}

.config-section .section-content {
    padding: 1.5rem;
}

/* Status Indicator */
.status-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-indicator.active {
    background-color: #dcfce7;
    color: #16a34a;
}

.status-indicator.inactive {
    background-color: #fef2f2;
    color: #dc2626;
}

/* Info Box */
.info-box {
    background-color: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
}

.info-box p {
    margin: 0 0 0.5rem 0;
    font-size: 0.875rem;
    color: #1e40af;
}

.info-box p:last-child {
    margin-bottom: 0;
}

.info-box a {
    color: #2563eb;
    text-decoration: underline;
}

.info-box a:hover {
    color: #1d4ed8;
}

.info-box ol {
    margin: 0.75rem 0 0 1.25rem;
    padding: 0;
    font-size: 0.875rem;
    color: #1e40af;
}

.info-box ol li {
    margin-bottom: 0.375rem;
}

.info-text {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

/* Password Input with Toggle */
.password-input {
    position: relative;
    display: flex;
}

.password-input input {
    flex: 1;
    padding-right: 3rem;
}

.toggle-password {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.toggle-password:hover {
    color: var(--text-primary);
}

/* Form Checkboxes */
.form-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

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

.checkbox-label input[type="checkbox"] {
    width: 1.125rem;
    height: 1.125rem;
    accent-color: var(--primary-color);
    cursor: pointer;
}

.checkbox-label span {
    user-select: none;
}

/* Connection Status & Test Result */
.connection-status {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.test-result {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    border-radius: 0.375rem;
    font-size: 0.875rem;
}

.test-result.success {
    background-color: #dcfce7;
    color: #16a34a;
}

.test-result.error {
    background-color: #fef2f2;
    color: #dc2626;
}

.test-result .status-icon {
    font-size: 1rem;
    font-weight: bold;
}

/* Token Status */
.token-status {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-radius: 0.5rem;
    margin-top: 1.5rem;
    font-size: 0.875rem;
}

.token-status.success {
    background-color: #dcfce7;
    border: 1px solid #86efac;
    color: #16a34a;
}

.token-status.warning {
    background-color: #fef3c7;
    border: 1px solid #fcd34d;
    color: #b45309;
}

.token-status .status-icon {
    font-size: 1.25rem;
}

.token-status .btn {
    margin-left: auto;
}

/* Sync Status */
.sync-status {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
}

.sync-status p {
    margin: 0 0 0.375rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.sync-status p:last-child {
    margin-bottom: 0;
}

.sync-status .error-text {
    color: var(--danger-color);
}

/* Template Section */
.template-info {
    background-color: #f8fafc;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
}

.template-info p {
    margin: 0 0 0.5rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.placeholder-list {
    margin: 0;
    padding-left: 1.25rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.placeholder-list li {
    margin-bottom: 0.25rem;
}

.placeholder-list code {
    background-color: #e2e8f0;
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 0.8125rem;
    color: #0f172a;
}

.template-preview {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.template-preview h3 {
    margin: 0 0 1rem 0;
    font-size: 1rem;
    font-weight: 600;
}

.preview-content {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: #fff;
    max-height: 300px;
    overflow-y: auto;
}

/* Fee Calculator */
.fee-calculator {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-color);
}

.fee-calculator h3 {
    margin: 0 0 1rem 0;
    font-size: 1rem;
    font-weight: 600;
}

.calculator-form {
    display: flex;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: 1rem;
}

.calculator-form .form-group {
    margin-bottom: 0;
    flex: 0 0 200px;
}

.calculation-result {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
}

.calculation-result table {
    width: 100%;
    border-collapse: collapse;
}

.calculation-result td {
    padding: 0.375rem 0;
    font-size: 0.875rem;
}

.calculation-result td:last-child {
    text-align: right;
    font-family: 'Consolas', 'Monaco', monospace;
}

.calculation-result tr.total td {
    border-top: 1px solid var(--border-color);
    padding-top: 0.625rem;
    font-weight: 600;
}

/* Page Actions */
.connector-overview-page .page-actions,
.ebay-config-page .page-actions,
.cardmarket-config-page .page-actions,
.woocommerce-config-page .page-actions,
.ebay-kleinanzeigen-config-page .page-actions {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    margin-top: 1.5rem;
}

/* Error & Success Banners */
.error-banner {
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
    margin-top: 1rem;
    color: #dc2626;
    font-size: 0.875rem;
}

.success-banner {
    background-color: #dcfce7;
    border: 1px solid #86efac;
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
    margin-top: 1rem;
    color: #16a34a;
    font-size: 0.875rem;
}

/* Connector Overview Specific Styles */
.connector-overview-page .header-actions {
    position: relative;
}

.connector-overview-page .dropdown {
    position: relative;
}

.connector-overview-page .dropdown-toggle {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.connector-overview-page .dropdown-toggle::after {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 0.3rem solid transparent;
    border-right: 0.3rem solid transparent;
    border-top: 0.3rem solid currentColor;
    margin-left: 0.25rem;
}

.connector-overview-page .dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 0.5rem;
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    min-width: 180px;
    z-index: 100;
    display: none;
}

.connector-overview-page .dropdown-menu.show {
    display: block;
}

.connector-overview-page .dropdown-item {
    display: block;
    width: 100%;
    padding: 0.625rem 1rem;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.875rem;
    color: var(--text-primary);
    transition: background-color 0.15s;
}

.connector-overview-page .dropdown-item:hover {
    background-color: var(--background-color);
}

.connector-overview-page .dropdown-item:first-child {
    border-radius: 0.5rem 0.5rem 0 0;
}

.connector-overview-page .dropdown-item:last-child {
    border-radius: 0 0 0.5rem 0.5rem;
}

/* Connectors Grid */
.connectors-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 1.5rem;
}

/* Connector Card */
.connector-card {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.connector-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.connector-card.active {
    border-color: #86efac;
}

.connector-card.inactive {
    border-color: #fecaca;
}

.connector-card .connector-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 1.25rem 1.5rem;
    background-color: var(--background-color);
    border-bottom: 1px solid var(--border-color);
}

.connector-card .connector-info h3 {
    margin: 0 0 0.25rem 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
}

.connector-card .connector-type {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.connector-card .connector-status .status-badge {
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.connector-card .connector-status .status-badge.active {
    background-color: #dcfce7;
    color: #16a34a;
}

.connector-card .connector-status .status-badge.inactive {
    background-color: #fef2f2;
    color: #dc2626;
}

.connector-card .connector-details {
    padding: 1.25rem 1.5rem;
}

.connector-card .detail-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
}

.connector-card .detail-row:last-child {
    margin-bottom: 0;
}

.connector-card .detail-row .label {
    color: var(--text-secondary);
}

.connector-card .detail-row .value {
    color: var(--text-primary);
    font-weight: 500;
}

.connector-card .connector-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 1rem 1.5rem;
    background-color: var(--background-color);
    border-top: 1px solid var(--border-color);
}

/* No Connectors Notice */
.no-connectors-notice,
.no-config-notice {
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    padding: 3rem 2rem;
    text-align: center;
}

.no-connectors-notice p,
.no-config-notice p {
    margin: 0 0 0.5rem 0;
    font-size: 0.9375rem;
    color: var(--text-secondary);
}

.no-connectors-notice p:last-of-type,
.no-config-notice p:last-of-type {
    margin-bottom: 1.5rem;
}

/* Loading Container */
.loading-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4rem 2rem;
    background-color: var(--card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--border-color);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

.loading-container p {
    margin-top: 1rem;
    color: var(--text-secondary);
    font-size: 0.9375rem;
}

/* Responsive Styles for Integration Pages */
@media (max-width: 768px) {
    .connectors-grid {
        grid-template-columns: 1fr;
    }

    .config-tabs {
        flex-wrap: nowrap;
        padding: 0;
    }

    .config-tabs .tab {
        padding: 0.75rem 1rem;
        font-size: 0.8125rem;
    }

    .connector-card .connector-actions {
        flex-direction: column;
    }

    .connector-card .connector-actions .btn {
        width: 100%;
    }

    .calculator-form {
        flex-direction: column;
        align-items: stretch;
    }

    .calculator-form .form-group {
        flex: 1 1 auto;
    }

    .token-status {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }

    .token-status .btn {
        margin-left: 0;
    }

    .connection-status {
        flex-direction: column;
        align-items: flex-start;
    }

    .connector-overview-page .page-actions,
    .ebay-config-page .page-actions,
    .cardmarket-config-page .page-actions,
    .woocommerce-config-page .page-actions,
    .ebay-kleinanzeigen-config-page .page-actions {
        flex-direction: column;
    }

    .connector-overview-page .page-actions .btn,
    .ebay-config-page .page-actions .btn,
    .cardmarket-config-page .page-actions .btn,
    .woocommerce-config-page .page-actions .btn,
    .ebay-kleinanzeigen-config-page .page-actions .btn {
        width: 100%;
    }
}

/* ==================================================================
   MESSAGES PAGE STYLES
   ================================================================== */

.messages-page {
    padding: 0;
    height: calc(100vh - 60px);
    overflow: hidden;
}

.messages-container {
    display: flex;
    height: 100%;
    background-color: var(--card-bg);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Conversation Panel (Left Side) */
.conversation-panel {
    width: 380px;
    min-width: 320px;
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    background-color: var(--card-bg);
}

.conversation-panel .panel-header {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.conversation-panel .panel-header h2 {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-primary);
}

.unread-badge {
    background-color: var(--danger-color);
    color: white;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.5rem;
    border-radius: 9999px;
    min-width: 22px;
    text-align: center;
}

.conversation-filters {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.search-input-wrapper {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 0.5rem 0.75rem;
}

.search-input-wrapper i {
    color: var(--text-secondary);
}

.search-input-wrapper input {
    flex: 1;
    border: none;
    background: transparent;
    outline: none;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.filter-buttons {
    display: flex;
    gap: 0.5rem;
}

.filter-btn {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
    background-color: transparent;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all 0.15s ease;
}

.filter-btn:hover {
    background-color: var(--background-color);
}

.filter-btn.active {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.connector-filter {
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: var(--background-color);
    color: var(--text-primary);
    cursor: pointer;
}

/* Conversation List */
.conversation-list {
    flex: 1;
    overflow-y: auto;
}

.conversation-item {
    display: flex;
    padding: 1rem 1.25rem;
    gap: 0.75rem;
    cursor: pointer;
    border-bottom: 1px solid var(--border-color);
    transition: background-color 0.15s ease;
}

.conversation-item:hover {
    background-color: var(--background-color);
}

.conversation-item.selected {
    background-color: rgba(59, 130, 246, 0.1);
    border-left: 3px solid var(--primary-color);
    padding-left: calc(1.25rem - 3px);
}

.conversation-item.unread {
    background-color: rgba(59, 130, 246, 0.05);
}

.conversation-item.unread .participant-name {
    font-weight: 600;
}

.conversation-avatar {
    position: relative;
    flex-shrink: 0;
}

.conversation-avatar img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.avatar-placeholder {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background-color: var(--background-color);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    font-size: 1.25rem;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23a0a0a0'><circle cx='12' cy='8' r='4'/><path d='M4 20c0-4 4-6 8-6s8 2 8 6'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%;
    color: transparent;
}

.connector-badge {
    position: absolute;
    bottom: 5px;
    right: 0;
    width: 16px;
    height: 16px;
    border-radius: 50%;
}

.connector-badge.ebay {
    background-color: #0064d2;
}

.connector-badge.ebaykleinanzeigen {
    background-color: #86b817;
}

.connector-badge.cardmarket {
    background-color: #ff6b00;
}

.connector-badge.woocommerce {
    background-color: #7f54b3;
}

.connector-badge.kaufland {
    display: inline-block;
    width: 28px;
    height: 28px;
    background-size: contain;
    padding: 5px;
    background-origin: content-box;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='27.146 29.819 442.036 442.026'><path fill='%23e10915' d='M 27.146 29.819 L 27.146 232.912 L 230.239 232.912 L 230.239 29.819 L 27.146 29.819 Z M 266.089 29.819 L 266.089 232.912 L 469.182 29.819 L 266.089 29.819 Z M 27.146 268.752 L 27.146 471.845 L 230.239 471.845 L 230.239 268.752 L 27.146 268.752 Z M 266.089 268.752 L 266.089 471.845 L 469.182 471.845 L 266.089 268.752 Z'/></svg>");
}

.conversation-content {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.conversation-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.25rem;
}

.participant-name {
    font-size: 0.9375rem;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.conversation-time {
    font-size: 0.75rem;
    color: var(--text-secondary);
    white-space: nowrap;
}

.conversation-subject {
    font-size: 0.8125rem;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.conversation-preview {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.conversation-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.5rem;
}

.conversation-actions .starred {
    color: #f59e0b;
}

.unread-count {
    background-color: var(--primary-color);
    color: white;
    font-size: 0.6875rem;
    font-weight: 600;
    padding: 0.125rem 0.375rem;
    border-radius: 9999px;
    min-width: 18px;
    text-align: center;
}

.conversation-pagination {
    padding: 0.75rem 1.25rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

/* Message Panel (Right Side) */
.message-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.message-panel.empty {
    background-color: var(--background-color);
}

.no-conversation-selected {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    text-align: center;
    padding: 2rem;
}

.no-conversation-selected i {
    font-size: 4rem;
    margin-bottom: 1.5rem;
    opacity: 0.5;
}

.no-conversation-selected h3 {
    margin: 0 0 0.5rem;
    font-weight: 500;
}

.no-conversation-selected p {
    margin: 0;
    font-size: 0.875rem;
}

/* Message Header */
.message-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    gap: 1rem;
    background-color: var(--card-bg);
}

.message-header .back-btn {
    display: none;
    padding: 0.5rem;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    border-radius: 6px;
}

.message-header .back-btn:hover {
    background-color: var(--background-color);
}

.conversation-info {
    flex: 1;
    min-width: 0;
}

.participant-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.participant-info strong {
    font-size: 1rem;
    color: var(--text-primary);
}

.participant-info .email {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.conversation-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 0.375rem;
}

.connector-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    color: white;
}

.connector-tag.ebay {
    background-color: #0064d2;
}

.connector-tag.ebaykleinanzeigen {
    background-color: #86b817;
}

.connector-tag.cardmarket {
    background-color: #ff6b00;
}

.connector-tag.woocommerce {
    background-color: #7f54b3;
}

.offer-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    background-color: var(--background-color);
    border-radius: 4px;
    color: var(--text-secondary);
}

.message-actions {
    display: flex;
    gap: 0.5rem;
}

.action-btn {
    padding: 0.5rem;
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all 0.15s ease;
}

.action-btn:hover {
    background-color: var(--background-color);
    color: var(--text-primary);
}

.action-btn.active {
    color: #f59e0b;
}

/* Messages List */
.messages-list {
    flex: 1;
    overflow-y: auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    background-color: var(--background-color);
}

.date-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1rem 0;
}

.date-divider span {
    background-color: var(--background-color);
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
    border-radius: 9999px;
    background-color: rgba(0, 0, 0, 0.05);
}

.message {
    display: flex;
    max-width: 70%;
}

.message.incoming {
    align-self: flex-start;
}

.message.outgoing {
    align-self: flex-end;
}

.message-content {
    padding: 0.75rem 1rem;
    border-radius: 12px;
    position: relative;
}

.message.incoming .message-content {
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    border-bottom-left-radius: 4px;
}

.message.outgoing .message-content {
    background-color: var(--primary-color);
    color: white;
    border-bottom-right-radius: 4px;
}

.message.pending .message-content {
    opacity: 0.7;
}

.message.failed .message-content {
    background-color: rgba(239, 68, 68, 0.1);
    border: 1px solid var(--danger-color);
}

.message.outgoing.failed .message-content {
    background-color: rgba(239, 68, 68, 0.2);
    color: var(--text-primary);
}

.message-attachment {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.8125rem;
}

.message-attachment a {
    color: inherit;
    text-decoration: underline;
}

.message-text {
    font-size: 0.9375rem;
    line-height: 1.5;
    white-space: pre-wrap;
    word-break: break-word;
}

.message-meta {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.375rem;
    margin-top: 0.375rem;
}

.message-time {
    font-size: 0.6875rem;
    opacity: 0.7;
}

.message-status i {
    font-size: 0.75rem;
}

.message-error {
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: var(--danger-color);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.retry-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    background-color: transparent;
    border: 1px solid var(--danger-color);
    border-radius: 4px;
    color: var(--danger-color);
    cursor: pointer;
    font-size: 0.75rem;
}

.retry-btn:hover {
    background-color: var(--danger-color);
    color: white;
}

.no-messages {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Message Input */
.message-input-container {
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--border-color);
    background-color: var(--card-bg);
}

.message-input-wrapper {
    display: flex;
    gap: 0.75rem;
    align-items: flex-end;
}

.message-input-wrapper textarea {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    resize: none;
    font-family: inherit;
    font-size: 0.9375rem;
    line-height: 1.5;
    max-height: 150px;
    outline: none;
}

.message-input-wrapper textarea:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.send-btn {
    padding: 0.75rem 1rem;
    background-color: var(--primary-color);
    border: none;
    border-radius: 8px;
    color: white;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.send-btn:hover:not(:disabled) {
    background-color: var(--primary-dark);
}

.send-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.send-btn i {
    font-size: 1.125rem;
}

.input-hint {
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Loading States */
.messages-page .loading-state {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    color: var(--text-secondary);
    padding: 2rem;
}

.messages-page .loading-spinner.small {
    width: 18px;
    height: 18px;
    border-width: 2px;
}

.messages-page .empty-state {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    text-align: center;
    padding: 2rem;
}

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

/* Responsive Design for Messages */
@media (max-width: 992px) {
    .conversation-panel {
        width: 100%;
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        z-index: 10;
        transition: transform 0.3s ease;
    }

    .conversation-panel.has-selection {
        transform: translateX(-100%);
    }

    .message-panel {
        width: 100%;
    }

    .message-header .back-btn {
        display: flex;
    }

    .message {
        max-width: 85%;
    }
}

@media (max-width: 576px) {
    .conversation-filters {
        padding: 0.75rem 1rem;
    }

    .filter-buttons {
        flex-wrap: wrap;
    }

    .conversation-item {
        padding: 0.75rem 1rem;
    }

    .message-header {
        padding: 0.75rem 1rem;
    }

    .messages-list {
        padding: 1rem;
    }

    .message-input-container {
        padding: 0.75rem 1rem;
    }
}
