/**
 * Custom styles for Remoto Theme - Neobrutalism Edition
 * Additional styles and overrides
 */

/*--------------------------------------------------------------
# Additional Neobrutalism Elements
--------------------------------------------------------------*/

/* Animated Hover Effects */
.job_listing,
.btn,
button,
.main-navigation a {
    position: relative;
    overflow: visible;
}

/* Job Filters Styling - Neobrutalism */
.job_filters {
    background: var(--color-primary);
    padding: var(--spacing-xl);
    border: var(--border);
    margin-bottom: var(--spacing-xl);
    box-shadow: var(--shadow-xl);
}

.job_filters h3 {
    color: var(--color-white);
    text-transform: uppercase;
    margin-bottom: var(--spacing-md);
    text-shadow: 3px 3px 0 var(--color-black);
}

/* Search Jobs Container */
.search_jobs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

/* Search Keywords and Location */
.search_keywords,
.search_location {
    display: flex;
    flex-direction: column;
}

.search_keywords label,
.search_location label {
    color: var(--color-white);
    font-weight: 900;
    text-transform: uppercase;
    margin-bottom: var(--spacing-xs);
    font-size: 0.9rem;
    letter-spacing: 0.5px;
}

#search_keywords,
#search_location {
    background: var(--color-white);
    border: var(--border);
    padding: var(--spacing-md);
    font-size: 1rem;
    font-weight: 600;
    box-shadow: var(--shadow-md);
    transition: all 0.2s ease;
}

#search_keywords:focus,
#search_location:focus {
    outline: none;
    transform: translate(-2px, -2px);
    box-shadow: 6px 6px 0 var(--color-black);
    border-color: var(--color-highlight);
}

#search_keywords::placeholder,
#search_location::placeholder {
    color: var(--color-gray-300);
    font-weight: 600;
}

/* Search Submit Button */
.search_submit {
    grid-column: 1 / -1;
}

.search_submit input[type="submit"] {
    width: 100%;
    background: var(--color-accent);
    color: var(--color-white);
    border: var(--border);
    padding: var(--spacing-md) var(--spacing-xl);
    font-weight: 900;
    text-transform: uppercase;
    font-size: 1.1rem;
    cursor: pointer;
    box-shadow: var(--shadow-lg);
    letter-spacing: 1px;
    transition: all 0.2s ease;
}

.search_submit input[type="submit"]:hover {
    background: var(--color-highlight);
    transform: translate(-3px, -3px);
    box-shadow: 10px 10px 0 var(--color-black);
}

.search_submit input[type="submit"]:active {
    transform: translate(0, 0);
    box-shadow: 3px 3px 0 var(--color-black);
}

/* Job Types Filters (if present) */
.job_types {
    list-style: none;
    padding: 0;
    margin: var(--spacing-md) 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.job_types li {
    border: none;
}

.job_types label {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    background: var(--color-white);
    border: var(--border);
    padding: var(--spacing-xs) var(--spacing-md);
    font-weight: 700;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    transition: all 0.2s ease;
}

.job_types label:hover {
    background: var(--color-highlight);
    color: var(--color-white);
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--color-black);
}

.job_types input[type="checkbox"] {
    width: auto;
    margin: 0;
}

/* Showing Jobs Bar */
.showing_jobs {
    background: var(--color-highlight);
    color: var(--color-white);
    padding: var(--spacing-sm) var(--spacing-md);
    border: var(--border);
    margin-top: var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 700;
    box-shadow: var(--shadow-sm);
}

.showing_jobs span {
    font-weight: 900;
    text-transform: uppercase;
}

.showing_jobs .rss_link {
    background: var(--color-white);
    color: var(--color-black);
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 2px solid var(--color-black);
    font-weight: 900;
    text-transform: uppercase;
    font-size: 0.85rem;
    text-decoration: none;
    box-shadow: 2px 2px 0 var(--color-black);
    transition: all 0.2s ease;
}

.showing_jobs .rss_link:hover {
    background: var(--color-accent);
    color: var(--color-white);
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--color-black);
}

/* Load More Jobs Button */
.load_more_jobs {
    display: inline-block;
    width: 100%;
    text-align: center;
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--color-highlight);
    color: var(--color-white);
    border: var(--border);
    font-weight: 900;
    text-transform: uppercase;
    font-size: 1.1rem;
    margin-top: var(--spacing-lg);
    box-shadow: var(--shadow-lg);
    transition: all 0.2s ease;
}

.load_more_jobs:hover {
    background: var(--color-accent);
    transform: translate(-3px, -3px);
    box-shadow: 10px 10px 0 var(--color-black);
}

/* Entry Header for Job Listings Page */
.entry-header {
    background: var(--color-primary);
    padding: var(--spacing-xl);
    border: var(--border);
    margin-bottom: var(--spacing-xl);
    box-shadow: var(--shadow-xl);
}

