.elsm-fullscreen {
    margin: 0;
    background: #070713;
    color: #f7f4ff;
}
.elsm-marketplace {
    min-height: 100vh;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: #070713;
    color: #f7f4ff;
}
.elsm-nav {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    justify-content: space-between;
    align-items: center;
    min-height: 64px;
    padding: 0 6vw;
    background: rgba(7, 7, 19, .88);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.elsm-nav a,
.elsm-link-button {
    color: #f7f4ff;
    text-decoration: none;
    font-weight: 800;
    margin-left: 18px;
}
.elsm-brand {
    margin-left: 0 !important;
    color: #79f2c0 !important;
    font-size: 18px;
}
.elsm-link-button {
    border: 0;
    background: transparent;
    cursor: pointer;
    font: inherit;
    padding: 0;
}
.elsm-user-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(121,242,192,.14);
    color: #79f2c0;
    font-weight: 800;
    margin-left: 18px;
}
.elsm-hero {
    min-height: 78vh;
    display: grid;
    align-items: center;
    padding: 64px 6vw;
    background:
        linear-gradient(120deg, rgba(7,7,19,.94), rgba(19,11,38,.82)),
        url("https://images.unsplash.com/photo-1558494949-ef010cbdcc31?auto=format&fit=crop&w=1800&q=80") center/cover;
}
.elsm-hero > div {
    max-width: 860px;
}
.elsm-kicker {
    color: #79f2c0;
    font-weight: 800;
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 0;
}
.elsm-hero h1 {
    font-size: clamp(40px, 7vw, 82px);
    line-height: .96;
    margin: 12px 0 22px;
    letter-spacing: 0;
}
.elsm-hero p {
    max-width: 680px;
    color: #d8d0ec;
    font-size: 20px;
    line-height: 1.55;
}
.elsm-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 28px;
}
.elsm-button,
.elsm-card a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 8px;
    background: #79f2c0;
    color: #07110d;
    font-weight: 800;
    text-decoration: none;
}
.elsm-button.secondary {
    background: rgba(255,255,255,.1);
    color: #fff;
    border: 1px solid rgba(255,255,255,.18);
}
.elsm-how {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: rgba(255,255,255,.08);
}
.elsm-proof {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: rgba(255,255,255,.08);
}
.elsm-proof div {
    background: #0d0d1c;
    padding: 24px 6vw;
}
.elsm-proof strong {
    display: block;
    font-size: 28px;
    color: #79f2c0;
}
.elsm-proof span {
    color: #d8d0ec;
}
.elsm-how article {
    background: #111124;
    padding: 34px 6vw;
}
.elsm-how strong {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: #79f2c0;
    color: #07110d;
}
.elsm-catalog {
    padding: 54px 6vw 80px;
}
.elsm-pricing,
.elsm-docs {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, .7fr);
    gap: 42px;
    padding: 68px 6vw;
    align-items: center;
    border-top: 1px solid rgba(255,255,255,.08);
}
.elsm-spotlight {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, .8fr);
    gap: 38px;
    padding: 68px 6vw;
    border-top: 1px solid rgba(255,255,255,.08);
}
.elsm-spotlight h2 {
    font-size: 42px;
    line-height: 1.05;
    margin: 0 0 18px;
}
.elsm-spotlight p {
    color: #d8d0ec;
    font-size: 18px;
    line-height: 1.6;
}
.elsm-terminal {
    background: #05050d;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    padding: 22px;
    box-shadow: 0 18px 50px rgba(0,0,0,.28);
}
.elsm-terminal span {
    display: block;
    color: #79f2c0;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    margin-top: 10px;
}
.elsm-terminal p {
    margin: 8px 0 18px;
    color: #f7f4ff;
    font-size: 16px;
}
.elsm-pricing h2,
.elsm-docs h2,
.elsm-faq h2 {
    font-size: 42px;
    line-height: 1.05;
    margin: 0 0 18px;
}
.elsm-pricing p,
.elsm-docs p {
    color: #d8d0ec;
    font-size: 18px;
    line-height: 1.6;
}
.elsm-price-box {
    background: #111124;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    padding: 26px;
}
.elsm-price-box span {
    color: #79f2c0;
    font-weight: 800;
}
.elsm-price-box strong {
    display: block;
    font-size: 34px;
    margin: 6px 0 16px;
}
.elsm-price-box li {
    margin: 10px 0;
    color: #d8d0ec;
}
.elsm-price-box small,
.elsm-download-box small {
    display: block;
    margin-top: 14px;
    color: #a9a0c6;
    line-height: 1.5;
}
.elsm-code {
    display: grid;
    gap: 10px;
}
.elsm-steps {
    display: grid;
    gap: 12px;
}
.elsm-steps div {
    display: flex;
    gap: 14px;
    align-items: center;
    background: #111124;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    padding: 18px;
}
.elsm-steps strong {
    color: #79f2c0;
}
.elsm-code code {
    display: block;
    white-space: normal;
    word-break: break-word;
    background: #111124;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    padding: 16px;
    color: #79f2c0;
}
.elsm-section-head {
    display: flex;
    gap: 20px;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 22px;
}
.elsm-section-head h2 {
    font-size: 34px;
    margin: 0;
}
#elsm-search {
    min-height: 44px;
    width: min(360px, 100%);
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.08);
    color: #fff;
    padding: 0 14px;
}
.elsm-category-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 24px;
}
.elsm-category-bar button {
    min-height: 36px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    background: rgba(255,255,255,.06);
    color: #d8d0ec;
    padding: 0 14px;
    cursor: pointer;
    font-weight: 800;
}
.elsm-category-bar button.active {
    background: #79f2c0;
    color: #07110d;
    border-color: #79f2c0;
}
.elsm-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
}
.elsm-card {
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    background: #111124;
    padding: 20px;
    min-height: 230px;
    display: flex;
    flex-direction: column;
}
.elsm-card-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}
.elsm-card span {
    color: #79f2c0;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}
.elsm-card b {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 9px;
    border-radius: 999px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0;
}
.elsm-card b.free {
    background: rgba(121,242,192,.14);
    color: #79f2c0;
    border: 1px solid rgba(121,242,192,.28);
}
.elsm-card b.premium {
    background: rgba(255,255,255,.12);
    color: #f7f4ff;
    border: 1px solid rgba(255,255,255,.18);
}
.elsm-card h3 {
    margin: 12px 0 8px;
    font-size: 20px;
}
.elsm-card p {
    color: #cfc7e7;
    line-height: 1.5;
    flex: 1;
}
.elsm-faq {
    padding: 20px 6vw 80px;
}
.elsm-faq details {
    border-top: 1px solid rgba(255,255,255,.12);
    padding: 18px 0;
}
.elsm-faq summary {
    cursor: pointer;
    font-size: 18px;
    font-weight: 800;
}
.elsm-faq p {
    color: #d8d0ec;
    max-width: 820px;
}
.elsm-skill-detail {
    padding: 54px 6vw 90px;
}
.elsm-back {
    color: #79f2c0;
    text-decoration: none;
    font-weight: 800;
}
.elsm-skill-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 32px;
    margin-top: 28px;
}
.elsm-skill-detail h1 {
    font-size: clamp(42px, 6vw, 76px);
    line-height: .98;
    margin: 10px 0 16px;
}
.elsm-lead {
    color: #d8d0ec;
    font-size: 21px;
    line-height: 1.55;
    max-width: 780px;
}
.elsm-skill-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin: 24px 0 36px;
}
.elsm-skill-meta span {
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    padding: 8px 12px;
    color: #d8d0ec;
}
.elsm-skill-detail h2 {
    margin-top: 30px;
}
.elsm-preview {
    white-space: pre-wrap;
    word-break: break-word;
    background: #111124;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    padding: 20px;
    color: #d8d0ec;
    line-height: 1.55;
}
.elsm-download-box {
    position: sticky;
    top: 84px;
    align-self: start;
    background: #111124;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    padding: 22px;
}
.elsm-download-box .elsm-button {
    width: 100%;
    margin-top: 10px;
}
.elsm-login-modal {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: grid;
    place-items: center;
    background: rgba(0,0,0,.72);
    padding: 20px;
}
.elsm-login-modal[hidden] {
    display: none;
}
.elsm-login-panel {
    position: relative;
    width: min(420px, 100%);
    background: #111124;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 8px;
    padding: 28px;
}
.elsm-login-close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.16);
    background: rgba(255,255,255,.08);
    color: #fff;
    cursor: pointer;
    font-size: 22px;
}
.elsm-login-panel label {
    display: grid;
    gap: 8px;
    margin: 14px 0;
    color: #d8d0ec;
}
.elsm-login-panel input {
    min-height: 44px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.08);
    color: #fff;
    padding: 0 12px;
}
.elsm-login-message {
    display: block;
    margin-top: 12px;
    color: #79f2c0;
}
.elsm-footer {
    display: flex;
    justify-content: space-between;
    gap: 28px;
    padding: 34px 6vw;
    border-top: 1px solid rgba(255,255,255,.1);
    background: #05050d;
}
.elsm-footer-brand {
    color: #79f2c0;
    font-weight: 900;
    text-decoration: none;
    font-size: 18px;
}
.elsm-footer p {
    color: #a9a0c6;
    max-width: 520px;
    margin: 8px 0 0;
}
.elsm-footer nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 14px;
}
.elsm-footer nav a {
    color: #d8d0ec;
    text-decoration: none;
    font-weight: 800;
}
@media (max-width: 760px) {
    .elsm-how,
    .elsm-proof,
    .elsm-section-head,
    .elsm-pricing,
    .elsm-docs,
    .elsm-spotlight,
    .elsm-skill-layout {
        grid-template-columns: 1fr;
        display: grid;
    }
    .elsm-nav {
        align-items: flex-start;
        gap: 8px;
        flex-direction: column;
        padding: 14px 6vw;
    }
    .elsm-nav a,
    .elsm-link-button,
    .elsm-user-pill {
        margin-left: 0;
        margin-right: 12px;
    }
    .elsm-hero {
        min-height: 72vh;
        padding-top: 40px;
    }
    .elsm-download-box {
        position: static;
    }
    .elsm-footer {
        display: grid;
    }
    .elsm-footer nav {
        justify-content: flex-start;
    }
}
