*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    background:#050816;
    color:white;
    font-family:'Poppins', sans-serif;
    overflow-x:hidden;
    padding:40px;
    position:relative;
}

.background-glow{
    position:fixed;
    width:700px;
    height:700px;
    background:#6f3cff;
    filter:blur(180px);
    opacity:0.15;
    top:-200px;
    left:-200px;
    z-index:-1;
}

.hero{
    margin-bottom:70px;
}
/* ========================= */
/* TOP RIGHT CONTACT */
/* ========================= */

.hero-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:30px;
}

.hero-contact{
    position:fixed;

    top:30px;
    right:40px;

    z-index:9999;

    display:flex;
    align-items:center;
    gap:18px;

    padding:14px 18px;

    border-radius:24px;

    backdrop-filter:blur(18px);

    background:
    linear-gradient(
        145deg,
        rgba(10,10,25,0.72),
        rgba(5,5,15,0.82)
    );

    border:1px solid rgba(139,92,255,0.18);

    box-shadow:
    0 0 30px rgba(0,0,0,0.35);

    transition:0.35s;
}

.hero-contact:hover{
    border-color:rgba(139,92,255,0.45);

    box-shadow:
    0 0 40px rgba(139,92,255,0.18);
}
.social-icon{
    width:64px;
    height:64px;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    border:1px solid rgba(139,92,255,0.45);

    color:#8b5cff;

    text-decoration:none;

    font-size:28px;

    background:
    linear-gradient(
        145deg,
        rgba(20,20,40,0.85),
        rgba(8,8,18,0.95)
    );

    transition:0.35s;
}

.social-icon:hover{
    transform:translateY(-5px);

    color:white;

    border-color:#8b5cff;

    box-shadow:
    0 0 25px rgba(139,92,255,0.45);
}

.top-divider{
    width:1px;
    height:55px;
    background:rgba(255,255,255,0.15);
}

.call-btn{
    height:64px;

    padding:0 34px;

    border-radius:20px;

    display:flex;
    align-items:center;
    gap:14px;

    text-decoration:none;

    color:white;

    font-size:22px;
    font-weight:700;

    border:1px solid rgba(139,92,255,0.5);

    background:
    linear-gradient(
        145deg,
        rgba(139,92,255,0.18),
        rgba(139,92,255,0.08)
    );

    transition:0.35s;
}

.call-btn i{
    color:#8b5cff;
    font-size:22px;
}

.call-btn:hover{
    transform:translateY(-5px);

    box-shadow:
    0 0 35px rgba(139,92,255,0.45);

    border-color:#8b5cff;
}


.logo{
    display:flex;
    align-items:center;
    gap:15px;
    color:#aaa;
    margin-bottom:30px;
    font-size:14px;
    letter-spacing:1px;
}

.logo i{
    color:#8b5cff;
    font-size:24px;
}

.hero h1{
    font-size:82px;
    line-height:0.95;
    font-weight:800;
    margin-bottom:25px;
}

.hero h1 span{
    color:#8b5cff;
}

.hero p{
    color:#b7b7b7;
    font-size:22px;
    max-width:650px;
    line-height:1.6;
}

.line{
    width:80px;
    height:4px;
    background:#8b5cff;
    margin-top:40px;
    border-radius:20px;
}

.pricing{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
    gap:30px;
    margin-bottom:60px;
}

.card{
    position:relative;

    background:
    linear-gradient(
        145deg,
        rgba(20,20,40,0.9),
        rgba(8,8,18,0.95)
    );

    border:1px solid rgba(139,92,255,0.25);

    border-radius:30px;

    padding:40px;

    backdrop-filter:blur(14px);

    transition:0.4s;

    overflow:hidden;
}

.card:hover{
    transform:translateY(-10px);

    box-shadow:
    0 0 50px rgba(139,92,255,0.25);
}

.popular{
    transform:scale(1.04);

    border:1px solid rgba(139,92,255,0.7);

    box-shadow:
    0 0 60px rgba(139,92,255,0.25);
}
.badge{
    position:absolute;
    top:48px;
    right:-60px;
    width:260px;
    background:#8b5cff;
    color:white;
    text-align:center;
    padding:14px;
    transform:rotate(45deg);
    font-size:14px;
    font-weight:700;
    letter-spacing:1px;
    box-shadow:
    0 0 20px rgba(139,92,255,0.45);
    z-index:10;
}

