/**
 * Zonkey Audit - Layout
 */

/* ========================================
   Page Layout
   ======================================== */

.page-wrapper {
    display: flex;
    min-height: 100vh;
}

/* ========================================
   Sidebar
   ======================================== */

.sidebar {
    width: var(--sidebar-width);
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    background-color: var(--color-bg-card);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-5) 0;
    box-shadow: var(--shadow-md);
    z-index: var(--z-sticky);
}

.sidebar-logo {
    margin-bottom: var(--space-10);
}

.sidebar-logo svg,
.sidebar-logo img {
    width: 48px;
    height: 48px;
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    flex: 1;
}

.sidebar-nav-item {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
    color: var(--color-text-secondary);
    font-size: var(--text-xl);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.sidebar-nav-item:hover {
    background-color: var(--color-bg);
    color: var(--color-text-primary);
}

.sidebar-nav-item.active {
    background-color: var(--color-bg);
    color: var(--color-primary);
}

.sidebar-footer {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
}

/* ========================================
   Main Content
   ======================================== */

.main-content {
    flex: 1;
    margin-left: var(--sidebar-width);
    padding: var(--space-8);
    max-height: 100vh;
    overflow-y: auto;
}

/* ========================================
   Header
   ======================================== */

.page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-8);
}

.page-header-left {
    flex: 1;
}

.page-title {
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    margin-bottom: var(--space-1);
}

.page-subtitle {
    font-size: var(--text-base);
    color: var(--color-text-secondary);
}

.page-header-right {
    display: flex;
    align-items: center;
    gap: var(--space-5);
}

.header-icon {
    font-size: var(--text-xl);
    color: var(--color-text-primary);
    cursor: pointer;
    transition: color var(--transition-fast);
}

.header-icon:hover {
    color: var(--color-primary);
}

/* ========================================
   Content Grid
   ======================================== */

.content-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
}

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

.content-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

.col-span-2 { grid-column: span 2; }
.col-span-3 { grid-column: span 3; }

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

    .col-span-3 { grid-column: span 2; }
}

@media (max-width: 768px) {
    .content-grid,
    .content-grid-2 {
        grid-template-columns: 1fr;
    }

    .col-span-2,
    .col-span-3 {
        grid-column: span 1;
    }
}

/* ========================================
   Two Column Layout (Sidebar + Content)
   ======================================== */

.two-column-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--space-6);
    height: calc(100vh - var(--header-height) - var(--space-16));
}

.content-sidebar {
    background-color: var(--color-bg-card);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    overflow-y: auto;
}

.content-main {
    background-color: var(--color-bg-card);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    overflow-y: auto;
}

/* ========================================
   Login Page Layout
   ======================================== */

.login-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: linear-gradient(135deg, var(--color-bg) 0%, #e8e8e8 100%);
}

.login-container {
    width: 100%;
    max-width: 420px;
    padding: var(--space-10);
    background-color: var(--color-bg-card);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    text-align: center;
}

.login-logo {
    margin-bottom: var(--space-8);
}

.login-logo svg,
.login-logo img {
    width: 64px;
    height: 64px;
    margin: 0 auto;
}

.login-title {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-2);
}

.login-subtitle {
    color: var(--color-text-secondary);
    margin-bottom: var(--space-8);
}

.login-form {
    text-align: left;
}

.login-footer {
    margin-top: var(--space-8);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

/* ========================================
   Responsive Sidebar
   ======================================== */

@media (max-width: 768px) {
    .sidebar {
        width: 60px;
    }

    .main-content {
        margin-left: 60px;
        padding: var(--space-4);
    }

    .two-column-layout {
        grid-template-columns: 1fr;
    }

    .content-sidebar {
        display: none;
    }

    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-4);
    }

    .page-header-right {
        width: 100%;
        justify-content: flex-start;
    }
}
