.md-pef__hero {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    margin-top: 0;
    margin-bottom: 24px;
    min-height: clamp(640px, 82vh, 860px);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    color: #fff;
}
.md-pef__hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url("../images/protoselida-hero.jpg");
    background-size: cover;
    background-position: center 38%;
    background-repeat: no-repeat;
    filter: saturate(1.02) contrast(1.04) brightness(.62);
    transform: scale(1.03);
}
.md-pef__hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.15) 28%, rgba(0,0,0,.20) 50%, rgba(0,0,0,.78) 100%),
        radial-gradient(ellipse at 12% 100%, rgba(213,19,23,.30) 0%, transparent 55%),
        radial-gradient(ellipse at 92% 10%, rgba(213,19,23,.18) 0%, transparent 45%);
    pointer-events: none;
}
.md-pef__hero-fade {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 70px;
    z-index: 3;
    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.95) 75%, #fff 100%);
    pointer-events: none;
}
.md-pef__hero-rule {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 70px;
    height: 3px;
    z-index: 4;
    background: linear-gradient(90deg, transparent 0%, #d51317 12%, #d51317 88%, transparent 100%);
    pointer-events: none;
}

.md-pef__hero-inner {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 1280px;
    padding: 0 28px 90px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 60px;
}
.md-pef__hero-left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
    max-width: 780px;
}
.md-pef__hero-accent {
    display: block;
    width: 64px;
    height: 4px;
    background: #d51317;
    box-shadow: 0 0 18px rgba(213,19,23,.7);
    margin-bottom: 2px;
}
.md-pef__hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: rgba(255,255,255,.92);
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .26em;
    text-transform: uppercase;
}
.md-pef__hero-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #d51317;
    box-shadow: 0 0 0 3px rgba(213,19,23,.28), 0 0 12px rgba(213,19,23,.9);
    animation: md-pef-pulse 2.4s ease-in-out infinite;
}
@keyframes md-pef-pulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(213,19,23,.25), 0 0 12px rgba(213,19,23,.9); }
    50%      { box-shadow: 0 0 0 6px rgba(213,19,23,.12), 0 0 20px rgba(213,19,23,.9); }
}
.md-pef__title {
    font-family: "CF Blast Gothic", var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif !important;
    font-size: clamp(48px, 7.4vw, 112px) !important;
    line-height: .88 !important;
    letter-spacing: -.022em;
    text-shadow: 0 8px 40px rgba(0,0,0,.55);
    margin: 0;
    font-weight: 900;
    text-transform: uppercase;
    color: #fff;
}
.md-pef__title em {
    font-style: italic;
    font-family: "Vollkorn", Georgia, serif;
    font-weight: 600;
    text-transform: none;
    letter-spacing: -.01em;
    color: #fff;
    background: linear-gradient(180deg, #fff 0%, rgba(255,255,255,.88) 100%);
    -webkit-background-clip: text;
    background-clip: text;
}
.md-pef__subtitle {
    color: rgba(255,255,255,.85);
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif;
    font-size: clamp(15px, 1.1vw, 19px);
    font-weight: 400;
    line-height: 1.5;
    margin: 8px 0 0;
    max-width: 620px;
    border-top: 1px solid rgba(255,255,255,.16);
    padding-top: 18px;
}

.md-pef__hero-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
    color: #fff;
    line-height: 1;
    padding-bottom: 4px;
}
.md-pef__hero-today {
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .35em;
    color: rgba(255,255,255,.6);
    margin-bottom: 8px;
}
.md-pef__hero-day {
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: .18em;
    color: #fff;
    margin-bottom: 6px;
}
.md-pef__hero-num {
    font-family: "Vollkorn", Georgia, serif;
    font-size: clamp(90px, 11vw, 180px);
    font-weight: 700;
    line-height: .82;
    color: #fff;
    letter-spacing: -.04em;
    text-shadow: 0 8px 40px rgba(0,0,0,.55);
    background: linear-gradient(180deg, #fff 0%, rgba(255,255,255,.78) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    margin: 6px 0 4px;
}
.md-pef__hero-mon {
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .14em;
    color: rgba(255,255,255,.85);
    text-transform: uppercase;
    margin-top: 2px;
}

.md-pef__hero-ticker {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    z-index: 4;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
    padding: 14px 24px;
    color: rgba(255,255,255,.85);
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: .3em;
    text-transform: uppercase;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,0) 100%);
}
.md-pef__hero-ticker span { color: rgba(255,255,255,.92); }
.md-pef__hero-ticker span:nth-child(even) { color: rgba(213,19,23,1); font-weight: 800; }