.icon{
    width:90px;
    height:90px;

    border-radius:50%;

    border:2px solid rgba(139,92,255,0.5);

    display:flex;
    align-items:center;
    justify-content:center;

    margin:0 auto 25px;

    font-size:34px;

    color:#8b5cff;
}

.card h2{
    text-align:center;
    font-size:42px;
    color:#8b5cff;
    margin-bottom:10px;
}

.small-desc{
    text-align:center;
    color:#aaa;
    margin-bottom:30px;
}

.price{
    text-align:center;
    font-size:72px;
    font-weight:800;
    margin-bottom:25px;
}

.price span{
    font-size:32px;
    color:#ddd;
}

.divider{
    width:100%;
    height:1px;
    background:rgba(255,255,255,0.08);
    margin:30px 0;
}

/* ========================= */
/* LISTY */
/* ========================= */

.section h3{
    color:#8b5cff;
    margin-bottom:20px;
    font-size:18px;
}

.section ul{
    list-style:none;
    padding:0;
    margin:0;
}

.section ul li{
    display:flex;
    align-items:flex-start;
    gap:12px;
    font-size: 17px;
    margin-bottom:16px;
    color:#ddd;
    line-height:1.6;
}

.section ul li i{
    color:#8b5cff;
    margin-top:4px;
    min-width:18px;
}

.negative li i{
    color:#868686 !important;
}

/* ========================= */
/* STANDARD 500zł/rok */
/* ========================= */

.extra-box{
    margin-top:30px;

    padding:30px;

    border-radius:25px;

    border:1px solid rgba(139,92,255,0.25);

    background:
    linear-gradient(
        145deg,
        rgba(15,15,30,0.95),
        rgba(5,5,15,0.98)
    );
}

.extra-price{
    text-align:center;

    color:#d7c2ff;

    font-weight:700;

    font-size:18px;
}

.extra-price strong{
    display:block;

    font-size:44px;

    color:white;

    margin-top:10px;
}

.extra-price strong span{
    font-size:28px;
}

/* NOWE PUNKTY */

.extra-box ul{
    list-style:none;

    padding:0;

    margin-top:15px;
}

.extra-box ul li{
    position:relative;

    padding-left:26px;

    margin-bottom:22px;

    color:#f1f1f1;

    font-size:18px;

    line-height:1.8;
}

.extra-box ul li::before{
    content:"•";

    position:absolute;

    left:0;
    top:-2px;

    color:#8b5cff;

    font-size:28px;

    line-height:1;
}

/* ========================= */
/* PREMIUM ABONAMENT */
/* ========================= */

.subscription-box{
    margin-top:30px;

    background:
    linear-gradient(
        145deg,
        rgba(139,92,255,0.25),
        rgba(139,92,255,0.1)
    );

    border-radius:25px;

    padding:35px;

    border:1px solid rgba(139,92,255,0.25);
}

.subscription-title{
    text-align:center;

    color:#d7c2ff;

    margin-bottom:20px;

    font-weight:700;

    font-size:20px;
}

.subscription-price{
    text-align:center;

    color:white;

    font-size:44px;

    font-weight:800;

    margin-bottom:10px;
}

.subscription-price span{
    font-size:28px;
    color:#ddd;
}

.subscription-content{
    margin-top:30px;
}

.subscription-content h4{
    color:#ffffff;

    font-size:22px;

    font-weight:700;

    margin-bottom:28px;
}

/* NOWY PREMIUM STYLE */

.subscription-content ul{
    list-style:none;

    padding:0;

    margin:0;
}

.subscription-content ul li{
    position:relative;

    padding-left:30px;

    margin-bottom:24px;

    color:#f5f5f5;

    font-size:16px;

    line-height:1.7;

    font-weight:500;
}

.subscription-content ul li::before{
    content:"";

    position:absolute;

    left:0;
    top:12px;

    width:10px;
    height:10px;

    border-radius:50%;

    background:#8b5cff;

    box-shadow:
    0 0 14px rgba(139,92,255,0.9);
}
/* ========================= */
/* DODATKOWE USŁUGI AI */
/* ========================= */

.addons-wrapper{
    background:rgba(15,15,30,0.9);

    border-radius:30px;

    padding:40px;

    border:1px solid rgba(139,92,255,0.15);

    margin-bottom:20px;
}

.addons{
    display:grid;

    grid-template-columns:repeat(5, 1fr);

    gap:24px;
}

