/*
 * SponsorshipSearch - Global Layout Fix
 * This file fixes alignment issues across all pages
 */

/* ============================================
   GLOBAL RESET & BASE
   ============================================ */
   
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #374151;
    background: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Fixed header space */
body:not(.home) {
    padding-top: 80px;
}

body.home,
body.ss-home {
    padding-top: 0;
}

/* ============================================
   MAIN CONTENT WRAPPER
   ============================================ */

#main-content {
    width: 100%;
    min-height: calc(100vh - 400px);
}

/* ============================================
   UNIVERSAL CONTAINER SYSTEM
   ============================================ */

/* Main container - centers content */
.ss-container,
.ss-section-container,
.ss-page-container,
.container,
.site-container {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 24px;
    padding-right: 24px;
}

/* Narrow container for text content */
.ss-container-narrow {
    max-width: 800px;
}

/* Wide container */
.ss-container-wide {
    max-width: 1400px;
}

/* Full width (no max) */
.ss-container-full {
    max-width: 100%;
    padding-left: 24px;
    padding-right: 24px;
}

/* ============================================
   PLUGIN CONTENT ALIGNMENT FIX
   ============================================ */

/* Force plugin shortcode content to be centered */
.ss-page-content,
.entry-content,
.page-content {
    width: 100%;
}

/* Browse Events Page */
.ss-browse-events,
.ss-events-page,
.ss-event-filters-wrap,
[class*="ss-browse"],
[class*="ss-filter"] {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 24px;
    padding-right: 24px;
}

/* Dashboard Pages */
.ss-dashboard,
.ss-dashboard-wrap,
.ss-organizer-dashboard,
.ss-sponsor-dashboard,
[class*="ss-dashboard"] {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding: 40px 24px;
}

/* Single Event Page */
.ss-single-event,
.ss-event-single,
.ss-event-page,
.single-ss_event .entry-content,
.single-ss_event .ss-page-content {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 24px;
    padding-right: 24px;
}

/* Forms (Submit Event, Edit Event, Register, Login) */
.ss-form-wrap,
.ss-submit-form,
.ss-edit-form,
.ss-auth-wrapper,
.ss-registration-form,
.ss-login-form {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding: 40px 24px;
}

/* Profile Pages */
.ss-profile,
.ss-profile-wrap,
.ss-organizer-profile,
.ss-sponsor-profile {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding: 40px 24px;
}

/* ============================================
   PAGE HEADER (Title Bar)
   ============================================ */

.ss-page-header {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    padding: 60px 0;
    text-align: center;
    margin-bottom: 0;
}

.ss-page-header h1 {
    color: #fff;
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    margin: 0;
}

.ss-page-header p {
    color: rgba(255, 255, 255, 0.8);
    margin: 10px 0 0;
}

/* ============================================
   SECTIONS
   ============================================ */

.ss-section {
    padding: 80px 0;
}

.ss-section-sm {
    padding: 40px 0;
}

.ss-section-lg {
    padding: 100px 0;
}

.ss-section-gray {
    background: #f9fafb;
}

.ss-section-dark {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    color: #fff;
}

/* ============================================
   GRID SYSTEM
   ============================================ */

.ss-grid {
    display: grid;
    gap: 24px;
}

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

.ss-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

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

.ss-grid-auto {
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

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

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

/* ============================================
   FLEXBOX UTILITIES
   ============================================ */

.ss-flex {
    display: flex;
}

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

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

.ss-flex-wrap {
    flex-wrap: wrap;
}

.ss-gap-2 { gap: 8px; }
.ss-gap-4 { gap: 16px; }
.ss-gap-6 { gap: 24px; }
.ss-gap-8 { gap: 32px; }

/* ============================================
   TYPOGRAPHY
   ============================================ */

h1, h2, h3, h4, h5, h6 {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    font-weight: 700;
    line-height: 1.2;
    color: #1a1a2e;
    margin: 0 0 0.5em;
}

h1 { font-size: clamp(2rem, 5vw, 3rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2.25rem); }
h3 { font-size: clamp(1.25rem, 3vw, 1.5rem); }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }

p {
    margin: 0 0 1em;
}

a {
    color: #EA7462;
    text-decoration: none;
    transition: color 0.2s;
}

a:hover {
    color: #d85a47;
}

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

.ss-btn,
button.ss-btn,
a.ss-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    font-size: 0.9375rem;
    font-weight: 600;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.2s;
    line-height: 1.4;
}

.ss-btn-primary {
    background: linear-gradient(135deg, #EA7462, #e85d4a);
    color: #fff;
}

.ss-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(234, 116, 98, 0.35);
    color: #fff;
}

.ss-btn-secondary {
    background: linear-gradient(135deg, #667EEA, #5a67d8);
    color: #fff;
}

.ss-btn-secondary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(102, 126, 234, 0.35);
    color: #fff;
}

.ss-btn-outline {
    background: transparent;
    border: 2px solid #EA7462;
    color: #EA7462;
}

.ss-btn-outline:hover {
    background: #EA7462;
    color: #fff;
}

.ss-btn-sm {
    padding: 8px 16px;
    font-size: 0.875rem;
}

.ss-btn-lg {
    padding: 16px 32px;
    font-size: 1rem;
}

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

.ss-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
}

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

.ss-card-body {
    padding: 24px;
}

/* ============================================
   EVENT CARDS (Plugin Override)
   ============================================ */

.ss-event-card,
.event-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
}

.ss-event-card:hover,
.event-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.15);
}

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

.ss-form-group {
    margin-bottom: 20px;
}

.ss-form-group label {
    display: block;
    font-weight: 600;
    color: #374151;
    margin-bottom: 8px;
    font-size: 0.875rem;
}

.ss-form-group input,
.ss-form-group select,
.ss-form-group textarea {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid #e5e7eb;
    border-radius: 8px;
    font-size: 1rem;
    font-family: inherit;
    transition: border-color 0.2s, box-shadow 0.2s;
    background: #fff;
}

.ss-form-group input:focus,
.ss-form-group select:focus,
.ss-form-group textarea:focus {
    outline: none;
    border-color: #EA7462;
    box-shadow: 0 0 0 4px rgba(234, 116, 98, 0.1);
}

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

