/* =========================
PAGE HERO
========================= */

.page-hero{
padding-top:220px;
padding-bottom:120px;
}

.page-hero h1{
max-width:900px;
font-size:72px;
line-height:1.05;
margin-bottom:30px;
}

.page-hero p{
max-width:700px;
}

.case-hero{
padding-top:220px;
padding-bottom:120px;
}

.case-hero h1{
max-width:900px;
font-size:72px;
line-height:1.05;
margin-bottom:24px;
}

.case-hero p{
max-width:700px;
}

/* =========================
ABOUT PAGE
========================= */

.about-page .about-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:80px;
}

.tools-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:24px;

    margin-top:50px;

}

.tool-card{

    background:var(--color-surface);

    border:1px solid var(--color-border);

    border-radius:24px;

    height:120px;

    display:flex;

    align-items:center;

    justify-content:center;

    transition:.3s ease;

}

.tool-card:hover{

    transform:translateY(-6px);

    border-color:rgba(255,255,255,.15);

}

.tool-card img{

    max-width:120px;

    max-height:48px;

    filter:grayscale(100%);

    opacity:.7;

    transition:.3s ease;

}

.tool-card:hover img{

    filter:none;

    opacity:1;

}

/* =========================
PORTFOLIO FILTER
========================= */

.portfolio-filter{
display:flex;
justify-content:center;
gap:16px;
flex-wrap:wrap;
}

/* =========================
HERO
========================= */

.hero{
margin-top:60px;
min-height:100vh;
display:flex;
align-items:center;
}

.hero-content{
display:grid;
grid-template-columns:1.1fr 1fr;
gap:70px;
align-items:center;
}

.hero h1{
font-size:78px;
line-height:1.05;
margin-bottom:28px;
}

.hero p{
max-width:560px;
margin-bottom:40px;
}

.hero-buttons{
display:flex;
gap:18px;
}

.hero-image{
height:650px;
overflow:hidden;
border-radius:30px;
background:#101010;
}

.hero-image img{
width:100%;
height:100%;
object-fit:cover;
}

/* =========================
CLIENTS
========================= */

.clients{
padding:120px 0;
}

.client-slider{
overflow:hidden;
margin-top:50px;
}

.client-track{
display:flex;
gap:70px;
width:max-content;
animation:clientScroll 25s linear infinite;
}

.client-slider:hover .client-track{
    animation-play-state:paused;
}

.client-logo{
width:140px;
height:80px;
display:flex;
align-items:center;
justify-content:center;
opacity:.5;
transition:.3s ease;
}

.client-logo:hover{
opacity:1;
}

.client-logo img{

    max-width:120px;
    max-height:50px;

    filter:grayscale(100%);

    opacity:.5;

    transition:.4s ease;

}

.client-logo:hover img{

    filter:grayscale(0%);

    opacity:1;

}

.client-logo{

    transition:.3s ease;

}

.client-logo:hover{

    transform:translateY(-4px);

}

.mono-logo img{

    filter:
        grayscale(100%)
        brightness(0)
        invert(1);

    opacity:.8;

}

.mono-logo:hover img{

    filter:brightness(0) invert(1);

    opacity:1;

}

@keyframes clientScroll{

from{
transform:translateX(0);
}

to{
transform:translateX(-50%);
}

}

/* =========================
ABOUT
========================= */

.about-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:70px;
align-items:center;
}

.stats{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:24px;
}

.stat-card{
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:30px;
padding:35px;
}

.stat-card h3{
font-size:48px;
margin-bottom:10px;
}

.stat-card p{
margin:0;
}

/* =========================
SERVICES
========================= */

.services-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:24px;
margin-top:50px;
}

.service-card{
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:30px;
padding:40px;
transition:.3s ease;
}

.service-card:hover{
transform:translateY(-8px);
border-color:rgba(255,255,255,.15);
}

.service-card h3{
font-size:24px;
margin-bottom:16px;
}

/* =========================
PORTFOLIO
========================= */

.portfolio-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:30px;
margin-top:50px;
}

.portfolio-card{
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:30px;
overflow:hidden;
transition:.3s ease;
}

.portfolio-card:hover{
transform:translateY(-8px);
}

.portfolio-image{
height:320px;
overflow:hidden;
}

.portfolio-image img{
width:100%;
height:100%;
object-fit:cover;
transition:.5s ease;
}

.portfolio-card:hover .portfolio-image img{
transform:scale(1.05);
}

.portfolio-content{
padding:32px;
}

.portfolio-content h3{
font-size:28px;
margin-bottom:12px;
}

