/* ================= BASIC RESET ================= */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html { scroll-behavior: smooth; }

body.siteRoot {
    background-color: #050607;
    color: #ffffff;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
    overflow-x: hidden;
}

/* ================= HEADER (scoped) ================= */
header.MnOpQrStUvWx {
    background: rgba(5, 6, 7, 0.92);
    border-bottom: 2px solid #5AF3FF;
    position: sticky;
    top: 0;
    z-index: 1000;
    padding: 15px 0;
}

header.MnOpQrStUvWx > .YzAbCdEfGhIj {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
}

/* logo only in header */
header.MnOpQrStUvWx .KlMnOpQrStUv {
    font-size: 28px;
    font-weight: 800;
    color: #5AF3FF;
    text-transform: uppercase;
    letter-spacing: 2px;
    text-shadow: 0 0 10px rgba(90, 243, 255, 0.5);
    flex: 0 0 auto; /* prevent accidental flex:1 overrides */
}

/* header nav only */
header.MnOpQrStUvWx nav.UvWxYzAbCdEf {
    display: flex;
    align-items: center;
}

header.MnOpQrStUvWx nav.UvWxYzAbCdEf > ul.GhIjKlMnOpQr {
    list-style: none;
    display: flex;
    gap: 20px;
    align-items: center;
    margin: 0;
    padding: 0;
}

header.MnOpQrStUvWx nav.UvWxYzAbCdEf > ul.GhIjKlMnOpQr li a {
    text-decoration: none;
    color: #ffffff;
    font-weight: 500;
    transition: 0.3s;
    font-size: 14px;
    text-transform: uppercase;
}

header.MnOpQrStUvWx nav.UvWxYzAbCdEf > ul.GhIjKlMnOpQr li a:hover {
    color: #5AF3FF;
    text-shadow: 0 0 8px #5AF3FF;
}

/* ================= BURGER (scoped) ================= */
input.WxYzAbCdEfGh { display: none; }

label.IjKlMnOpQrSt {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
}

label.IjKlMnOpQrSt span {
    width: 30px;
    height: 3px;
    background-color: #5AF3FF;
    border-radius: 2px;
}

/* ================= HERO ================= */
section#HeroFlowSection {
    padding: 100px 20px;
    position: relative;
    overflow: hidden;
}

section#HeroFlowSection::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(90, 243, 255, 0.05) 1px, transparent 1px),
        linear-gradient(rgba(90, 243, 255, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    z-index: -1;
}

/* hero quick links (was conflicting with header nav) */
#HeroFlowSection .UvWxYzAbCdEf {
    display: flex;
    justify-content: center;
    gap: 15px;
    margin-bottom: 50px;
    flex-wrap: wrap;
}

#HeroFlowSection .UvWxYzAbCdEf a {
    padding: 10px 20px;
    border: 1px solid #5AF3FF;
    color: #5AF3FF;
    text-decoration: none;
    border-radius: 4px;
    font-size: 13px;
    transition: 0.3s;
}

#HeroFlowSection .UvWxYzAbCdEf a:hover {
    background: #5AF3FF;
    color: #050607;
    box-shadow: 0 0 15px #5AF3FF;
}

/* hero inner grid (kept same class but scoped) */
#HeroFlowSection .AbCdEfGhIjKl {
    display: flex;
    align-items: center;
    gap: 50px;
    max-width: 1200px;
    margin: 0 auto;
}

#HeroFlowSection .MnOpQrStUvWx { flex: 1; }

#HeroFlowSection .MnOpQrStUvWx img {
    width: 100%;
    border-radius: 10px;
    box-shadow: 0 0 30px rgba(90, 243, 255, 0.2);
    border: 1px solid rgba(90, 243, 255, 0.3);
}

#HeroFlowSection .KlMnOpQrStUv { flex: 1; } /* text column only in hero */

#HeroFlowSection h1.WxYzAbCdEfGh {
    font-size: 48px;
    margin-bottom: 25px;
    line-height: 1.1;
    color: #5AF3FF;
}

#HeroFlowSection p.IjKlMnOpQrSt {
    font-size: 18px;
    margin-bottom: 20px;
    color: #e0e0e0;
}

