:root{
    --bg: #e9e9e9;
    --white: #ffffff;
    --black: #0d0d0f;
    --text: #141414;
    --muted: #6f6f72;
    --pink: #ef4aa8;
    --blue: #3d79ff;
    --gold: #e3bc16;
    --soft: #f2f2f2;
    --dark: #111214;
    --coral: #f56b5f;
    --violet: #8b5cf6;
    --mint: #25c2a0;
    --border: rgba(0,0,0,0.06);
    --shadow: 0 30px 80px rgba(0,0,0,0.08);
    --radius: 0px;
    --transition: 0.45s cubic-bezier(.2,.8,.2,1);
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Inter', sans-serif;
    background:var(--bg);
    color:var(--text);
    overflow-x:hidden;
}

body.menu-open{
    overflow:hidden;
}

img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}

a{
    text-decoration:none;
    color:inherit;
}

.page-frame{
    position:fixed;
    inset:0;
    border:1px solid rgba(0,0,0,0.08);
    pointer-events:none;
    z-index:200;
}

.topbar{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:105px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:26px 40px;
    z-index:9999;
    pointer-events:none;
}

.brand,
.menu-button{
    pointer-events:auto;
}

.brand,
.signature-logo{
    position:fixed;
    top:28px;
    left:42px;
    font-family:'Caveat', cursive;
    font-size:2.35rem;
    line-height:1;
    letter-spacing:-1px;
    z-index:10000;
    pointer-events:auto;
    color:#ff2aa1;
    background:none;
    -webkit-background-clip:initial;
    -webkit-text-fill-color:initial;
    text-shadow:none;
    text-transform:none;
    transform:rotate(-5deg);
}

.brand::after,
.signature-logo::after{
    content:"";
    position:absolute;
    left:4px;
    right:5px;
    bottom:-5px;
    height:2px;
    background:#ff2aa1;
    border-radius:999px;
    opacity:.85;
    transform:rotate(-2deg);
}

.menu-button,
.menu-close{
    border:none;
    background:#fff;
    color:#111;
    font-weight:800;
    font-size:1.05rem;
    letter-spacing:0.5px;
    padding:18px 24px;
    cursor:pointer;
    transition:var(--transition);
    box-shadow:var(--shadow);
}

.menu-button{
    position:fixed;
    top:26px;
    right:40px;
    z-index:10000;
}

.menu-button:hover,
.menu-close:hover{
    transform:translateY(-2px);
}

.overlay-menu{
    position:fixed;
    top:96px;
    right:40px;
    width:360px;
    max-width:calc(100vw - 40px);
    background:rgba(255,255,255,0.98);
    border:1px solid rgba(0,0,0,0.08);
    box-shadow:0 30px 80px rgba(0,0,0,0.16);
    opacity:0;
    visibility:hidden;
    transform:translateY(-14px) scale(0.98);
    transition:var(--transition);
    z-index:300;
    backdrop-filter:blur(10px);
}

.overlay-menu.active{
    opacity:1;
    visibility:visible;
    transform:translateY(0) scale(1);
}

.overlay-inner{
    width:100%;
    padding:22px;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:18px;
}

.overlay-nav{
    width:100%;
    display:flex;
    flex-direction:column;
    gap:10px;
    align-items:flex-start;
}

.overlay-nav a{
    width:100%;
    font-size:clamp(1.4rem, 2vw, 2rem);
    font-weight:900;
    color:#111;
    line-height:1;
    padding:12px 8px;
    transition:var(--transition);
    border-bottom:1px solid rgba(0,0,0,0.06);
}

.overlay-nav a:hover{
    color:var(--gold);
    transform:translateX(8px);
}

.hero{
    position:relative;
    width:100%;
    min-height:100vh;
    overflow:hidden;
    background:#f5f5f5;
}

.hero-full{
    width:100%;
    min-height:100vh;
}

.hero-bg{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    z-index:1;
}

.hero-bg img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    display:block;
}

.hero-overlay-soft{
    position:absolute;
    inset:0;
    z-index:2;
    background:
        linear-gradient(
            to right,
            rgba(255,255,255,0.46) 0%,
            rgba(255,255,255,0.24) 22%,
            rgba(255,255,255,0.10) 42%,
            rgba(255,255,255,0.00) 68%
        ),
        linear-gradient(
            to top,
            rgba(255,255,255,0.30) 0%,
            rgba(255,255,255,0.00) 35%
        );
}

