/* ============================================================
   ADMIN PORTAL CSS - Job Orchestrator Design System
   ============================================================

   This file imports shared design tokens and defines
   admin-portal specific styles.

   Shared tokens are located at: ../app/css/tokens.css

   ============================================================ */

/* Import Shared Design Tokens */
@import url('../../app/css/tokens.css');


/* ========================================
   ADMIN-SPECIFIC OVERRIDES
   Layout dimensions for desktop admin UI
   ======================================== */

:root {
    /* Admin-specific layout dimensions (override shared tokens) */
    --sidebar-width: 250px;
    --topbar-height: 60px;

    /* Admin might have different content width */
    --admin-content-max-width: 1400px;
}


/* ========================================
   CSS RESET (Admin Portal)
   ======================================== */

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

body {
    font-family: var(--font-family);
    background-color: var(--color-bg-page);
    color: var(--color-text-primary);
    line-height: var(--line-height-normal);
}

a {
    text-decoration: none;
    color: inherit;
}


/* ========================================
   UTILITY CLASSES
   ======================================== */

.flex { display: flex; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-md { gap: var(--spacing-md); }

/* Grid Utilities */
.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.gap-2 { gap: var(--spacing-sm); }
.gap-4 { gap: var(--spacing-md); }

/* Responsive Grid */
@media (max-width: 768px) {
    .grid-cols-2, .grid-cols-3, .grid-cols-4 {
        grid-template-columns: 1fr;
    }
}


/* ========================================
   BUTTONS
   ======================================== */

.btn {
    padding: var(--btn-padding-y) var(--btn-padding-x);
    border-radius: var(--radius-button);
    border: none;
    cursor: pointer;
    font-weight: var(--font-weight-medium);
    transition: var(--transition-button);
}

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

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

.btn-secondary {
    background-color: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
    border: 1px solid var(--btn-secondary-border);
}

.btn-secondary:hover {
    background-color: var(--btn-secondary-bg-hover);
}

.btn-sm {
    padding: var(--btn-padding-y-sm) var(--btn-padding-x-sm);
    font-size: var(--font-size-sm);
}

.btn-icon {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.5rem;
    padding: var(--spacing-sm);
    border-radius: var(--radius-sm);
    color: var(--color-text-primary);
    transition: var(--transition-fast);
}

.btn-icon:hover {
    background-color: var(--color-bg-surface-hover);
}


/* ========================================
   CARDS
   ======================================== */

.card {
    background: var(--card-bg);
    padding: var(--card-padding);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-card);
    margin-bottom: var(--spacing-md);
    border: 1px solid var(--card-border);
}


/* ========================================
   TABLES
   ======================================== */

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

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-sm);
    border-radius: var(--radius-md);
    background: var(--color-bg-surface);
}

th, td {
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--color-border);
}

th {
    background-color: var(--color-bg-surface-alt);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}


/* ========================================
   BADGES
   ======================================== */

.badge {
    padding: 4px 10px;
    border-radius: var(--radius-badge);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    display: inline-block;
    white-space: nowrap;
}

.badge-success {
    background: var(--badge-success-bg);
    color: var(--badge-success-fg);
}

.badge-warning {
    background: var(--badge-warning-bg);
    color: var(--badge-warning-fg);
}

.badge-gray, .badge-neutral {
    background: var(--badge-neutral-bg);
    color: var(--badge-neutral-fg);
}

.badge-error, .badge-danger {
    background: var(--badge-error-bg);
    color: var(--badge-error-fg);
}

.badge-info {
    background: var(--badge-info-bg);
    color: var(--badge-info-fg);
}


/* ========================================
   FORMS
   ======================================== */

.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: var(--input-padding-y) var(--input-padding-x);
    border: 1px solid var(--input-border);
    border-radius: var(--radius-input);
    background-color: var(--input-bg);
    color: var(--input-text);
    font-family: inherit;
    font-size: inherit;
    transition: var(--transition-input);
}

.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none;
    border-color: var(--input-border-focus);
    box-shadow: 0 0 0 2px var(--color-focus-ring);
}

.form-input::placeholder {
    color: var(--input-placeholder);
}


/* ========================================
   PAGE TRANSITIONS
   ======================================== */

#view-container {
    transition: opacity var(--duration-fast) var(--ease-in-out);
}

#view-container.page-transitioning {
    opacity: 0.3;
}
