/* UW Posters - Shared Styles */

/* CSS Variables */
:root {
    --spacing: 1vw;
    --border-radius: min(2vw, 12px);
}

/* Global Reset and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Nunito', sans-serif;
    background: #000;
    color: #fff;
    line-height: 1.6;
    min-height: 100vh;
}

/* Header Styles */
.header {
    padding: calc(var(--spacing) * 2) var(--spacing) var(--spacing) var(--spacing);
    text-align: left;
}

.header h1 {
    font-size: min(6vw, 2rem);
    font-weight: 700;
    color: #FFC943;
}

/* Navigation Styles */
.nav-container {
    background: #000;
    padding: var(--spacing);
    display: flex;
    align-items: center;
    gap: var(--spacing);
    width: 100%;
}

.search-container {
    position: relative;
    flex-grow: 1;
}

.search-input {
    width: 100%;
    height: min(12vw, 44px);
    border: none;
    border-radius: var(--border-radius);
    padding: 0 calc(var(--spacing) * 2) 0 calc(var(--spacing) * 6);
    font-size: min(4vw, 16px);
    font-family: 'Nunito', sans-serif;
    background: #fff;
    outline: none;
}

.search-icon {
    position: absolute;
    left: calc(var(--spacing) / 2);
    top: 50%;
    transform: translateY(-50%);
    width: min(4vw, 16px);
    height: min(4vw, 16px);
    border: 2px solid #000;
    border-radius: 50%;
}

.search-icon::after {
    content: '';
    position: absolute;
    top: calc(min(4vw, 16px) * 0.75);
    left: calc(min(4vw, 16px) * 0.75);
    width: calc(min(4vw, 16px) * 0.375);
    height: 2px;
    background: #000;
    border-radius: 1px;
    transform: rotate(45deg);
}

.nav-button {
    background: none;
    border: none;
    color: #fff;
    font-size: min(4vw, 16px);
    font-weight: 500;
    font-family: 'Nunito', sans-serif;
    padding: calc(var(--spacing) / 3) calc(var(--spacing) / 2);
    cursor: pointer;
    border-radius: var(--border-radius);
    transition: background-color .2s;
    white-space: nowrap;
}

.nav-button:hover {
    background: rgba(255, 255, 255, .1);
}

.nav-button:active {
    background: rgba(255, 255, 255, .2);
}

/* Container Styles */
.container {
    padding: var(--spacing);
}

/* Form Styles */
.form-group {
    margin-bottom: calc(var(--spacing) * 3);
}

.form-label {
    display: block;
    font-size: min(3.5vw, 16px);
    font-weight: 600;
    margin-bottom: calc(var(--spacing) * 1.5);
    color: #fff;
}

.form-input {
    width: 100%;
    padding: calc(var(--spacing) * 2);
    border: 1px solid #333;
    border-radius: var(--border-radius);
    background: #222;
    color: #fff;
    font-size: min(3vw, 14px);
    font-family: 'Nunito', sans-serif;
    outline: none;
    transition: border-color .2s;
}

.form-input:focus {
    border-color: #FFC943;
}

.form-textarea {
    resize: vertical;
    min-height: calc(var(--spacing) * 15);
}

/* Button Styles */
.back-button {
    background: none;
    border: 1px solid #fff;
    color: #fff;
    font-size: min(3vw, 14px);
    font-family: 'Nunito', sans-serif;
    padding: calc(var(--spacing) * 2) calc(var(--spacing) * 3);
    cursor: pointer;
    border-radius: var(--border-radius);
    margin-bottom: calc(var(--spacing) * 3);
    transition: background-color .2s;
}

.back-button:hover {
    background: rgba(255, 255, 255, .1);
}

.submit-button {
    width: 100%;
    padding: calc(var(--spacing) * 3);
    background: #FFC943;
    color: #000;
    border: none;
    border-radius: var(--border-radius);
    font-size: min(4vw, 18px);
    font-weight: 600;
    font-family: 'Nunito', sans-serif;
    cursor: pointer;
    transition: background-color .2s;
}

.submit-button:hover {
    background: #ffdb6b;
}

/* Tag Styles */
.tag {
    background: #e91e63;
    color: #fff;
    padding: calc(var(--spacing) * 0.5) calc(var(--spacing) * 1.5);
    border-radius: calc(var(--border-radius) * 2);
    font-size: min(2.5vw, 12px);
    font-weight: 500;
    border: none;
    flex-shrink: 0;
}

.tag:nth-child(2) { background: #9c27b0; }
.tag:nth-child(3) { background: #673ab7; }
.tag:nth-child(4) { background: #3f51b5; }
.tag:nth-child(5) { background: #2196f3; }

.tag-suggestions {
    margin-top: calc(var(--spacing) * 1.5);
}

.tag-grid {
    display: flex;
    gap: calc(var(--spacing) * 1);
    flex-wrap: wrap;
}

.tag-suggestion {
    background: #333;
    color: #fff;
    padding: calc(var(--spacing) * 1) calc(var(--spacing) * 2);
    border-radius: calc(var(--border-radius) * 2);
    font-size: min(2.5vw, 12px);
    cursor: pointer;
    border: none;
    transition: background-color .2s;
}

.tag-suggestion:hover,
.tag-suggestion.selected {
    background: #FFC943;
    color: #000;
}

/* Utility Classes */
.hidden-input {
    display: none;
}

/* Responsive Design */
@media (max-width: 480px) {
    :root {
        --spacing: 1.5vw;
    }
}

@media (min-width: 1200px) {
    :root {
        --spacing: 0.5rem;
    }
}