.md-pef__widget-wrap {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 16px 80px;
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, -apple-system, sans-serif;
    color: #15171c;
}
.md-pef__widget-wrap #protosel { width: 100%; }
.md-pef__widget-wrap .protosel_wrap {
    overflow: visible;
    padding: 0 !important;
    width: 100% !important;
    box-sizing: border-box;
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, -apple-system, sans-serif !important;
}
.md-pef__widget-wrap .protosel_wrap > h2 { display: none !important; }
.md-pef__widget-wrap .protosel_wrap .dateAndClip > span,
.md-pef__widget-wrap #topadvwrap,
.md-pef__widget-wrap #topadv {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}
.md-pef__widget-wrap .dateAndClip {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 4px 0 0;
    margin-bottom: 4px;
    min-height: auto !important;
    height: auto !important;
}

.md-pef__widget-wrap #protosel_content { padding: 0; }

.md-pef__widget-wrap #protosel_content h3 {
    background: none !important;
    border: 0 !important;
    border-bottom: 1px solid #e8e8eb !important;
    padding: 6px 0 14px !important;
    margin: 38px 0 22px !important;
    color: #15171c !important;
    font-family: "CF Blast Gothic", var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif !important;
    font-size: clamp(20px, 2vw, 28px) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    height: auto !important;
    letter-spacing: .01em !important;
    text-transform: uppercase !important;
    text-align: left !important;
    position: relative;
    cursor: default !important;
    display: flex;
    align-items: center;
    gap: 14px;
}
.md-pef__widget-wrap #protosel_content h3::before {
    content: "";
    display: inline-block;
    width: 36px;
    height: 4px;
    background: #d51317;
    flex: 0 0 36px;
}
.md-pef__widget-wrap #protosel_content h3:first-of-type { margin-top: 18px !important; }

.md-pef__widget-wrap .protosel_img_wrap {
    margin: 0 18px 22px 0 !important;
    padding: 0 !important;
    width: calc(25% - 14px) !important;
    max-height: none !important;
    text-align: center !important;
    vertical-align: top;
    display: inline-block;
    background: #fff;
    border: 1px solid #e6e6ea;
    border-radius: 4px;
    overflow: hidden !important;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    position: relative;
}
.md-pef__widget-wrap .protosel_img_wrap:nth-of-type(4n) {
    margin-right: 0 !important;
}
.md-pef__widget-wrap .protosel_img_wrap:hover {
    transform: translateY(-3px);
    border-color: #d51317;
    box-shadow: 0 14px 30px -12px rgba(0,0,0,.28), 0 4px 8px rgba(0,0,0,.05);
}

.md-pef__widget-wrap .protosel_ef {
    color: #15171c !important;
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif !important;
    font-size: 11.5px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    max-height: none !important;
    height: auto !important;
    border-top: 0 !important;
    border-bottom: 1px solid #f0f0f3 !important;
    padding: 13px 12px 11px !important;
    overflow: hidden !important;
    text-transform: uppercase !important;
    letter-spacing: .12em !important;
    text-align: center;
    background: #fff;
}
.md-pef__widget-wrap .protosel_ef ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    font-family: inherit !important;
    font-size: inherit !important;
}
.md-pef__widget-wrap .protosel_ef li,
.md-pef__widget-wrap .protosel_ef li a {
    color: #15171c !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
    text-decoration: none !important;
}

.md-pef__widget-wrap .protosel_img {
    border: 0 !important;
    background: #f5f5f7 !important;
    padding: 14px !important;
    position: relative !important;
    overflow: hidden !important;
    aspect-ratio: 5 / 7;
    display: flex !important;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}
.md-pef__widget-wrap .protosel_img::before {
    content: "";
    position: absolute;
    inset: 14px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0) 75%, rgba(0,0,0,.04) 100%);
    pointer-events: none;
    z-index: 1;
}
.md-pef__widget-wrap .protosel_img::after {
    content: "";
    position: absolute;
    top: 14px;
    right: 14px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #d51317 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 18 15 12 9 6'/></svg>") center/14px no-repeat;
    box-shadow: 0 6px 18px rgba(213,19,23,.45);
    opacity: 0;
    transform: translateY(-6px) scale(.85);
    transition: opacity .2s ease, transform .2s ease;
    z-index: 2;
    pointer-events: none;
}
.md-pef__widget-wrap .protosel_img_wrap:hover .protosel_img::after {
    opacity: 1;
    transform: translateY(0) scale(1);
}
.md-pef__widget-wrap .protosel_img img {
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    cursor: pointer !important;
    display: block !important;
    object-fit: contain !important;
    box-shadow: 0 6px 18px rgba(0,0,0,.16), 0 2px 4px rgba(0,0,0,.06);
    transition: transform .25s ease;
    background: #fff;
}
.md-pef__widget-wrap .protosel_img_wrap:hover .protosel_img img {
    transform: scale(1.025);
}

.md-pef__widget-wrap #protosel_datepicker,
.md-pef__widget-wrap .protosel_wrap input[type="text"] {
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    padding: 9px 14px !important;
    border: 1px solid #d8d8dc !important;
    border-radius: 6px !important;
    margin: 0 !important;
    background: #fff;
    color: #15171c;
    cursor: pointer;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
    min-width: 200px;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.md-pef__widget-wrap #protosel_datepicker:hover,
.md-pef__widget-wrap #protosel_datepicker:focus {
    border-color: #d51317 !important;
    outline: 0;
    box-shadow: 0 0 0 3px rgba(213,19,23,.12);
}

