/**
 * MinikOkur Grid and Layout Utilities
 */

.container {
    width: min(100% - var(--space-8), 1200px);
    margin-inline: auto;
    padding-inline: var(--space-4);
}

.reading-container {
    width: min(100% - var(--space-8), 780px);
    margin-inline: auto;
    padding-inline: var(--space-4);
}

.section {
    padding-block: var(--space-16);
}

.flex-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-6);
}

.grid-cols-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
}

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

.grid-cols-4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
}

@media (max-width: 992px) {
    .grid-cols-4, .grid-cols-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .grid-cols-4, .grid-cols-3, .grid-cols-2 {
        grid-template-columns: 1fr;
    }
    .section {
        padding-block: var(--space-10);
    }
}

/* Base Wrapper Headers & Footers */
.app-header {
    background-color: var(--mk-surface);
    border-bottom: 1px solid var(--mk-border);
    padding-block: var(--space-4);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 100;
}

.app-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo-link {
    font-size: var(--font-xl);
    font-weight: 800;
    color: var(--mk-primary);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.logo-star {
    color: var(--mk-accent);
}

.main-nav ul {
    display: flex;
    list-style: none;
    gap: var(--space-6);
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.nav-link {
    font-weight: 600;
    color: var(--mk-text-muted);
}

.nav-link:hover, .nav-link.active {
    color: var(--mk-primary);
}

.nav-cta {
    background-color: var(--mk-primary);
    color: #fff !important;
    padding: var(--space-2) var(--space-5);
    border-radius: var(--radius-md);
    font-weight: 700;
}

.nav-cta:hover {
    background-color: var(--mk-primary-hover);
}

.app-footer {
    background-color: var(--mk-text);
    color: #fff;
    padding-block: var(--space-16);
    margin-top: auto;
}

.app-footer h4 {
    color: #fff;
    margin-bottom: var(--space-5);
}

.app-footer p {
    color: rgba(255, 255, 255, 0.7);
}

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

.footer-col ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.footer-col a {
    color: rgba(255, 255, 255, 0.7);
}

.footer-col a:hover {
    color: var(--mk-accent);
}

@media (max-width: 768px) {
    .container,
    .reading-container {
        width: min(100% - var(--space-4), 1200px);
        padding-inline: var(--space-2);
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .app-header .container {
        flex-direction: column;
        gap: var(--space-4);
    }

    .main-nav {
        width: 100%;
    }

    .main-nav ul {
        justify-content: center;
        gap: var(--space-2);
    }

    .nav-link,
    .nav-cta {
        font-size: 0.86rem;
        line-height: 1.2;
    }

    .nav-cta {
        padding: var(--space-2) var(--space-3);
    }

    .section {
        padding-block: var(--space-8);
    }

    .app-main div[style*="grid-template-columns"],
    .app-main section[style*="grid-template-columns"],
    .app-main form[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
    }

    .app-main div[style*="display: flex"],
    .app-main form[style*="display:flex"],
    .app-main form[style*="display: flex"] {
        max-width: 100%;
    }
}

@media (max-width: 520px) {
    h1 {
        font-size: var(--font-2xl);
    }

    h2 {
        font-size: var(--font-xl);
    }

    .btn {
        width: 100%;
        min-height: 44px;
    }

    .card {
        padding: var(--space-4);
        border-radius: var(--radius-md);
    }

    .app-footer [style*="justify-content:space-between"] {
        justify-content: flex-start !important;
        text-align: left !important;
    }
}