.addon-card{
    background:
    linear-gradient(
        145deg,
        rgba(20,20,40,0.9),
        rgba(8,8,18,0.95)
    );

    border:1px solid rgba(139,92,255,0.2);

    border-radius:24px;

    padding:32px;

    text-align:center;

    transition:0.35s;

    backdrop-filter:blur(12px);
}

.addon-card:hover{
    transform:translateY(-8px);

    border-color:rgba(139,92,255,0.45);

    box-shadow:
    0 0 35px rgba(139,92,255,0.18);
}

.addon-icon{
    width:78px;
    height:78px;

    margin:0 auto 22px;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    background:rgba(139,92,255,0.1);

    border:1px solid rgba(139,92,255,0.25);

    color:#8b5cff;

    font-size:30px;
}

.addon-card h4{
    font-size:24px;

    font-weight:700;

    margin-bottom:14px;

    color:white;

    line-height:1.3;
}

.addon-card p{
    color:#aaa;

    font-size:15px;

    line-height:1.7;

    margin-bottom:24px;

    min-height:76px;
}

.addon-price{
    display:inline-block;

    padding:12px 22px;

    border-radius:14px;

    font-size:20px;

    font-weight:700;

    color:#ffffff;

    background:
    linear-gradient(
        145deg,
        rgba(139,92,255,0.22),
        rgba(139,92,255,0.08)
    );

    border:1px solid rgba(139,92,255,0.25);

    box-shadow:
    0 0 20px rgba(139,92,255,0.08);
}

/* ========================= */
/* PROCESS */
/* ========================= */

.process-wrapper{
    background:rgba(15,15,30,0.9);

    border-radius:30px;

    padding:40px;

    border:1px solid rgba(139,92,255,0.15);
}

.process-title{
    margin-bottom:40px;

    font-size:28px;

    font-weight:700;
}

.process{
    display:flex;

    align-items:center;

    justify-content:space-between;

    flex-wrap:wrap;

    gap:20px;
}

.step{
    flex:1;

    min-width:160px;

    text-align:center;
}

.step i{
    width:80px;
    height:80px;

    display:flex;
    align-items:center;
    justify-content:center;

    margin:0 auto 20px;

    border-radius:50%;

    background:rgba(139,92,255,0.1);

    border:1px solid rgba(139,92,255,0.2);

    color:#8b5cff;

    font-size:30px;
}

.step h4{
    margin-bottom:10px;
}

.step p{
    color:#aaa;
    line-height:1.6;
}

.arrow{
    font-size:36px;
    color:#8b5cff;
}
footer{
    background-color: rgba(15,15,30,0.9);
    border:1px solid rgba(139,92,255,0.15);
    border-radius: 30px;
    margin-top: 20px;
    padding: 40px;
    font-weight: 600;
    display: flex;
    justify-content: space-between; 
    align-items: flex-end;
}
footer a{
    color: #8b5cff;
}
.copyright {
  margin-left: auto;  
  text-align: right;
}
/* ===================================== */
/* MOBILE PREMIUM RESPONSIVE */
/* ===================================== */