.hero-socials{
    position:absolute;
    top:140px;
    right:42px;
    z-index:20;
    display:flex;
    align-items:center;
    gap:12px;
}

.hero-socials a{
    width:42px;
    height:42px;
    background:#ffffff;
    color:#111111;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    font-size:17px;
    text-decoration:none;
    box-shadow:0 12px 28px rgba(0,0,0,.10);
    transition:all .3s ease;
}

.hero-socials a:hover{
    transform:translateY(-5px);
    background:#111111;
    color:#ffffff;
}

.hero-content{
    max-width:620px;
}

.hero-content-absolute{
    position:absolute;
    left:60px;
    bottom:70px;
    z-index:3;
    max-width:620px;
}

.mini-label,
.section-mini{
    display:inline-block;
    font-size:0.9rem;
    font-weight:800;
    letter-spacing:0.08em;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:18px;
}

.hero-content-absolute .mini-label{
    background:rgba(255,255,255,0.72);
    padding:8px 12px;
    backdrop-filter:blur(6px);
}

.hero-title{
    font-size:clamp(4.8rem, 9vw, 9.2rem);
    line-height:0.86;
    font-weight:900;
    letter-spacing:-0.07em;
    color:var(--black);
    text-transform:uppercase;
}

.hero-title-hidden{
    font-size:0 !important;
    line-height:0 !important;
    min-height:0 !important;
    margin:0 !important;
}

.hero-link{
    margin-top:22px;
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-size:1.4rem;
    font-weight:800;
    color:var(--black);
    background:rgba(255,255,255,0.72);
    padding:12px 16px;
    backdrop-filter:blur(8px);
    transition:var(--transition);
}

.hero-link:hover{
    transform:translateX(6px);
    background:#fff;
}

.hero-link .arrow{
    font-size:2rem;
    line-height:1;
}

.scroll-indicator{
    position:absolute;
    left:50%;
    bottom:38px;
    transform:translateX(-50%);
    width:34px;
    height:62px;
    border:2px solid rgba(255,255,255,0.9);
    border-radius:40px;
    display:flex;
    justify-content:center;
    align-items:flex-start;
    padding-top:10px;
    z-index:3;
    mix-blend-mode:difference;
}

.scroll-indicator span{
    display:block;
    width:5px;
    height:14px;
    border-radius:10px;
    background:#fff;
    animation:scrollDot 1.5s infinite;
}

@keyframes scrollDot{
    0%{ transform:translateY(0); opacity:0.4; }
    50%{ transform:translateY(14px); opacity:1; }
    100%{ transform:translateY(0); opacity:0.4; }
}

.about-section{
    display:none !important;
}

.about-grid{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap:32px;
}

.about-text,
.about-box{
    background:#fff;
    padding:50px;
    box-shadow:var(--shadow);
    position:relative;
    overflow:hidden;
    border:1px solid rgba(0,0,0,0.04);
    transition:
        transform 0.38s cubic-bezier(.2,.8,.2,1),
        box-shadow 0.38s cubic-bezier(.2,.8,.2,1),
        background 0.38s cubic-bezier(.2,.8,.2,1),
        border-color 0.38s cubic-bezier(.2,.8,.2,1),
        color 0.38s cubic-bezier(.2,.8,.2,1);
}

.about-text::before,
.about-box::before{
    content:"";
    position:absolute;
    top:0;
    left:-120%;
    width:72%;
    height:100%;
    background:linear-gradient(
        to right,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0.42) 52%,
        rgba(255,255,255,0) 100%
    );
    transform:skewX(-18deg);
    transition:0.9s ease;
    pointer-events:none;
    z-index:1;
}

.about-text::after,
.about-box::after{
    content:"";
    position:absolute;
    inset:14px;
    border:1px solid rgba(255,255,255,0);
    transition:0.35s ease;
    pointer-events:none;
    z-index:1;
}

.about-text > *,
.about-box > *{
    position:relative;
    z-index:2;
}