.entry-header .entry-title {
    color: var(--color-white);
    text-shadow: 4px 4px 0 var(--color-black);
    margin: 0;
}

/* Entry Content */
.entry-content {
    margin-top: var(--spacing-lg);
}

/* Small text in location */
.location small {
    font-size: 0.75rem;
    opacity: 0.8;
}

/* Job Listing Additional Styles */
.job_listing_preview_title {
    color: var(--color-black);
}

/* Override for company logo default */
.company_logo {
    max-width: 100%;
    height: auto;
    object-fit: contain;
}

/* Noscript message */
noscript {
    display: block;
    background: var(--color-accent);
    color: var(--color-white);
    padding: var(--spacing-md);
    border: var(--border);
    margin-bottom: var(--spacing-md);
    font-weight: 700;
    box-shadow: var(--shadow-md);
}

.job-package {
    background: var(--color-highlight);
    color: var(--color-white);
    padding: var(--spacing-xs) var(--spacing-md);
    border: var(--border);
    display: inline-block;
    font-weight: 900;
    text-transform: uppercase;
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--spacing-md);
}

/* Pagination */
.wp-pagenavi,
.posts-navigation,
.pagination {
    display: flex;
    gap: var(--spacing-sm);
    justify-content: center;
    margin: var(--spacing-xl) 0;
}

.wp-pagenavi a,
.wp-pagenavi span,
.posts-navigation a,
.page-numbers {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-white);
    border: var(--border);
    color: var(--color-black);
    font-weight: 900;
    box-shadow: var(--shadow-sm);
    transition: all 0.2s ease;
}

.wp-pagenavi a:hover,
.posts-navigation a:hover,
.page-numbers:hover {
    background: var(--color-highlight);
    color: var(--color-white);
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--color-black);
}

.wp-pagenavi .current,
.page-numbers.current {
    background: var(--color-primary);
    color: var(--color-white);
}

/* Widgets */
.widget {
    background: var(--color-white);
    border: var(--border);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--shadow-md);
}

.widget-title {
    color: var(--color-primary);
    text-transform: uppercase;
    border-bottom: var(--border);
    padding-bottom: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.widget ul {
    list-style: none;
    padding: 0;
}

.widget li {
    padding: var(--spacing-xs) 0;
    border-bottom: 2px solid var(--color-gray-100);
}

.widget li:last-child {
    border-bottom: none;
}

.widget a {
    color: var(--color-black);
    font-weight: 700;
    transition: all 0.2s ease;
}

.widget a:hover {
    color: var(--color-highlight);
    padding-left: var(--spacing-xs);
}

/* Comments */
.comment-list {
    list-style: none;
    padding: 0;
}

.comment {
    background: var(--color-white);
    border: var(--border);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    box-shadow: var(--shadow-sm);
}

.comment-author {
    font-weight: 900;
    color: var(--color-primary);
    margin-bottom: var(--spacing-xs);
}

.comment-meta {
    font-size: 0.85rem;
    color: var(--color-gray-300);
    margin-bottom: var(--spacing-sm);
}

.reply {
    margin-top: var(--spacing-sm);
}

.reply a {
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-highlight);
    color: var(--color-white);
    border: var(--border);
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    box-shadow: var(--shadow-sm);
}

/* Comment Form */
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    margin-bottom: var(--spacing-md);
}

.comment-form label {
    font-weight: 700;
    color: var(--color-black);
    margin-bottom: var(--spacing-xs);
    display: block;
}

/* Job Manager Form Styles */
.fieldset-job_title,
.fieldset-job_location,
.fieldset-job_type,
.fieldset-job_description,
.fieldset-application,
.fieldset-company_name,
.fieldset-company_website,
.fieldset-company_tagline,
.fieldset-company_twitter,
.fieldset-company_logo {
    margin-bottom: var(--spacing-lg);
}

.fieldset-job_title label,
.fieldset-job_location label,
.fieldset-job_type label,
.fieldset-job_description label,
.fieldset-application label,
.fieldset-company_name label {
    font-weight: 900;
    color: var(--color-black);
    text-transform: uppercase;
    margin-bottom: var(--spacing-sm);
    display: block;
}

.field {
    margin-bottom: var(--spacing-md);
}

.field_description {
    font-size: 0.9rem;
    color: var(--color-gray-300);
    margin-top: var(--spacing-xs);
    font-weight: 600;
}

/* File Upload */
.job-manager-uploaded-file {
    background: var(--color-white);
    border: var(--border);
    padding: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    box-shadow: var(--shadow-sm);
}

/* Alert Messages */
.job-manager-message,
.woocommerce-message,
.woocommerce-error {
    background: var(--color-white);
    border: var(--border);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    box-shadow: var(--shadow-md);
    font-weight: 700;
}

.job-manager-message {
    border-left: 5px solid var(--color-highlight);
}