.ss-badge {
    display: inline-block;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 50px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ss-badge-primary {
    background: rgba(234, 116, 98, 0.1);
    color: #EA7462;
}

.ss-badge-secondary {
    background: rgba(102, 126, 234, 0.1);
    color: #667EEA;
}

.ss-badge-success {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.ss-badge-warning {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.ss-badge-danger {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
    body:not(.home) {
        padding-top: 70px;
    }
    
    .ss-container,
    .ss-section-container,
    .ss-page-container {
        padding-left: 16px;
        padding-right: 16px;
    }
    
    .ss-section {
        padding: 50px 0;
    }
    
    .ss-page-header {
        padding: 40px 0;
    }
}

/* ============================================
   TEXT UTILITIES
   ============================================ */

.ss-text-center { text-align: center; }
.ss-text-left { text-align: left; }
.ss-text-right { text-align: right; }

.ss-text-sm { font-size: 0.875rem; }
.ss-text-lg { font-size: 1.125rem; }
.ss-text-xl { font-size: 1.25rem; }

.ss-text-muted { color: #6b7280; }
.ss-text-primary { color: #EA7462; }
.ss-text-success { color: #059669; }

/* ============================================
   SPACING UTILITIES
   ============================================ */

.ss-mt-4 { margin-top: 16px; }
.ss-mt-8 { margin-top: 32px; }
.ss-mb-4 { margin-bottom: 16px; }
.ss-mb-8 { margin-bottom: 32px; }
.ss-my-4 { margin-top: 16px; margin-bottom: 16px; }
.ss-my-8 { margin-top: 32px; margin-bottom: 32px; }

.ss-pt-4 { padding-top: 16px; }
.ss-pt-8 { padding-top: 32px; }
.ss-pb-4 { padding-bottom: 16px; }
.ss-pb-8 { padding-bottom: 32px; }
.ss-py-4 { padding-top: 16px; padding-bottom: 16px; }
.ss-py-8 { padding-top: 32px; padding-bottom: 32px; }

/* ============================================
   FOOTER - CONSISTENT ACROSS ALL PAGES
   ============================================ */

.ss-footer {
    background: #1a1a2e;
    color: #fff;
    padding: 80px 0 0;
    margin-top: auto;
}

.ss-footer .ss-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.ss-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.ss-footer-brand {
    padding-right: 32px;
}

.ss-footer-brand .ss-logo {
    display: inline-block;
    margin-bottom: 20px;
}

.ss-footer-brand .ss-logo img {
    height: 40px;
    width: auto;
    filter: brightness(0) invert(1);
}

.ss-footer-brand p {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9375rem;
    line-height: 1.7;
    margin: 0 0 24px;
}

.ss-footer-social {
    display: flex;
    gap: 12px;
}

.ss-footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: #fff;
    transition: all 0.2s;
}

.ss-footer-social a:hover {
    background: #EA7462;
    transform: translateY(-2px);
}

.ss-footer-title {
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 20px;
}

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

.ss-footer-links li {
    margin-bottom: 12px;
}

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

.ss-footer-links a:hover {
    color: #EA7462;
}

.ss-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 0;
    margin-top: 0;
}

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

@media (max-width: 992px) {
    .ss-footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 40px;
    }
    
    .ss-footer-brand {
        grid-column: span 2;
        padding-right: 0;
    }
}

@media (max-width: 576px) {
    .ss-footer {
        padding: 60px 0 0;
    }
    
    .ss-footer-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    
    .ss-footer-brand {
        grid-column: span 1;
    }
    
    .ss-footer-bottom {
        flex-direction: column;
        gap: 12px;
        text-align: center;
    }
}

/* ============================================
   SINGLE EVENT PAGE - FIX OVERLAP
   ============================================ */

/* Event Hero Section */
.ss-event-hero,
.single-ss_event .ss-event-header,
.ss-single-event-hero,
[class*="event-hero"],
[class*="event-header"] {
    padding-top: 100px !important;
    position: relative;
}

/* Category Badge - prevent overlap */
.ss-event-hero .ss-event-category,
.ss-event-category-badge,
.single-ss_event .event-category,
[class*="event-category"] {
    display: inline-block !important;
    margin-bottom: 16px !important;
    position: relative !important;
    z-index: 1 !important;
}

/* Event Title - ensure proper spacing */
.ss-event-hero h1,
.ss-event-title,
.single-ss_event h1,
.single-ss_event .entry-title {
    margin-top: 0 !important;
    padding-top: 0 !important;
    position: relative !important;
    z-index: 1 !important;
}

/* Fix the category bar that's stretching */
.ss-event-hero .category-bar,
.event-category-bar,
[class*="category-bar"] {
    width: auto !important;
    max-width: fit-content !important;
    display: inline-block !important;
}

/* Single Event Content */
.single-ss_event #main-content,
.single-ss_event .ss-page-content {
    padding-top: 0;
}

/* Single Event - Body padding */
body.single-ss_event {
    padding-top: 80px;
}

/* Ensure hero is full width but content inside centered */
.ss-event-hero .ss-container,
.ss-event-hero .container,
.ss-event-hero > div:first-child {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}


/* ==================================================
   FORCE DASHBOARD TO ESCAPE PAGE LAYOUT (FINAL FIX)
================================================== */

/* Stop blog layout rules from affecting dashboards */
.ss-page-content .ss-dashboard {
    max-width: none !important;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: 40px;
    padding-right: 40px;
}

/* Re-center inner dashboard content cleanly */
.ss-dashboard > * {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

/* Remove ALL typography constraints */
.ss-dashboard h1,
.ss-dashboard h2,
.ss-dashboard h3,
.ss-dashboard p,
.ss-dashboard ul,
.ss-dashboard ol {
    max-width: none !important;
}

/* Mobile safety */
@media (max-width: 768px) {
    .ss-page-content .ss-dashboard {
        padding-left: 20px;
        padding-right: 20px;
    }
}

#ss-dashboard-root {
    width: 100%;
    max-width: none;
    padding: 0;
    margin: 0;
}