.about-text:hover,
.about-box:hover{
    transform:translateY(-8px);
    background:linear-gradient(135deg, #f4d64e 0%, #e3bc16 100%);
    box-shadow:0 34px 90px rgba(0,0,0,0.16);
    border-color:rgba(0,0,0,0.08);
}

.about-text:hover::before,
.about-box:hover::before{
    left:145%;
}

.about-text:hover::after,
.about-box:hover::after{
    border-color:rgba(255,255,255,0.34);
}

.about-text:hover .section-mini,
.about-box:hover .section-mini,
.about-text:hover p,
.about-box:hover p,
.about-text:hover span,
.about-box:hover span{
    color:#2b2c31;
}

.about-text:hover h2,
.about-box:hover h2,
.about-box:hover .about-stat strong,
.about-text:hover .about-stat strong{
    color:#0d0d0f;
}

.about-box .about-stat strong,
.about-text .about-stat strong{
    transition:transform 0.35s ease, letter-spacing 0.35s ease, color 0.35s ease;
}

.about-box:hover .about-stat strong,
.about-text:hover .about-stat strong{
    transform:scale(1.03);
    letter-spacing:-1px;
}

.about-text h2{
    font-size:clamp(2rem, 4vw, 4rem);
    line-height:0.95;
    font-weight:900;
    letter-spacing:-0.05em;
    margin-bottom:18px;
}

.about-text p:last-child{
    font-size:1.05rem;
    line-height:1.9;
    color:#4e4e53;
    max-width:760px;
}

.about-box{
    display:grid;
    gap:22px;
    align-content:center;
}

.about-stat strong{
    display:block;
    font-size:3rem;
    font-weight:900;
    line-height:1;
}

.about-stat span{
    display:block;
    margin-top:6px;
    font-size:1rem;
    color:#5f5f65;
    font-weight:600;
}

.projects-section{
    padding:0 0 40px;
}

.projects-grid{
    display:grid;
    grid-template-columns: 1fr 1.08fr;
    grid-template-rows: 1fr 1fr;
    gap:20px;
    min-height:820px;
    padding:20px;
    background:#e9e9e9;
}

.project-card{
    position:relative;
    overflow:hidden;
    min-height:420px;
    background:#ececec;
    transition:var(--transition);
    border:1px solid rgba(0,0,0,0.04);
}

.project-card.big-left{
    grid-column:1 / 2;
    grid-row:1 / 3;
    min-height:820px;
}

.project-card.right-long:nth-child(2),
.project-card.small-right:nth-child(2){
    grid-column:2 / 3;
    grid-row:1 / 2;
    min-height:400px;
}

.project-card.right-long:nth-child(3),
.project-card.small-right:nth-child(3){
    grid-column:2 / 3;
    grid-row:2 / 3;
    min-height:400px;
}

.card-tall{
    min-height:760px;
}

.card-small{
    min-height:380px;
}

.project-visual{
    position:absolute;
    inset:0;
}

.project-visual img{
    transition:transform 0.9s ease, filter 0.5s ease, opacity 0.5s ease;
}

.project-overlay{
    position:absolute;
    inset:0;
    background:rgba(255,255,255,0.02);
    transition:var(--transition);
    z-index:1;
}

.project-content{
    position:absolute;
    inset:0;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    padding:28px 28px 22px;
    z-index:2;
}

.project-count{
    font-size:1rem;
    font-weight:800;
    margin-bottom:8px;
    transition:var(--transition);
}

.project-title{
    font-size:clamp(3rem, 7vw, 7rem);
    line-height:0.88;
    font-weight:900;
    letter-spacing:-0.08em;
    text-transform:uppercase;
    max-width:95%;
    transition:var(--transition);
}

.project-link{
    margin-top:10px;
    font-size:1rem;
    font-weight:700;
    opacity:0;
    transform:translateY(16px);
    transition:var(--transition);
}

.project-card:hover .project-link{
    opacity:1;
    transform:translateY(0);
}

.project-card:hover .project-visual img{
    transform:scale(1.08);
    filter:blur(2px) brightness(0.72);
}

.badge{
    position:absolute;
    top:20px;
    left:20px;
    z-index:3;
    background:#000;
    color:#fff;
    padding:7px 11px;
    font-size:0.72rem;
    font-weight:800;
    letter-spacing:0.12em;
    text-transform:uppercase;
}

.hover-soft:hover .project-overlay{
    background:rgba(245, 94, 91, 0.88);
}

.hover-gold:hover .project-overlay{
    background:rgba(227, 188, 22, 0.88);
}

.hover-blue:hover .project-overlay{
    background:rgba(61, 121, 255, 0.88);
}

.hover-white:hover .project-overlay{
    background:rgba(139, 92, 246, 0.88);
}

.hover-dark:hover .project-overlay{
    background:rgba(17, 18, 20, 0.88);
}

.hover-pink:hover .project-overlay{
    background:rgba(239, 74, 168, 0.88);
}

.hover-soft:hover .project-title,
.hover-soft:hover .project-count,
.hover-soft:hover .project-link,
.hover-gold:hover .project-title,
.hover-gold:hover .project-count,
.hover-gold:hover .project-link,
.hover-blue:hover .project-title,
.hover-blue:hover .project-count,
.hover-blue:hover .project-link,
.hover-white:hover .project-title,
.hover-white:hover .project-count,
.hover-white:hover .project-link,
.hover-dark:hover .project-title,
.hover-dark:hover .project-count,
.hover-dark:hover .project-link,
.hover-pink:hover .project-title,
.hover-pink:hover .project-count,
.hover-pink:hover .project-link{
    color:#fff;
}

.contact-strip{
    padding:40px;
    background:#f3f3f3;
}

.contact-inner{
    max-width:1400px;
    margin:0 auto;
    background:#fff;
    padding:48px 50px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    box-shadow:var(--shadow);
}

.contact-text h2{
    font-size:clamp(2rem, 4vw, 4rem);
    line-height:0.95;
    font-weight:900;
    letter-spacing:-0.05em;
}

.contact-button{
    background:#111;
    color:#fff;
    padding:20px 28px;
    font-weight:800;
    transition:var(--transition);
    white-space:nowrap;
}

.contact-button:hover{
    background:#ff3b9f;
    color:#fff;
    transform:translateY(-3px);
}

.scroll-top-btn{
    position:fixed;
    right:22px;
    bottom:22px;
    width:56px;
    height:56px;
    border:none;
    border-radius:50%;
    background:#111;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:1.4rem;
    font-weight:900;
    cursor:pointer;
    box-shadow:0 18px 40px rgba(0,0,0,0.18);
    opacity:0;
    visibility:hidden;
    transform:translateY(12px);
    transition:0.3s ease;
    z-index:10001;
}

.scroll-top-btn.show{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

.scroll-top-btn:hover{
    background:var(--gold);
    color:#111;
}

@media (max-width: 1200px){
    .about-grid,
    .contact-inner{
        grid-template-columns:1fr;
        flex-direction:column;
        align-items:flex-start;
    }
}

@media (max-width: 900px){
    .topbar{
        height:92px;
        padding:16px 18px;
    }

    .brand,
    .signature-logo{
        top:20px;
        left:22px;
        font-size:1.75rem;
    }

    .menu-button{
        top:18px;
        right:18px;
        padding:12px 16px;
        font-size:0.9rem;
    }

    .overlay-menu{
        top:78px;
        right:20px;
        width:calc(100vw - 40px);
        max-width:none;
    }

    .hero-socials{
        top:105px;
        right:18px;
        gap:8px;
    }

    .hero-socials a{
        width:36px;
        height:36px;
        font-size:15px;
    }

    .projects-grid{
        display:flex;
        flex-direction:column;
        min-height:auto;
        padding:12px;
        gap:12px;
    }

    .project-card.big-left,
    .project-card.right-long,
    .project-card.small-right,
    .card-tall,
    .card-small{
        min-height:420px;
    }

    .about-section,
    .contact-strip{
        padding:20px;
    }

    .about-grid{
        grid-template-columns:1fr !important;
        gap:20px;
    }

    .about-text,
    .about-box,
    .contact-inner{
        padding:24px;
    }

    .project-content{
        padding:18px;
    }

    .hero-content-absolute{
        left:22px;
        right:22px;
        bottom:34px;
        max-width:none;
    }

    .hero-title{
        font-size:clamp(3.2rem, 12vw, 5rem);
    }

    .hero-link{
        font-size:1.1rem;
        padding:10px 14px;
    }

    .hero-bg img{
        object-position:center center;
    }

    .scroll-top-btn{
        right:16px;
        bottom:16px;
        width:48px;
        height:48px;
        font-size:1.15rem;
    }
}

@media (max-width: 560px){
    .hero-title{
        font-size:3rem;
    }

    .hero-link{
        font-size:1rem;
    }

    .project-title{
        font-size:3.2rem;
    }

    .overlay-nav a{
        font-size:1.25rem;
    }

    .mini-label,
    .section-mini{
        font-size:0.72rem;
    }

    .hero-socials{
        flex-wrap:wrap;
        width:180px;
        justify-content:flex-end;
    }
}