/* hero CTA button */
#HeroFlowSection a.StUvWxYzAbCd {
    display: inline-block;
    padding: 15px 40px;
    background-color: #5AF3FF;
    color: #050607;
    text-decoration: none;
    font-weight: bold;
    border-radius: 5px;
    text-transform: uppercase;
    transition: 0.4s;
    margin-top: 20px;
}

#HeroFlowSection a.StUvWxYzAbCd:hover {
    box-shadow: 0 0 25px #5AF3FF;
    filter: brightness(1.1);
}

/* ================= REVIEWS (CSS slider) ================= */
section#ReviewFlowSection {
    background: #0a0c0e;
    padding: 80px 20px;
}

#ReviewFlowSection .QrStUvWxYzAb {
    max-width: 1000px;
    margin: 0 auto;
    text-align: center;
}

#ReviewFlowSection h2.CdEfGhIjKlMn {
    font-size: 36px;
    margin-bottom: 40px;
    color: #5AF3FF;
    position: relative;
    display: inline-block;
}

#ReviewFlowSection h2.CdEfGhIjKlMn::before {
    content: '>> ';
    color: #5AF3FF;
}

/* wrapper for radio+slides */
#ReviewFlowSection .OpQrStUvWxYz { position: relative; }

#ReviewFlowSection .OpQrStUvWxYz input { display: none; }

/* IMPORTANT: slider container scoped (was conflicting with many .KlMnOpQrStUv uses) */
#ReviewFlowSection .KlMnOpQrStUv {
    min-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#ReviewFlowSection .WxYzAbCdEfGh {
    display: none;
    animation: fadeIn 0.5s ease-in-out;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

#rev1:checked ~ .KlMnOpQrStUv .slide-1,
#rev2:checked ~ .KlMnOpQrStUv .slide-2,
#rev3:checked ~ .KlMnOpQrStUv .slide-3 {
    display: block;
}

/* dots controls scoped (avoid overriding header menu list) */
#ReviewFlowSection .GhIjKlMnOpQr {
    margin-top: 30px;
    display: flex;
    justify-content: center;
    gap: 15px;
    list-style: none;
    padding: 0;
}

#ReviewFlowSection .GhIjKlMnOpQr label {
    width: 12px;
    height: 12px;
    border: 2px solid #5AF3FF;
    border-radius: 50%;
    cursor: pointer;
    display: inline-block;
}

#rev1:checked ~ .GhIjKlMnOpQr label[for="rev1"],
#rev2:checked ~ .GhIjKlMnOpQr label[for="rev2"],
#rev3:checked ~ .GhIjKlMnOpQr label[for="rev3"] {
    background: #5AF3FF;
    box-shadow: 0 0 10px #5AF3FF;
}

/* ================= PRICES ================= */
section#PriceFlowSection { padding: 100px 20px; }

/* container for prices section (scoped) */
#PriceFlowSection .OpQrStUvWxYz {
    max-width: 1200px;
    margin: 0 auto;
}

/* cards row wrapper: SAME class as header, so scope it */
#PriceFlowSection .MnOpQrStUvWx {
    display: flex;
    gap: 30px;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 50px;
}

/* card: SAME class as header wrapper, so scope it */
#PriceFlowSection .YzAbCdEfGhIj {
    flex: 1;
    min-width: 250px;
    background: #0d0f11;
    padding: 40px 30px;
    border: 1px solid rgba(90, 243, 255, 0.1);
    border-radius: 15px;
    text-align: center;
    transition: 0.4s;
    display: block;          /* cancel header flex wrapper effect */
    justify-content: initial;
    align-items: initial;
}

#PriceFlowSection .YzAbCdEfGhIj:hover {
    border-color: #5AF3FF;
    transform: translateY(-10px);
}

#PriceFlowSection .featured-card {
    border: 1px solid #5AF3FF;
    box-shadow: 0 0 20px rgba(90, 243, 255, 0.1);
}

#PriceFlowSection .price-tag {
    font-size: 32px;
    font-weight: 800;
    color: #5AF3FF;
    margin: 20px 0;
}

/* list inside price card uses same class as label, so scope it */
#PriceFlowSection .IjKlMnOpQrSt {
    list-style: none;
    margin-bottom: 30px;
    text-align: left;
    padding: 0;
}

