.dresscode {
    background-color: var(--color-bg-primary);
    padding: var(--space-3xl) 0;
}
.dresscode__container {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 var(--container-padding);
}
.dresscode__header {
    margin-bottom: var(--space-2xl);
    text-align: center;
}
.dresscode__label {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.7rem;
    font-weight: var(--font-weight-bold);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-text-heading);
    background-color: var(--color-primary);
    padding: var(--space-2xs) var(--space-sm);
    margin-bottom: var(--space-md);
}
.dresscode__title {
    font-family: var(--font-heading);
    font-size: clamp(2.5rem, 8vw, 4rem);
    font-weight: var(--font-weight-black);
    line-height: 0.9;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: var(--color-text-heading);
    margin: 0;
}
.dresscode__type {
    text-align: center;
    margin-bottom: var(--space-xl);
}
.dresscode__type-label {
    display: inline-block;
    padding: var(--space-sm) var(--space-xl);
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: var(--font-weight-black);
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: var(--color-bg-surface);
    background-color: var(--color-text-heading);
    border: 3px solid var(--color-text-heading);
}
.dresscode__description {
    text-align: center;
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-text-body);
    line-height: 1.7;
    max-width: 600px;
    margin: 0 auto var(--space-xl);
}
.dresscode__boards {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    max-width: 900px;
    margin: 0 auto var(--space-xl);
}
@media (min-width: 768px) {
    .dresscode__boards {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-2xl);
    }
}
.dresscode__board {
    background-color: var(--color-bg-surface);
    border: 3px solid var(--color-text-heading);
    padding: var(--space-lg);
}
.dresscode__board-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-sm);
    border-bottom: 3px solid var(--color-primary);
}
.dresscode__board-header .material-symbols-outlined {
    font-size: 1.75rem;
    color: var(--color-primary);
}
.dresscode__board-header h3 {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-text-heading);
    margin: 0;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.dresscode__mood {
    display: grid;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}
.dresscode__mood--1 {
    grid-template-columns: 1fr;
}
.dresscode__mood--2 {
    grid-template-columns: repeat(2, 1fr);
}
.dresscode__mood--3 {
    grid-template-columns: repeat(3, 1fr);
}
.dresscode__mood--4 {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
}
.dresscode__mood-img {
    aspect-ratio: 3/4;
    overflow: hidden;
    border: 2px solid var(--color-text-heading);
}
.dresscode__mood-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
    filter: contrast(110%) saturate(80%);
}
.dresscode__mood-img:hover img {
    transform: scale(1.05);
}
.dresscode__board-text {
    text-align: center;
    font-family: var(--font-body);
    font-size: 0.95rem;
    color: var(--color-text-body);
    line-height: 1.6;
    margin: 0;
}
.dresscode__board:not(:has(.dresscode__mood)) .dresscode__board-header {
    flex-direction: column;
    gap: var(--space-2xs);
}
.dresscode__board:not(:has(.dresscode__mood)) .dresscode__board-header .material-symbols-outlined {
    font-size: 2.5rem;
}
.dresscode__footer {
    max-width: 700px;
    margin: 0 auto;
    text-align: center;
}
.dresscode__avoid {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    background-color: var(--color-bg-surface);
    border: 3px solid var(--color-text-heading);
    margin-bottom: var(--space-md);
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: var(--color-text-body);
}
.dresscode__avoid .material-symbols-outlined {
    font-size: 1.25rem;
    color: var(--color-text-heading);
}
.dresscode__avoid strong {
    color: var(--color-text-heading);
    font-weight: var(--font-weight-bold);
}
.dresscode__note {
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0;
}
@media (max-width: 767px) {
    .dresscode__board {
        padding: var(--space-md);
    }
    .dresscode__mood--3 {
        grid-template-columns: repeat(2, 1fr);
    }
    .dresscode__mood--3 .dresscode__mood-img:last-child {
        grid-column: span 2;
    }
}
