.ubw-shell,
.ubw-shell * { box-sizing: border-box; }
.ubw-shell {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at 50% 0%, rgba(0, 94, 255, .18), transparent 36%), #020513;
    padding: 22px 14px;
    font-family: Inter, Arial, Helvetica, sans-serif;
}
.ubw-panel {
    --ubw-accent: #039DFF;
    --ubw-blue: #006DFF;
    --ubw-card-bg: #061444;
    --ubw-scale: .78;
    position: relative;
    overflow: hidden;
    width: min(1450px, 100%);
    border: 2px solid rgba(0, 158, 255, .92);
    border-radius: 31px;
    background:
        linear-gradient(90deg, rgba(1, 8, 31, .94) 0%, rgba(0, 24, 99, .92) 48%, rgba(0, 35, 125, .9) 100%);
    box-shadow: 0 0 0 1px rgba(0, 95, 255, .18) inset, 0 0 38px rgba(0, 114, 255, .45), 0 24px 75px rgba(0, 0, 0, .65);
}
.ubw-panel:before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 8% 20%, rgba(0, 110, 255, .35), transparent 22%),
        radial-gradient(circle at 85% 36%, rgba(0, 149, 255, .25), transparent 22%),
        linear-gradient(180deg, rgba(255,255,255,.08), transparent 20%);
    pointer-events: none;
}
.ubw-glow {
    position: absolute;
    border-radius: 999px;
    filter: blur(14px);
    pointer-events: none;
}
.ubw-glow-1 {
    width: 320px; height: 320px;
    right: -80px; top: 55px;
    background: radial-gradient(circle, rgba(0, 216, 255, .35), transparent 58%);
}
.ubw-glow-2 {
    width: 290px; height: 190px;
    left: 70px; top: 22px;
    background: radial-gradient(circle, rgba(0, 82, 255, .36), transparent 66%);
}
.ubw-wave {
    position: absolute;
    right: 0;
    top: 102px;
    width: 455px;
    height: 220px;
    opacity: .48;
    background: repeating-radial-gradient(ellipse at right, rgba(0,184,255,.28) 0 1px, transparent 2px 10px);
    transform: rotate(-8deg);
    mask-image: linear-gradient(90deg, transparent, #000 22%, #000 82%, transparent);
    pointer-events: none;
}
.ubw-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.22fr .72fr .96fr;
    align-items: center;
    gap: 28px;
    zoom: var(--ubw-scale);
}
.ubw-courses {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 18px;
}
.ubw-course-card {
    position: relative;
    overflow: hidden;
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none !important;
    border: 1.5px solid rgba(0, 177, 255, .96);
    border-radius: 22px;
    background:
        radial-gradient(ellipse at top, rgba(0, 153, 255, .95) 0%, rgba(0, 97, 255, .82) 22%, rgba(5, 18, 70, .96) 62%),
        var(--ubw-card-bg);
    box-shadow: 0 0 22px rgba(0, 176, 255, .45), inset 0 0 30px rgba(0, 80, 255, .36);
    padding: 31px 13px 20px;
    transition: transform .35s ease, box-shadow .35s ease;
}
.ubw-course-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 0 34px rgba(0, 176, 255, .72), inset 0 0 34px rgba(0, 80, 255, .42);
}
.ubw-card-shine {
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.18) 14%, transparent 28%);
    transform: translateX(-120%);
    animation: ubwShine 4.8s ease-in-out infinite;
}
.ubw-card-logo { height: 70px; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.ubw-logo-img { max-width: 110px; max-height: 86px; object-fit: contain; }
.ubw-u-logo {
    position: relative;
    display: block;
    width: 88px;
    height: 76px;
    border-bottom-left-radius: 44px;
    border-bottom-right-radius: 44px;
    border-left: 22px solid #fff;
    border-right: 22px solid #fff;
    border-bottom: 22px solid #fff;
    filter: drop-shadow(0 8px 12px rgba(0,0,0,.28));
}
.ubw-u-logo:before,
.ubw-u-logo:after,
.ubw-u-logo span,
.ubw-u-logo i,
.ubw-u-logo b,
.ubw-u-logo em {
    content: "";
    position: absolute;
    display: block;
    background: #fff;
    border-radius: 1px;
}
.ubw-u-logo:before { right: -29px; top: -5px; width: 10px; height: 28px; }
.ubw-u-logo:after { right: -17px; top: -14px; width: 10px; height: 12px; }
.ubw-u-logo span { right: -17px; top: 7px; width: 10px; height: 14px; }
.ubw-u-logo i { right: -40px; top: -22px; width: 9px; height: 9px; }
.ubw-u-logo b { right: -40px; top: -4px; width: 9px; height: 18px; }
.ubw-u-logo em { right: -51px; top: -31px; width: 8px; height: 8px; }
.ubw-card-title {
    color: #fff;
    font-size: 23px;
    line-height: 1;
    font-weight: 900;
    margin: 0 0 13px;
    letter-spacing: -.02em;
    text-shadow: 0 2px 13px rgba(0,0,0,.45);
}
.ubw-card-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 55px;
    height: 26px;
    padding: 0 12px;
    margin-bottom: 18px;
    border-radius: 7px;
    color: #fff;
    font-size: 17px;
    font-weight: 900;
    line-height: 1;
    background: linear-gradient(180deg, #1a95ff, #005cff);
    box-shadow: 0 0 16px rgba(0, 140, 255, .6);
}
.ubw-card-desc {
    margin: auto 0 0;
    color: #fff;
    font-size: 13px;
    line-height: 1.16;
    font-weight: 600;
    text-align: center;
    text-shadow: 0 2px 8px rgba(0,0,0,.65);
}
.ubw-plus {
    position: relative;
    z-index: 2;
    flex: 0 0 48px;
    width: 48px;
    height: 48px;
    margin-left: -38px;
    margin-right: -38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1.5px solid rgba(0, 197, 255, .95);
    border-radius: 999px;
    background: radial-gradient(circle at 45% 30%, rgba(5, 64, 157, .95), rgba(0, 13, 55, .95));
    box-shadow: 0 0 20px rgba(0, 176, 255, .8), inset 0 0 18px rgba(0, 109, 255, .8);
    font-size: 34px;
    font-weight: 700;
    line-height: 1;
}
.ubw-copy {
    min-height: 335px;
    padding-left: 7px;
    padding-right: 26px;
    border-right: 1.5px solid rgba(0, 119, 255, .78);
}
.ubw-heading {
    margin: 0;
    text-transform: uppercase;
    font-size: clamp(34px, 3vw, 48px);
    line-height: 1.32;
    font-weight: 950;
    letter-spacing: -.035em;
}
.ubw-heading span {
    display: block;
    color: var(--ubw-accent);
    background: linear-gradient(180deg, #8fe2ff 0%, #108dff 55%, #0064ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 12px rgba(0, 121, 255, .6));
}
.ubw-heading .ubw-heading-white {
    color: #fff;
    background: linear-gradient(180deg, #fff 0%, #e8efff 54%, #c4d0ea 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 3px 3px rgba(0,0,0,.5));
}
.ubw-line {
    width: 220px;
    height: 2px;
    margin: 20px 0 24px;
    background: linear-gradient(90deg, var(--ubw-accent), rgba(255,255,255,.85), transparent);
    box-shadow: 0 0 13px rgba(0, 190, 255, .85);
}
.ubw-desc {
    color: rgba(255,255,255,.92);
    font-size: clamp(16px, 1.3vw, 21px);
    line-height: 1.36;
    font-weight: 400;
}
.ubw-desc strong { color: var(--ubw-accent); font-weight: 900; }
.ubw-price-area { text-align: center; padding-left: 8px; }
.ubw-ribbon {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 310px;
    height: 44px;
    padding: 0 30px;
    color: #fff;
    background: linear-gradient(180deg, #138dff, #0063f5);
    border-radius: 7px;
    font-size: 21px;
    line-height: 1;
    font-weight: 900;
    text-transform: uppercase;
    box-shadow: 0 0 22px rgba(0, 116, 255, .5);
}
.ubw-ribbon:before,
.ubw-ribbon:after {
    content: "";
    position: absolute;
    top: 0;
    border-top: 22px solid transparent;
    border-bottom: 22px solid transparent;
}
.ubw-ribbon:before { left: -18px; border-right: 18px solid #117ff9; }
.ubw-ribbon:after { right: -18px; border-left: 18px solid #005be4; }
.ubw-price {
    margin: 20px 0 28px;
    color: #fff;
    font-size: clamp(72px, 7.5vw, 118px);
    line-height: .92;
    font-weight: 950;
    letter-spacing: -.055em;
    background: linear-gradient(180deg, #fff 0%, #eff7ff 47%, #cbddf8 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 8px 17px rgba(0,0,0,.42));
}
.ubw-currency { font-size: .9em; margin-right: .02em; }
.ubw-benefits {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    max-width: 545px;
    margin: 0 auto;
}
.ubw-benefit {
    position: relative;
    padding: 0 17px;
    min-height: 128px;
    color: #fff;
}
.ubw-benefit:not(:last-child):after {
    content: "";
    position: absolute;
    right: 0;
    top: 10px;
    width: 1px;
    height: 112px;
    background: rgba(50, 155, 255, .68);
}
.ubw-benefit-icon {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
    border-radius: 999px;
    color: #fff;
    border: 1.2px solid rgba(255, 255, 255, .55);
    background: rgba(255,255,255,.06);
    box-shadow: 0 0 12px rgba(0, 108, 255, .35), inset 0 0 10px rgba(255,255,255,.08);
    font-size: 18px;
}
.ubw-benefit-icon svg,
.ubw-benefit-icon svg path {
    fill: currentColor;
}
.ubw-benefit h4 {
    margin: 0 0 8px;
    color: #fff;
    font-size: 14px;
    line-height: 1.12;
    font-weight: 900;
}
.ubw-benefit-text {
    color: rgba(255,255,255,.92);
    font-size: 15px;
    line-height: 1.18;
}
@keyframes ubwShine { 0%, 50% { transform: translateX(-125%); } 74%, 100% { transform: translateX(130%); } }

@media (max-width: 1440px) {
    .ubw-grid { grid-template-columns: 1.12fr .72fr .96fr; gap: 22px; }
    .ubw-course-card { width: 160px; min-height: 245px; }
    .ubw-card-title { font-size: 29px; }
    .ubw-plus { width: 54px; height: 54px; flex-basis: 54px; }
    .ubw-ribbon { min-width: 315px; font-size: 22px; }
    .ubw-benefit { padding: 0 15px; }
}
@media (max-width: 1024px) {
    .ubw-grid { grid-template-columns: 1fr; }
    .ubw-courses { justify-content: center; flex-wrap: wrap; }
    .ubw-copy { min-height: auto; border-right: 0; border-top: 1px solid rgba(0, 119, 255, .55); border-bottom: 1px solid rgba(0, 119, 255, .55); padding: 35px 0; text-align: center; }
    .ubw-line { margin-left: auto; margin-right: auto; }
}
@media (max-width: 767px) {
    .ubw-shell { padding: 22px 10px; }
    .ubw-panel { border-radius: 22px; padding: 30px 16px !important; --ubw-scale: 1; }
    .ubw-grid { gap: 28px; }
    .ubw-courses { flex-direction: column; gap: 16px; }
    .ubw-course-card { width: min(100%, 285px) !important; min-height: 235px !important; }
    .ubw-plus { margin: -5px 0; transform: rotate(90deg); }
    .ubw-heading { font-size: 40px; }
    .ubw-desc { font-size: 20px; }
    .ubw-ribbon { min-width: 0; width: calc(100% - 30px); font-size: 17px; height: 44px; padding: 0 12px; }
    .ubw-ribbon:before, .ubw-ribbon:after { border-top-width: 22px; border-bottom-width: 22px; }
    .ubw-price { font-size: 82px; margin: 22px 0 28px; }
    .ubw-benefits { grid-template-columns: 1fr; gap: 18px; }
    .ubw-benefit { min-height: auto; padding: 0 10px 18px; }
    .ubw-benefit:not(:last-child):after { right: 50%; top: auto; bottom: 0; width: 110px; height: 1px; transform: translateX(50%); }
}