@media (max-width: 768px) {

    /* GLOBAL */
    html,
    body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden;
    }

    body {
        padding: 18px;
        padding-bottom: 110px; /* miejsce na dolny panel kontaktowy */
    }

    * {
        max-width: 100%;
    }

    /* HERO */
    .hero {
        margin-bottom: 50px;
    }

    .hero-top {
        margin-bottom: 20px;
    }

    .logo {
        display: flex;
        align-items: flex-start;
        gap: 10px;
        font-size: 11px;
        line-height: 1.5;
        flex-wrap: nowrap;
    }

    .logo i {
        font-size: 18px;
        flex-shrink: 0;
        margin-top: 2px;
    }

    .logo span {
        flex: 1;
    }

    .hero h1 {
        font-size: 42px;
        line-height: 1.1;
        margin-bottom: 20px;
        letter-spacing: -0.02em;
        word-break: keep-all;
    }
    
    .hero p {
        font-size: 17px;
        line-height: 1.7;
    }

    .line {
        margin-top: 30px;
    }

    /* FLOAT CONTACT */
    .hero-contact {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: 12px;
        top: auto;
        z-index: 9999;

        display: flex;
        align-items: center;
        justify-content: center;
        gap: 12px;

        width: auto;
        max-width: calc(100% - 24px);
        box-sizing: border-box;

        padding: 12px;
        border-radius: 22px;
    }

    .social-icon {
        width: 52px;
        height: 52px;
        font-size: 22px;
        flex-shrink: 0;
    }

    .top-divider {
        display: none;
    }

    .call-btn {
        flex: 1;
        min-width: 0;
        height: 52px;

        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;

        padding: 0 16px;
        border-radius: 16px;

        font-size: 15px;
        white-space: nowrap;
    }

    .call-btn i {
        font-size: 16px;
    }

    /* PRICING */
    .pricing {
        display: grid;
        grid-template-columns: 1fr;
        gap: 24px;
        margin-bottom: 20px;
    }

    .card {
        width: 100%;
        padding: 28px 22px;
        border-radius: 24px;
    }

    .popular {
        transform: none;
    }

    .badge {
        width: 210px;
        top: 36px;
        right: -58px;
        padding: 10px;
        font-size: 11px;
    }

    .icon {
        width: 74px;
        height: 74px;
        font-size: 28px;
        margin-bottom: 20px;
    }

    .card h2 {
        font-size: 34px;
        line-height: 1.1;
        word-break: break-word;
    }

    .small-desc {
        font-size: 15px;
        line-height: 1.6;
        margin-bottom: 24px;
    }

    .price {
        font-size: 52px;
        line-height: 1;
        word-break: break-word;
    }

    .price span {
        font-size: 24px;
    }

    /* LISTY */
    .section h3 {
        font-size: 16px;
    }

    .section ul li {
        font-size: 15px;
        line-height: 1.7;
        margin-bottom: 14px;
        word-break: break-word;
    }

    /* EXTRA BOX */
    .extra-box {
        padding: 24px 20px;
        border-radius: 22px;
    }

    .extra-price {
        font-size: 16px;
    }

    .extra-box ul li {
        font-size: 15px;
        line-height: 1.8;
        margin-bottom: 18px;
    }

    /* SUBSCRIPTION */
    .subscription-box {
        padding: 24px 20px;
        border-radius: 22px;
    }

    .subscription-title {
        font-size: 17px;
    }

    .subscription-price {
        font-size: 36px;
        line-height: 1.2;
        word-break: break-word;
    }

    .subscription-price span {
        font-size: 20px;
    }

    .subscription-content h4 {
        font-size: 18px;
        margin-bottom: 20px;
    }

    .subscription-content ul li {
        font-size: 15px;
        line-height: 1.8;
        margin-bottom: 18px;
        word-break: break-word;
    }

    /* ADDONS */
    .addons-wrapper {
        padding: 28px 22px;
        border-radius: 24px;
        margin-bottom: 20px;
    }

    .addons {
        display: grid;
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .addon-card {
        width: 100%;
        padding: 26px 22px;
        border-radius: 22px;
    }

    .addon-icon {
        width: 68px;
        height: 68px;
        font-size: 26px;
        margin-bottom: 18px;
    }

    .addon-card h4 {
        font-size: 20px;
        line-height: 1.3;
        margin-bottom: 12px;
        word-break: break-word;
    }

    .addon-card p {
        font-size: 14px;
        line-height: 1.7;
        margin-bottom: 20px;
        min-height: auto;
    }

    .addon-price {
        font-size: 18px;
        padding: 10px 18px;
        border-radius: 12px;
    }

    /* PROCESS */
    .process-wrapper {
        width: 100%;
        padding: 28px 22px;
        border-radius: 24px;
        margin-bottom: 20px;
    }

    .process-title {
        font-size: 24px;
        text-align: center;
        line-height: 1.3;
        margin-bottom: 30px;
    }

    .process {
        display: flex;
        flex-direction: column;
        gap: 18px;
    }

    .arrow {
        transform: rotate(90deg);
        font-size: 28px;
    }

    .step {
        width: 100%;
        min-width: 0;
    }

    .step i {
        width: 70px;
        height: 70px;
        font-size: 26px;
    }

    .step h4 {
        font-size: 18px;
        line-height: 1.3;
    }

    .step p {
        font-size: 15px;
        line-height: 1.7;
    }

    /* FOOTER */
    footer {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;

        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;

        padding: 28px 22px;
        border-radius: 24px;
    }

    footer p {
        font-size: 14px;
        line-height: 1.7;
        word-break: break-word;
    }

    footer a {
        color: #8b5cff;
        word-break: break-word;
    }

    .copyright {
        margin-left: 0;
        text-align: left;
    }
}