:root{
    --bg:#0f1114;
    --text: rgba(255,255,255,.90);
    --muted: rgba(255,255,255,.62);
    --muted2: rgba(255,255,255,.48);
    --shadow: 0 20px 70px rgba(0,0,0,.55);
    --radius2: 22px;
    --container: 1160px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
    margin:0;
    color:var(--text);
    background: var(--bg);
    font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

a{ color: inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.container{
    width:min(var(--container), calc(100% - 48px));
    margin:0 auto;
}

/* ---- global bg ---- */
.bg{
    position:fixed;
    inset:0;
    z-index:-3;
    background:
            radial-gradient(1000px circle at 15% 5%, rgba(255,255,255,.08), transparent 55%),
            radial-gradient(900px circle at 80% 15%, rgba(255,255,255,.06), transparent 55%),
            radial-gradient(1200px circle at 50% 90%, rgba(255,255,255,.05), transparent 60%);
}

/* ---- NAV ---- */
.nav{
    position:fixed;
    top:0; left:0; right:0;
    z-index:50;
    background: rgba(10,12,14,.55);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(255,255,255,.08);
    will-change: transform;
    transition: transform .22s ease;
}
.nav.nav--hidden{
    transform: translateY(-100%);
}

.nav__inner{
    height:64px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
}

.brand{ font-weight:600; letter-spacing:.2px; }

.nav__links{
    display:flex;
    gap:20px;
    color: var(--muted);
    font-size:14px;
}
.nav__links a:hover{ color: var(--text); }

.burger{
    display:none;
    width:40px; height:40px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color:#fff;
    cursor:pointer;
}
.burger span{
    display:block;
    height:2px;
    margin:5px 9px;
    background: rgba(255,255,255,.85);
    border-radius:2px;
}

@media (max-width: 760px){
    .nav__links{ display:none; }
    .burger{ display:inline-block; }
}

/* ===== MOBILE MENU (panel + backdrop) ===== */
.mobileMenu{
    position: fixed;
    inset: 0;
    z-index: 60;
    display: none;
}
.mobileMenu.is-open{ display:block; }

.mobileMenu__backdrop{
    position:absolute;
    inset:0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(8px);
}

.mobileMenu__panel{
    position:absolute;
    left: 12px;
    right: 12px;
    top: 74px; /* під nav */
    border-radius: 18px;
    overflow:hidden;

    background: rgba(14,16,18,.88);
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: var(--shadow);
}

.mobileMenu__top{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(255,255,255,.10);

    /* окремий фон під текстом (щоб не зливався) */
    background: rgba(10,12,14,.65);
    backdrop-filter: blur(10px);
}
.mobileMenu__title{
    font-weight:600;
    letter-spacing:.2px;
}

.mobileMenu__close{
    appearance:none;
    border:1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color:#fff;
    border-radius: 12px;
    padding: 8px 10px;
    cursor:pointer;
}
.mobileMenu__close:hover{ background: rgba(255,255,255,.12); }

.mobileMenu__links a{
    display:block;
    padding: 14px 14px;
    font-size: 18px;
    color: rgba(255,255,255,.88);
    border-bottom: 1px solid rgba(255,255,255,.10);
}
.mobileMenu__links a:last-child{ border-bottom:none; }
.mobileMenu__links a:active{ background: rgba(255,255,255,.06); }

/* ---- HERO ---- */
.hero{
    position:relative;
    padding-top: 86px;
    padding-bottom: 28px;
}
.hero__bg{
    position:absolute;
    inset:0;
    z-index:-1;
    background-image:
            linear-gradient(to bottom, rgba(10,12,14,.55), rgba(10,12,14,.75)),
            url("./assets/Artwork.webp");
    background-size: cover;
    background-position: center;
    background-repeat:no-repeat;
    filter: saturate(1.05);
}
.hero__content{ padding: 36px 0 24px; }

.heroCard{
    border-radius: 22px;
    background: rgba(20,22,24,.55);
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: var(--shadow);
    padding: 30px 28px;
    max-width: 980px;
}
.heroCard__kicker{
    letter-spacing: 2.6px;
    font-size: 12px;
    color: var(--muted2);
}
.heroCard__title{
    margin: 10px 0 10px;
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1.06;
}
.heroCard__sub{ margin:0 0 18px; color: var(--muted); }
.heroCard__actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* ---- buttons ---- */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding: 10px 14px;
    border-radius: 999px;
    border:1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: var(--text);
    cursor:pointer;
    font-size:14px;
}
.btn:hover{ background: rgba(255,255,255,.10); }
.btn--primary{
    background:#fff;
    color:#111;
    border-color: rgba(255,255,255,.22);
}
.btn--primary:hover{ opacity:.92; }
.btn--ghost{ background: rgba(255,255,255,.06); color: var(--text); }

/* ---- sections ---- */
.section{ padding: 34px 0; }
.section--bottom{ padding-bottom: 70px; }

.section__title{
    margin: 0 0 10px;
    font-size: 34px;
    letter-spacing: .1px;
}
.section__bullets{ margin: 0 0 18px; color: var(--muted); }
.section__spacer{ margin-top: 34px; }

/* ---- grid / item ---- */
.grid{
    display:grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap:18px;
}
@media (max-width: 980px){
    .grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px){
    .grid{ grid-template-columns: 1fr; }
}

.item{
    appearance:none;
    border:1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.04);
    border-radius: 22px;
    overflow:hidden;
    cursor:pointer;
    text-align:left;
    padding:0;
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.item:hover{
    border-color: rgba(255,255,255,.18);
    background: rgba(255,255,255,.055);
}

.item__media{
    position:relative;
    aspect-ratio: 16/9;
    background: rgba(255,255,255,.03);
}
.item__img{
    width:100%;
    height:100%;
    object-fit: cover;
    display:block;
}
.item__body{ display:none; }

/* ---- contacts ---- */
.contacts{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin-top: 10px;
}
.pill{
    display:inline-flex;
    padding: 10px 12px;
    border-radius: 999px;
    border:1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.82);
}
.pill:hover{ background: rgba(255,255,255,.10); }

/* ---- MODAL ---- */
.modal{
    position:fixed;
    inset:0;
    z-index:999;
    display:none;
}
.modal.is-open{ display:block; }

.modal__backdrop{
    position:absolute;
    inset:0;
    background: rgba(0,0,0,.65);
    backdrop-filter: blur(6px);
}

.modal__panel{
    position:absolute;
    left:50%;
    top:50%;
    transform: translate(-50%, -50%);
    width: min(1100px, calc(100vw - 32px));
    max-height: calc(100vh - 32px);
    border-radius: 18px;
    overflow:hidden;
    background: rgba(20,22,24,.92);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: var(--shadow);
    display:flex;
    flex-direction:column;
}

.modal__top{ display:none; }
.modal__body{
    padding: 12px;
    overflow:auto;
}
.modal__body img{
    width:100%;
    height:auto;
    display:block;
    border-radius: 12px;
    background: rgba(255,255,255,.03);
}

/* Personal: last items as 3:4 */
#gridPersonal .item:nth-last-child(-n+4) .item__media {
    aspect-ratio: 3 / 4;
}