.md-pef__widget-wrap .protosel_zoom {
    padding: 24px 0;
    text-align: center;
}
.md-pef__widget-wrap .protosel_zoom button {
    font-family: var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif !important;
    background: #15171c !important;
    color: #fff !important;
    border: 0 !important;
    border-radius: 999px !important;
    padding: 10px 22px !important;
    font-size: 12.5px !important;
    font-weight: 700 !important;
    letter-spacing: .12em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .2s ease;
}
.md-pef__widget-wrap .protosel_zoom button:hover { background: #d51317 !important; }
.md-pef__widget-wrap .protosel_zoom .h2title,
.md-pef__widget-wrap .protosel_zoom h2 {
    font-family: "CF Blast Gothic", var(--mde-sans, "CF Panoptik"), Tahoma, sans-serif !important;
    font-size: clamp(22px, 2.4vw, 32px) !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    border: 0 !important;
    margin: 24px 0 16px !important;
    color: #15171c !important;
    letter-spacing: -.01em;
}
.md-pef__widget-wrap .protosel_zoom #protoselido {
    width: 100% !important;
    max-width: 760px !important;
    height: auto !important;
    box-shadow: 0 24px 60px -20px rgba(0,0,0,.4), 0 8px 20px rgba(0,0,0,.12);
    border-radius: 6px;
    margin-top: 12px;
}

@media (max-width: 1200px) {
    .md-pef__widget-wrap .protosel_img_wrap { width: calc(25% - 14px) !important; margin-right: 18px !important; }
    .md-pef__widget-wrap .protosel_img_wrap:nth-of-type(4n) { margin-right: 0 !important; }
}
@media (max-width: 900px) {
    .md-pef__hero { min-height: clamp(540px, 70vh, 640px); margin-bottom: 18px; }
    .md-pef__hero-inner {
        grid-template-columns: 1fr;
        gap: 28px;
        padding: 0 22px 80px;
    }
    .md-pef__hero-right {
        flex-direction: row;
        align-items: baseline;
        align-self: start;
        gap: 14px;
        padding-bottom: 0;
        order: -1;
    }
    .md-pef__hero-today { margin-bottom: 0; font-size: 10px; letter-spacing: .3em; }
    .md-pef__hero-day { margin-bottom: 0; font-size: 12px; }
    .md-pef__hero-num { font-size: clamp(40px, 8vw, 64px); margin: 0; }
    .md-pef__hero-mon { margin-top: 0; font-size: 11px; }
    .md-pef__title { font-size: clamp(40px, 9vw, 72px) !important; }
    .md-pef__hero-ticker { gap: 10px; font-size: 9.5px; letter-spacing: .22em; padding: 10px 18px; }
    .md-pef__widget-wrap .protosel_img_wrap {
        width: calc(33.333% - 12px) !important;
        margin-right: 18px !important;
    }
    .md-pef__widget-wrap .protosel_img_wrap:nth-of-type(4n) { margin-right: 18px !important; }
    .md-pef__widget-wrap .protosel_img_wrap:nth-of-type(3n) { margin-right: 0 !important; }
    .md-pef__widget-wrap #protosel_content h3 { font-size: 20px !important; margin: 30px 0 16px !important; }
}
@media (max-width: 600px) {
    .md-pef__hero { min-height: 460px; }
    .md-pef__hero-inner { padding: 0 18px 70px; gap: 20px; }
    .md-pef__title { font-size: clamp(32px, 11vw, 52px) !important; }
    .md-pef__subtitle { font-size: 13px; padding-top: 14px; }
    .md-pef__hero-ticker { display: none; }
    .md-pef__hero-accent { width: 48px; height: 3px; }
    .md-pef__widget-wrap { padding: 0 14px 60px; }
    .md-pef__widget-wrap .protosel_img_wrap {
        width: calc(50% - 8px) !important;
        margin-right: 16px !important;
        margin-bottom: 16px !important;
    }
    .md-pef__widget-wrap .protosel_img_wrap:nth-of-type(3n) { margin-right: 16px !important; }
    .md-pef__widget-wrap .protosel_img_wrap:nth-of-type(2n) { margin-right: 0 !important; }
    .md-pef__widget-wrap .protosel_ef,
    .md-pef__widget-wrap .protosel_ef li,
    .md-pef__widget-wrap .protosel_ef li a { font-size: 10.5px !important; padding: 10px 8px 8px !important; letter-spacing: .08em !important; }
    .md-pef__widget-wrap .protosel_img { padding: 10px !important; }
    .md-pef__widget-wrap .protosel_img::after { width: 28px; height: 28px; background-size: 12px; top: 10px; right: 10px; }
}
@media (max-width: 380px) {
    .md-pef__widget-wrap .protosel_img_wrap { width: 100% !important; margin-right: 0 !important; }
}
