.dresscode {
    background-color: transparent;
}

.dresscode .section__title {
    font-size: clamp(2.5rem, 5.8vw, 3.25rem);
    font-weight: var(--font-weight-regular);
}

.dresscode__type {
    text-align: center;
    margin-bottom: var(--space-lg);
}

.dresscode__type-label {
    display: inline-block;
    padding: var(--space-sm) var(--space-xl);
    font-family: var(--font-heading);
    font-size: 2rem;
    font-weight: var(--font-weight-regular);
    letter-spacing: 0.02em;
    text-transform: none;
    color: var(--color-text-heading);
    background: transparent;
    position: relative;
}

.dresscode__type-label::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 40' preserveAspectRatio='none'%3E%3Cpath d='M4,3 Q10,1 20,3 L50,2 Q80,4 100,2 L116,3 Q119,2 118,8 L119,18 Q117,22 119,32 L117,37 Q119,39 110,38 L70,39 Q50,36 30,39 L8,38 Q2,39 3,32 L2,22 Q4,18 2,8 L3,5 Q2,1 4,3 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 40' preserveAspectRatio='none'%3E%3Cpath d='M4,3 Q10,1 20,3 L50,2 Q80,4 100,2 L116,3 Q119,2 118,8 L119,18 Q117,22 119,32 L117,37 Q119,39 110,38 L70,39 Q50,36 30,39 L8,38 Q2,39 3,32 L2,22 Q4,18 2,8 L3,5 Q2,1 4,3 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

.dresscode__description {
    text-align: center;
    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: transparent;
    padding: var(--space-lg);
    position: relative;
}

.dresscode__board::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M3,2 Q8,1 15,3 L40,1 Q60,4 85,2 L97,3 Q99,2 98,8 L99,30 Q97,55 99,80 L98,97 Q99,99 92,98 L60,99 Q40,96 20,99 L5,98 Q1,99 2,92 L1,70 Q3,45 1,20 L2,5 Q1,1 3,2 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M3,2 Q8,1 15,3 L40,1 Q60,4 85,2 L97,3 Q99,2 98,8 L99,30 Q97,55 99,80 L98,97 Q99,99 92,98 L60,99 Q40,96 20,99 L5,98 Q1,99 2,92 L1,70 Q3,45 1,20 L2,5 Q1,1 3,2 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    pointer-events: none;
}

.dresscode__board:nth-child(2)::before {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M2,4 Q5,2 18,3 L45,2 Q65,5 88,3 L96,4 Q98,3 97,10 L98,35 Q96,60 98,85 L97,96 Q98,98 90,97 L55,98 Q35,95 15,98 L4,97 Q2,98 3,90 L2,65 Q4,40 2,15 L3,6 Q2,3 2,4 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M2,4 Q5,2 18,3 L45,2 Q65,5 88,3 L96,4 Q98,3 97,10 L98,35 Q96,60 98,85 L97,96 Q98,98 90,97 L55,98 Q35,95 15,98 L4,97 Q2,98 3,90 L2,65 Q4,40 2,15 L3,6 Q2,3 2,4 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
}

.dresscode__board-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    margin-bottom: var(--space-sm);
    position: relative;
    z-index: 1;
}

.dresscode__board-header .material-symbols-outlined {
    font-size: 1.75rem;
    color: var(--color-primary);
    opacity: 0.7;
}

.dresscode__board-header h3 {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: var(--font-weight-regular);
    color: var(--color-text-heading);
    margin: 0;
    letter-spacing: 0.02em;
    text-transform: none;
}

.dresscode__mood {
    display: grid;
    gap: var(--space-xs);
    margin-bottom: var(--space-sm);
    position: relative;
    z-index: 1;
}

.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;
    position: relative;
}

.dresscode__mood-img::after {
    content: '';
    position: absolute;
    inset: -2px;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M4,3 Q10,1 22,4 L50,2 Q72,5 90,3 L95,5 Q97,4 96,12 L97,40 Q95,65 97,88 L95,95 Q97,97 85,96 L50,97 Q30,94 12,97 L5,95 Q3,97 4,88 L3,60 Q5,35 3,12 L4,5 Q3,2 4,3 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M4,3 Q10,1 22,4 L50,2 Q72,5 90,3 L95,5 Q97,4 96,12 L97,40 Q95,65 97,88 L95,95 Q97,97 85,96 L50,97 Q30,94 12,97 L5,95 Q3,97 4,88 L3,60 Q5,35 3,12 L4,5 Q3,2 4,3 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    pointer-events: none;
    z-index: 2;
}

.dresscode__mood-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-normal);
    filter: sepia(8%) contrast(95%) brightness(102%);
}

.dresscode__mood-img:hover img {
    transform: scale(1.05);
}

.dresscode__board-text {
    text-align: center;
    font-size: 0.95rem;
    color: var(--color-text-body);
    line-height: 1.6;
    margin: 0;
    position: relative;
    z-index: 1;
}

.dresscode__board:not(:has(.dresscode__mood)) .dresscode__board-header {
    flex-direction: column;
    gap: var(--space-2xs);
    margin-bottom: var(--space-xs);
}

.dresscode__board:not(:has(.dresscode__mood)) .dresscode__board-header .material-symbols-outlined {
    font-size: 2rem;
    opacity: 0.5;
}

.dresscode__board:not(:has(.dresscode__mood)) .dresscode__board-text {
    margin-top: 0;
}

.dresscode__footer {
    max-width: 600px;
    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: transparent;
    margin-bottom: var(--space-md);
    font-size: 0.9rem;
    color: var(--color-text-body);
    position: relative;
}

.dresscode__avoid::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 40' preserveAspectRatio='none'%3E%3Cpath d='M4,3 Q10,1 20,3 L50,2 Q80,4 100,2 L116,3 Q119,2 118,8 L119,18 Q117,22 119,32 L117,37 Q119,39 110,38 L70,39 Q50,36 30,39 L8,38 Q2,39 3,32 L2,22 Q4,18 2,8 L3,5 Q2,1 4,3 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 40' preserveAspectRatio='none'%3E%3Cpath d='M4,3 Q10,1 20,3 L50,2 Q80,4 100,2 L116,3 Q119,2 118,8 L119,18 Q117,22 119,32 L117,37 Q119,39 110,38 L70,39 Q50,36 30,39 L8,38 Q2,39 3,32 L2,22 Q4,18 2,8 L3,5 Q2,1 4,3 Z' fill='none' stroke='white' stroke-width='1' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

.dresscode__avoid .material-symbols-outlined {
    font-size: 1.25rem;
    color: var(--color-text-muted);
    position: relative;
    z-index: 1;
}

.dresscode__avoid span {
    position: relative;
    z-index: 1;
}

.dresscode__avoid strong {
    color: var(--color-text-heading);
}

.dresscode__note {
    font-size: 0.9rem;
    font-style: italic;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0;
}