#PriceFlowSection .IjKlMnOpQrSt li {
    margin-bottom: 10px;
    font-size: 15px;
    color: #ccc;
}

#PriceFlowSection .IjKlMnOpQrSt li::before {
    content: '— ';
    color: #5AF3FF;
}

/* button in price card uses same class as hero CTA, so scope it */
#PriceFlowSection a.UvWxYzAbCdEf {
    display: inline-block;
    padding: 12px 26px;
    border: 1px solid #5AF3FF;
    border-radius: 6px;
    color: #5AF3FF;
    text-decoration: none;
    font-weight: 700;
    text-transform: uppercase;
    transition: .3s;
}

#PriceFlowSection a.UvWxYzAbCdEf:hover {
    background: #5AF3FF;
    color: #050607;
    box-shadow: 0 0 15px #5AF3FF;
}

/* ================= BENEFITS ================= */
section#BenefitsFlowSection {
    padding: 100px 20px;
    background: #0a0c0e;
}

#BenefitsFlowSection .StUvWxYzAbCd {
    display: flex;
    gap: 60px;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}

/* benefit text column */
#BenefitsFlowSection .EfGhIjKlMnOp { flex: 1; }

/* list class is reused elsewhere -> scope */
#BenefitsFlowSection .OpQrStUvWxYz {
    list-style: none;
    margin-top: 30px;
    padding: 0;
    position: static; /* cancel review positioning */
    font-size: inherit; /* cancel expert quote styling */
    font-style: normal;
    color: inherit;
}

#BenefitsFlowSection .OpQrStUvWxYz li {
    margin-bottom: 15px;
    font-size: 18px;
}

#BenefitsFlowSection .OpQrStUvWxYz li span {
    color: #5AF3FF;
    margin-right: 10px;
    text-shadow: 0 0 5px #5AF3FF;
}

/* image column in benefits uses AbCd... so scope it */
#BenefitsFlowSection .AbCdEfGhIjKl img.MnOpQrStUvWx {
    width: 100%;
    border-radius: 10px;
    border: 1px solid rgba(90, 243, 255, 0.2);
}

/* ================= AUDIENCE ================= */
section#AudienceFlowSection { padding: 100px 20px; }

/* container class reused -> scope */
#AudienceFlowSection .KlMnOpQrStUv {
    max-width: 1200px;
    margin: 0 auto;
    min-height: auto;   /* cancel review slider */
    display: block;     /* cancel review slider */
    align-items: initial;
    justify-content: initial;
}

/* list-grid is unique; keep as-is */
.list-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
    margin-top: 40px;
    list-style: none;
    padding: 0;
}

.list-grid li {
    background: #0d1013;
    padding: 20px;
    border-left: 4px solid #5AF3FF;
}

/* ================= EXPERT ================= */
section#ExpertFlowSection {
    padding: 120px 20px;
    background: linear-gradient(to right, #050607, #0a0c0e);
}

#ExpertFlowSection blockquote.CdEfGhIjKlMn {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

/* quote text class reused elsewhere -> scope */
#ExpertFlowSection .OpQrStUvWxYz {
    font-size: 24px;
    font-style: italic;
    color: #e0e0e0;
    line-height: 1.5;
    list-style: none;   /* neutralize if applied to list */
    margin: 0;
}

/* cite has class used elsewhere -> keep scoped */
#ExpertFlowSection cite.MnOpQrStUvWx {
    display: block;
    margin-top: 25px;
    color: #5AF3FF;
    font-style: normal;
    font-weight: bold;
    text-transform: uppercase;
}

/* ================= FAQ ================= */
section#FaqFlowSection { padding: 100px 20px; }

#FaqFlowSection .faq-container {
    max-width: 800px;
    margin: 50px auto 0;
}

#FaqFlowSection details.GhIjKlMnOpQr {
    background: #0d1013;
    margin-bottom: 15px;
    border-radius: 8px;
    border: 1px solid rgba(90, 243, 255, 0.1);
    list-style: none;
}

#FaqFlowSection summary.StUvWxYzAbCd {
    padding: 20px;
    cursor: pointer;
    font-weight: bold;
    color: #5AF3FF;
    outline: none;
}