/* =========================
TESTIMONIALS
========================= */

.testimonial-slider{
overflow-x:auto;
margin-top:50px;
scrollbar-width:none;
}

.testimonial-slider::-webkit-scrollbar{
display:none;
}

.testimonial-track{
display:flex;
gap:24px;
width:max-content;
}

.testimonial-card{
width:420px;
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:30px;
padding:40px;
transition:.3s ease;
}

.testimonial-card:hover{
transform:translateY(-8px);
}

.testimonial-text{
font-size:18px;
line-height:1.9;
margin-bottom:35px;
}

.testimonial-user{
display:flex;
align-items:center;
gap:16px;
}

.testimonial-avatar{
width:58px;
height:58px;
border-radius:50%;
overflow:hidden;
}

.testimonial-avatar img{
width:100%;
height:100%;
object-fit:cover;
}

/* =========================
CTA
========================= */

.cta-box{
background:linear-gradient(
145deg,
#141414,
#0c0c0c
);

border:1px solid var(--color-border);
border-radius:40px;
padding:90px 60px;
text-align:center;
}

.cta-box h2{
margin-bottom:20px;
}

.cta-box p{
max-width:700px;
margin:0 auto 35px auto;
}

/* =========================
BLOG
========================= */

.featured-post-card{
display:grid;
grid-template-columns:1.2fr 1fr;
gap:40px;
align-items:center;
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:30px;
overflow:hidden;
}

.featured-post-image{
height:500px;
}

.featured-post-image img{
width:100%;
height:100%;
object-fit:cover;
}

.featured-post-content{
padding:40px;
}

.featured-post-content h2{
margin:16px 0 20px;
}

.blog-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
margin-top:50px;
}

.pagination-section{
padding-top:40px;
padding-bottom:120px;
}

/* =========================
SINGLE BLOG
========================= */

.article-content{
max-width:800px;
margin:0 auto;
}

.article-content h2{
margin-top:60px;
margin-bottom:20px;
font-size:36px;
}

.article-content p{
margin-bottom:24px;
font-size:18px;
line-height:1.9;
}

.article-content blockquote{
margin:50px 0;
padding:30px;
border-left:4px solid var(--color-accent);
background:#101010;
border-radius:20px;
font-size:22px;
font-weight:600;
color:#fff;
}

.author-box{
display:flex;
align-items:center;
gap:24px;
max-width:800px;
margin:0 auto;
padding:32px;
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:24px;
}

.author-avatar{
width:80px;
height:80px;
border-radius:50%;
overflow:hidden;
flex-shrink:0;
}

.author-avatar img{
width:100%;
height:100%;
object-fit:cover;
}

/* =========================
CONTACT
========================= */

.contact-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
align-items:start;
}

.contact-list{
margin-top:40px;
display:flex;
flex-direction:column;
gap:24px;
}

.contact-item h4{
margin-bottom:8px;
}

.contact-item a{
color:#fff;
}

.contact-form-wrapper{
background:var(--color-surface);
border:1px solid var(--color-border);
border-radius:30px;
padding:40px;
}

.contact-form{
display:flex;
flex-direction:column;
gap:24px;
}

/* =====================================
   PORTFOLIO EMPTY STATE
===================================== */

.portfolio-empty {
    text-align: center;
    padding: 80px 20px;
    border: 1px solid var(--border-color);
    border-radius: 20px;
}

.portfolio-empty h3 {
    margin-bottom: 12px;
}

.portfolio-empty p {
    max-width: 500px;
    margin: 0 auto;
}

/* =====================================
   PORTFOLIO PAGINATION
===================================== */

.navigation.pagination {
    margin-top: 60px;
    width: 100%;
}

.navigation.pagination .nav-links {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 12px;
}

.navigation.pagination .page-numbers {
    display: inline-flex !important;

    width: auto !important;
    min-width: 48px;
    height: 48px;

    align-items: center;
    justify-content: center;

    padding: 0 18px;

    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.1);

    text-decoration: none;
    line-height: 1;
}

.navigation.pagination .current {
    font-weight: 600;
}

.navigation.pagination .prev,
.navigation.pagination .next {
    min-width: 90px;
}

.navigation.pagination {
    width: 100%;
    margin-top: 60px;
}

.navigation.pagination .nav-links {
    display: inline-flex !important;
    flex-direction: row !important;
    justify-content: center;
    align-items: center;
    gap: 12px;
}

.navigation.pagination .page-numbers {
    display: inline-flex !important;
    flex: 0 0 auto !important;
}