﻿:root {
    --bg: #0b1020;
    --bg2: #12193a;
    --txt: #e8ecff;
    --muted: #aab2dc;
    --brand: #5757c9;
    --brand2: #7f7fff;
    --brand3: #313175;
    --card: #121a38cc;
    --star-size: 2rem;
    --star-gap: 0.4rem;
    --star-color: #c9c9c9; /* kolor "pustej" gwiazdki */
    --star-active: #ffb400; /* kolor zaznaczonej */
    --star-hover: #ffc94d; /* kolor pod hoverem */
    --radius: 16px;
    --shadow: 0 10px 30px rgba(0,0,0,.15);
}

* {
    box-sizing: border-box
}

html, body {
    height: 100%
}

body {
    margin: 0;
    font-family: Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
    color: var(--txt);
    background: radial-gradient(1000px 600px at 10% 0%, #1a2250 0, transparent 60%), radial-gradient(900px 500px at 90% 0%, #202a63 0, transparent 60%), var(--bg);
}

.container {
    width: min(1100px,92vw);
    margin-inline: auto
}

.section {
    padding: 64px 0
}


/* Nav */
nav {
    position: sticky;
    top: 0;
    z-index: 10;
    backdrop-filter: blur(10px);
    background: #0b1020b0;
    border-bottom: 1px solid #202a60
}

    nav .in {
        display: flex;
        flex-direction: column;
        gap: 10px;
        justify-content: space-between;
        align-items: start;
        padding: 14px 0 0 0;
    }

.brand {
    display: flex;
    gap: 10px;
    align-items: center;
    color: var(--txt);
    text-decoration: none
}

nav a {
    color: var(--muted);
    text-decoration: none;
    margin: 5px ;
    font-weight: 600
}

    nav a:hover {
        color: var(--txt)
    }


/* Hero */
.hero {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 28px;
    align-items: center;
    padding: 56px 0 24px
}

    .hero h1 {
        font-size: clamp(28px,4.5vw,48px);
        line-height: 1.06;
        margin: 0 0 10px
    }

.lead {
    margin: 14px 0 26px;
    color: #cbd4ff;
    font-size: clamp(14px,1.6vw,18px)
}

.btn {
    display: inline-block;
    padding: 12px 18px;
    border-radius: 14px;
    text-decoration: none;
    font-weight: 800
}

.btn:hover{
    cursor: pointer;
}

.btn-primary {
    background: linear-gradient(135deg,var(--brand),var(--brand2));
    color: #fff
}

.btn-ghost {
    border: 1px solid #2b3470;
    color: #dbe1ff;
    background-color: transparent;
}

.flex-row {
    display: flex;
    flex-direction: row;
    gap: 12px;
}

.preview {
    border-radius: 18px;
    border: 1px solid #26306b;
    background: #0f1635;
    padding: 22px
}

    .preview .grid {
        display: grid;
        grid-template-columns: repeat(3,1fr);
        gap: 14px
    }

.card {
    background: var(--card);
    border: 1px solid #2b3470;
    padding: 16px;
    border-radius: 16px
}

    .card h4 {
        margin: 0 0 8px;
        font-size: 14px;
        color: #cfd6ff
    }

    .card p {
        margin: 0;
        font-size: 13px;
        color: #aeb8ea
    }


h2 {
    margin: 0 0 12px
}

.grid-3 {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 18px
}

.service {
    background: var(--card);
    border: 1px solid #28306a;
    padding: 20px;
    border-radius: 18px
}

.tag {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 999px;
    background: #141d3f;
    border: 1px solid #2b3470;
    color: #bfc9ff;
    font-size: 12px;
    margin: 6px 6px 0 0
}


.about {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px
}


.contact {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    grid-template-rows: auto auto;
    gap: 18px
}

.rate {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px
}


.box {
    background: var(--card);
    border: 1px solid #28306a;
    padding: 20px;
    border-radius: 18px
}

    .box a {
        color: #dbe1ff
    }

.box-padding-submenu {
    padding: 6px 12px;
}

footer {
    border-top: 1px solid #253066;
    padding: 22px 0;
    color: #91a0dc;
    text-align: center
}



@media (max-width:980px) {
    .hero {
        grid-template-columns: 1fr
    }

    .preview .grid {
        grid-template-columns: repeat(2,1fr)
    }

    .grid-3 {
        grid-template-columns: 1fr 1fr
    }

    .about {
        grid-template-columns: 1fr
    }

    .contact {
        grid-template-columns: 1fr
    }

    .rates{
        max-width: 950px;
    }
}

@media (max-width:620px) {
    .grid-3, .preview .grid {
        grid-template-columns: 1fr
    }

}

@media (pointer: coarse) {
    :root {
        --star-size: 2.2rem;
    }
}