.woocommerce-message {
    border-left: 5px solid #4ade80;
}

.woocommerce-error {
    border-left: 5px solid var(--color-accent);
}

/* Tables */
table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border: var(--border);
    box-shadow: var(--shadow-md);
    margin-bottom: var(--spacing-lg);
}

thead {
    background: var(--color-primary);
    color: var(--color-white);
}

th {
    padding: var(--spacing-sm);
    text-align: left;
    font-weight: 900;
    text-transform: uppercase;
    border-right: var(--border);
}

th:last-child {
    border-right: none;
}

td {
    padding: var(--spacing-sm);
    border-top: var(--border);
    border-right: var(--border);
}

td:last-child {
    border-right: none;
}

tr:hover {
    background: var(--color-gray-100);
}

/* Blockquotes */
blockquote {
    background: var(--color-white);
    border-left: 8px solid var(--color-primary);
    border-top: var(--border);
    border-right: var(--border);
    border-bottom: var(--border);
    padding: var(--spacing-lg);
    margin: var(--spacing-lg) 0;
    box-shadow: var(--shadow-md);
    font-style: italic;
    font-weight: 600;
}

blockquote p:last-child {
    margin-bottom: 0;
}

/* Code Blocks */
code {
    background: var(--color-black);
    color: var(--color-white);
    padding: 2px 6px;
    border: 2px solid var(--color-black);
    font-family: var(--font-mono);
    font-size: 0.9rem;
}

pre {
    background: var(--color-black);
    color: var(--color-white);
    padding: var(--spacing-md);
    border: var(--border);
    overflow-x: auto;
    margin: var(--spacing-lg) 0;
    box-shadow: var(--shadow-md);
}

pre code {
    border: none;
    padding: 0;
}

/* Tags */
.tags-links a,
.cat-links a {
    display: inline-block;
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-white);
    border: var(--border);
    margin: 0 var(--spacing-xs) var(--spacing-xs) 0;
    font-size: 0.85rem;
    font-weight: 700;
    box-shadow: var(--shadow-sm);
    text-transform: uppercase;
}

.tags-links a:hover,
.cat-links a:hover {
    background: var(--color-accent);
    color: var(--color-white);
    transform: translate(-2px, -2px);
    box-shadow: 3px 3px 0 var(--color-black);
}

/* Loading States */
.loading {
    position: relative;
}

.loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    margin: -20px 0 0 -20px;
    border: 4px solid var(--color-gray-200);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

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

/* Utility Classes */
.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

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

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

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

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

.bg-highlight {
    background: var(--color-highlight);
}

.bg-accent {
    background: var(--color-accent);
}

/* Sticky Banner */
.sticky-banner {
    background: var(--color-accent);
    color: var(--color-white);
    padding: var(--spacing-sm);
    text-align: center;
    font-weight: 900;
    border-bottom: var(--border);
    box-shadow: 0 3px 0 var(--color-black);
}

/* Skip to content */
.skip-link {
    background: var(--color-primary);
    color: var(--color-white);
    padding: var(--spacing-sm) var(--spacing-md);
    border: var(--border);
    font-weight: 900;
    text-transform: uppercase;
}

.skip-link:focus {
    clip: auto;
    height: auto;
    width: auto;
    position: absolute;
    top: var(--spacing-sm);
    left: var(--spacing-sm);
    z-index: 100000;
    box-shadow: var(--shadow-lg);
}


/*--------------------------------------------------------------
# Responsive Design - Mobile Optimization
--------------------------------------------------------------*/
@media (max-width: 768px) {
    /* Job Filters */
    .job_filters {
        padding: var(--spacing-md);
    }

    .search_jobs {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
    }

    .search_keywords label,
    .search_location label {
        font-size: 0.85rem;
    }

    #search_keywords,
    #search_location {
        padding: var(--spacing-sm);
        font-size: 0.95rem;
    }

    .search_submit input[type="submit"] {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 1rem;
    }

    /* Job Types */
    .job_types {
        gap: var(--spacing-xs);
    }

    .job_types label {
        font-size: 0.85rem;
        padding: 6px var(--spacing-sm);
    }

    /* Showing Jobs Bar */
    .showing_jobs {
        flex-direction: column;
        gap: var(--spacing-xs);
        text-align: center;
    }

    /* Entry Header */
    .entry-header {
        padding: var(--spacing-md);
    }

    .entry-header .entry-title {
        font-size: 2rem;
        text-shadow: 3px 3px 0 var(--color-black);
    }

    /* Load More Jobs */
    .load_more_jobs {
        font-size: 1rem;
        padding: var(--spacing-sm) var(--spacing-md);
    }
}

@media (max-width: 480px) {
    .search_submit input[type="submit"] {
        font-size: 0.9rem;
        letter-spacing: 0.5px;
    }

    .entry-header .entry-title {
        font-size: 1.75rem;
    }
}