/* FAQ answer block class reused -> scope and neutralize flex */
#FaqFlowSection .EfGhIjKlMnOp {
    padding: 0 20px 20px;
    color: #ccc;
    flex: initial;
}

/* ================= LONG TEXT BLOCKS ================= */
.text-block-long {
    padding: 80px 20px;
    border-top: 1px solid rgba(90, 243, 255, 0.05);
}

.text-block-long .KlMnOpQrStUv {
    max-width: 900px;
    margin: 0 auto;
    display: block;   /* cancel review slider */
    min-height: auto;
}

.text-block-long h2 {
    margin-bottom: 30px;
    color: #5AF3FF;
}

.text-block-long p {
    margin-bottom: 25px;
    font-size: 17px;
    color: #d1d1d1;
}

/* ================= CONTACT FORM ================= */
section#ContactFlowSection {
    padding: 100px 20px;
    background: #0d1013;
}

/* form wrapper class reused in header menu -> scope */
#ContactFlowSection form.GhIjKlMnOpQr {
    max-width: 600px;
    margin: 40px auto 0;
    display: flex;
    flex-direction: column;
    gap: 20px;
    list-style: none;
}

/* field wrapper class reused in benefits/faq -> scope */
#ContactFlowSection .StUvWxYzAbCd {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: none;
    margin: 0;
}

#ContactFlowSection .StUvWxYzAbCd label {
    margin-bottom: 8px;
    color: #5AF3FF;
}

#ContactFlowSection .StUvWxYzAbCd input,
#ContactFlowSection .StUvWxYzAbCd textarea {
    padding: 12px;
    background: #050607;
    border: 1px solid rgba(90, 243, 255, 0.3);
    color: #fff;
    border-radius: 4px;
    font-family: inherit;
}

#ContactFlowSection .StUvWxYzAbCd input:focus,
#ContactFlowSection .StUvWxYzAbCd textarea:focus {
    outline: none;
    border-color: #5AF3FF;
    box-shadow: 0 0 10px rgba(90, 243, 255, 0.3);
}

/* submit button class reused in other sections -> keep global for button only */
button.OpQrStUvWxYz {
    padding: 15px;
    background: #5AF3FF;
    color: #050607;
    border: none;
    font-weight: bold;
    text-transform: uppercase;
    cursor: pointer;
    border-radius: 4px;
    transition: 0.3s;
}

button.OpQrStUvWxYz:hover {
    box-shadow: 0 0 20px #5AF3FF;
}

/* ================= FOOTER ================= */
footer.AbCdEfGhIjKl {
    padding: 60px 20px;
    border-top: 2px solid #5AF3FF;
    background: #050607;
    text-align: center;
    display: block;          /* cancel hero flex */
    align-items: initial;
    gap: 0;
    max-width: none;
    margin: 0;
}

footer.AbCdEfGhIjKl .MnOpQrStUvWx {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: block;          /* cancel price wrapper flex */
}

.footer-links {
    margin-top: 30px;
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.footer-links a {
    color: #888;
    text-decoration: none;
    font-size: 13px;
    transition: 0.3s;
}

.footer-links a:hover { color: #5AF3FF; }

/* ================= RESPONSIVE ================= */
@media (max-width: 992px) {
    #HeroFlowSection .AbCdEfGhIjKl { flex-direction: column; }
    #BenefitsFlowSection .StUvWxYzAbCd { flex-direction: column; }
    #HeroFlowSection h1.WxYzAbCdEfGh { font-size: 36px; }
}

@media (max-width: 768px) {
    label.IjKlMnOpQrSt { display: flex; }

    header.MnOpQrStUvWx nav.UvWxYzAbCdEf {
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background: #050607;
        height: 0;
        overflow: hidden;
        transition: 0.4s;
        display: block;
    }

    header.MnOpQrStUvWx nav.UvWxYzAbCdEf > ul.GhIjKlMnOpQr {
        flex-direction: column;
        padding: 40px;
        align-items: center;
        gap: 18px;
    }

    input#burger-toggle:checked ~ nav.UvWxYzAbCdEf {
        height: auto;
        padding-bottom: 40px;
    }
}