@import url('https://fonts.googleapis.com/css2?family=MuseoModerno:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');
:root{
    --black:#353535;
    --yellow:#beef35;
    --yellow-dim: #85b107;
    --gray: rgba(87, 87, 87, 0.34);
    --light-gray:#2a2a2a;
    --text-secondary:#ffffff;
    --spacing-xs:.5rem;
    --spacing-sm:1rem;
    --spacing-md:2rem;
    --spacing-lg:4rem;
    --spacing-xl:6rem;
}
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Reset + base */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    font:400 1rem/1.6 "Darker Grotesque",sans-serif;
    background:var(--black);
    color:#fff;
    overflow-x:hidden;
}

/* Accessibility */
.skip-link{
    position:absolute;top:-40px;left:0;z-index:100;
    padding:8px;
    background:var(--yellow);
    color:var(--black);
    text-decoration:none;
    font-weight:400;
}
.skip-link:focus{top:0}
*:focus-visible{outline:2px solid var(--yellow);outline-offset:2px}

/* Header + nav */
header{
    position:fixed;inset:0 0 auto;
    z-index:50;
    background: rgb(50 50 50 / 75%);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(255,237,0,.1);
}
nav{
    max-width:1400px;
    margin:0 auto;
    padding:1.2rem 2rem;
    display:flex;
    justify-content:space-between;
    align-items:center;
}
.logo{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    text-decoration: none;
    font-family: "MuseoModerno", sans-serif;
    font-weight: 400;
    background: linear-gradient(135deg, #fff 0, var(--yellow) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 2rem;
    text-indent: 15px;
}

.logo-text{
    white-space: nowrap;
    line-height: 1;
}

.logo img{
    display: block;
    height: 60px;
    width: auto;
    background: linear-gradient(135deg, #fff 0, var(--yellow) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.nav-links{
    display:flex;gap:2.5rem;
    list-style:none;
}
.nav-links a{
    position:relative;
    color:#fff;
    text-decoration:none;
    font-size:1.1rem;
    transition:color .3s ease;
}
.nav-links a::after{
    content:"";
    position:absolute;left:0;bottom:-5px;
    width:0;height:2px;
    background:var(--yellow);
    transition:width .3s ease;
}
.nav-links a:hover,
.nav-links a:focus{color:var(--yellow);outline:0}
.nav-links a:hover::after,
.nav-links a:focus::after{width:100%}

/* Mobile menu button */
.menu-toggle{
    display:none;
    background:none;
    border:2px solid var(--yellow);
    color:var(--yellow);
    padding:.5rem 1rem;
    font:400 1rem/1 "JetBrains Mono",monospace;
    cursor:pointer;
    transition:all .3s ease;
}
.menu-toggle:hover,
.menu-toggle:focus{
    background:var(--yellow);
    color:var(--black);
    outline:2px solid var(--yellow);
    outline-offset:2px;
}

/* Hero */
#home{
    min-height:100vh;
    display:flex;
    align-items:center;
    padding:8rem 2rem 4rem;
    position:relative;
    overflow:hidden;
}
#home::before{
    content:"";
    position: absolute;
    top: -70%;
    width: 100%;
    height: 180%;
    background: radial-gradient(circle, rgb(255 250 0 / 25%) 0, #00000000 70%);
}

.hero-container{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:4rem;
    align-items:center;
    position:relative;
    z-index:1;
}

.tagline{
    display:inline-block;
    margin-bottom:1.5rem;
    font:400 .9rem/1 "JetBrains Mono",monospace;
    color:var(--yellow);
    text-transform:uppercase;
    letter-spacing:2px;
}
h1{
    margin-bottom:1.5rem;
    font-size:clamp(2.5rem,6vw,5rem);
    font-weight:800;
    line-height:1.1;
    background:linear-gradient(135deg,#fff 0,var(--yellow) 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.hero-description{
    max-width:600px;
    margin-bottom:2.5rem;
    font-size:1.3rem;
    font-weight:300;
    color:var(--text-secondary);
}

.cta-buttons{display:flex;gap:1.5rem;flex-wrap:wrap}

/* Buttons */
.btn{
    display:inline-block;
    padding:1rem 2.5rem;
    font:600 1.1rem/1 "Darker Grotesque",sans-serif;
    text-decoration:none;
    border:0;
    cursor:pointer;
    position:relative;
    overflow:hidden;
    transition:all .3s ease;
}
.btn-primary{
    background:var(--yellow);
    color:var(--black);
    clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,0 100%);
}
.btn-primary:hover,
.btn-primary:focus{
    background:var(--yellow-dim);
    transform:translateY(-2px);
    box-shadow:0 10px 30px rgba(255,237,0,.3);
    outline:2px solid var(--yellow);
    outline-offset:2px;
}
.btn-secondary{
    background:transparent;
    color:var(--yellow);
    border:2px solid var(--yellow);
}
.btn-secondary:hover,
.btn-secondary:focus{
    background:var(--yellow);
    color:var(--black);
    outline:2px solid var(--yellow);
    outline-offset:2px;
}

/* Stats */
.hero-stats{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:2rem;
    padding:2rem;
    background:rgba(10,10,10,.25);
    backdrop-filter:blur(10px);
    border:1px solid var(--light-gray);
    border-left:4px solid var(--yellow);
    animation:fadeInUp .8s ease-out .4s both;
}
.stat{text-align:center}
.stat-number{
    display:block;
    font:800 2.5rem/1 "JetBrains Mono",monospace;
    color:var(--yellow);
}
.stat-label{
    font-size:.9rem;
    color:var(--text-secondary);
    text-transform:uppercase;
    letter-spacing:1px;
}

/* Sections */
.section-container{max-width:1400px;margin:0 auto}
.section-header{text-align:center;margin-bottom:var(--spacing-lg)}
.section-label{
    margin-bottom:1rem;
    font:400 .85rem/1 "JetBrains Mono",monospace;
    color:var(--yellow);
    text-transform:uppercase;
    letter-spacing:3px;
}
h2{
    margin-bottom:1rem;
    font-size:clamp(2rem,4vw,3.5rem);
    font-weight:800;
}
.section-description{
    max-width:900px;
    margin:0 auto;
    font-size:1.2rem;
    color:var(--text-secondary);
    font-weight: 400;
    letter-spacing: 1px;
}

/* About */
#about{
    padding:var(--spacing-xl) 2rem;
    position:relative;
    background: radial-gradient(circle, rgb(255 250 0 / 25%) 0, #00000038 70%);
}
#about::before{
    content:"";
    position:absolute;top:0;left:0;right:0;
    height:1px;
    background:linear-gradient(90deg,transparent,var(--yellow),transparent);
}
.lgla11y {
    padding: 8rem 2rem 4rem !important;
}

/* Services */
.services-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:2rem;
    margin-top:var(--spacing-lg);
}
.service-card{
    position:relative;
    padding:2.5rem;
    border:1px solid var(--light-gray);
    background: rgba(10, 10, 10, .45);
    box-shadow:0 4px 30px rgba(0,0,0,.1);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    transition:all .4s ease;
}
.service-card::before{
    content:"";
    position:absolute;top:0;left:0;
    width:0;height:4px;
    background:var(--yellow);
    transition:width .4s ease;
}
.service-card:hover,
.service-card:focus-within{transform:translateY(-5px);border-color:var(--yellow)}
.service-card:hover::before,
.service-card:focus-within::before{width:100%}

.service-card h3{margin-bottom:1rem;font-size:1.8rem;font-weight:700;color:var(--yellow)}
.service-card p{margin-bottom:1rem;font-weight:400;font-size:22px;line-height:150%;color:var(--text-secondary)}

.service-features{list-style:none;padding:0}
.service-features li{
    position:relative;
    padding:.5rem 0 .5rem 1.5rem;
    color:var(--text-secondary);
    font-size: 22px;
    font-weight: 400;
}
.service-features li::before{
    content:"▸";
    position:absolute;left:0;
    color:var(--yellow);
}

/* Contact */
#contact{position:relative;padding:var(--spacing-xl) 2rem;background:var(--black)}
#contact::before {
    content:"";
    position:absolute;top:0;left:0;right:0;
    height:1px;
    background:linear-gradient(90deg,transparent,var(--yellow),transparent);
}
.contact-container{max-width:1000px;margin:0 auto}
.contact-content{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:4rem;
    margin-top:var(--spacing-lg);
}
.contact-info{display:flex;flex-direction:column;gap:2rem}

.contact-item{
    background:var(--gray);
    padding:2rem;
    border-left:4px solid var(--yellow);
}
.contact-item h3{
    margin-bottom:.75rem;
    font:400 1rem/1 "JetBrains Mono",monospace;
    color:var(--yellow);
    text-transform:uppercase;
    letter-spacing:2px;
}
.contact-item a{
    display:inline-block;
    color:#fff;
    text-decoration:none;
    font-size:1.3rem;
    font-weight:400;
    transition:color .3s ease;
}
.contact-item a:hover,
.contact-item a:focus{color:var(--yellow);outline:2px solid var(--yellow);outline-offset:4px}
.contact-item p{font-size:1.2rem;line-height:1.6;color:var(--text-secondary)}

.contact-social-media a {
    color: var(--yellow);
    transition: all 0.3s ease;
}
.contact-social-media a:hover {
    opacity: 1;
    filter: brightness(1.4);
}
.contact-social-media a.ln:hover {
    color: #0a66c2;
}
.contact-social-media a.yt:hover {
    color: #ce0909;
}
.contact-social-media a.ig {
    display: inline-block;
    line-height: 1;
    overflow: visible;
    padding: 2px;
}
.contact-social-media a.ig:hover {
    background: linear-gradient(133deg,rgba(225, 82, 247, 1) 0%, rgba(89, 54, 194, 1) 50%, rgba(83, 96, 237, 1) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.contact-social-media i {
    font-size: 2rem;
}
.contact-social-media ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
/* Footer */
footer{
    background:var(--gray);
    border-top:1px solid var(--light-gray);
    padding:2rem;
    text-align:center;
}
footer p{color:var(--text-secondary);font-size:.95rem}
.footer-links{
    margin-top:1rem;
    display:flex;
    justify-content:center;
    gap:2rem;
}
.footer-links a{
    color:var(--yellow);
    text-decoration:none;
    font-size:.9rem;
    transition:opacity .3s ease;
}
.footer-links a:hover,
.footer-links a:focus{opacity:.7;outline:2px solid var(--yellow);outline-offset:4px}

/* Responsive */
@media (max-width:968px){
    .hero-container{grid-template-columns:1fr;gap:2rem}
    .contact-content{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:768px){
    nav{padding:1rem}
    .nav-links{
        position:fixed;
        top:80px;left:0;right:0;
        background:var(--light-gray);
        flex-direction:column;
        padding:2rem;
        gap:1.5rem;
        transform:translateX(-100%);
        transition:transform .3s ease;
        border-bottom:2px solid var(--yellow);
    }
    .nav-links.active{transform:translateX(0)}
    .menu-toggle{display:block}
    h1{font-size:2.5rem}
    .hero-stats{grid-template-columns:1fr;gap:1rem}
    .services-grid{grid-template-columns:1fr}
    .cta-buttons{flex-direction:column}
    .btn{width:100%;text-align:center}
    .logo{
        font-size: 1rem;
        text-indent: 10px;
    }
    .logo img {
        max-width: 40px;
    }
    #home::before{
        background: none;
    }
    .contact-social-media ul {
        display: flex;
        flex-direction: row;
        gap: 20px;
    }
    .service-card p,
    .service-card li {font-size:16px;}
}
@media (max-width:480px){
    :root{--spacing-xl:3rem;--spacing-lg:2rem}
    #home,#about,#contact{padding-left:1rem;padding-right:1rem}
    .service-card,.contact-form{padding:1.5rem}
}

/* Motion + contrast preferences */
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{
        animation-duration:.01ms !important;
        animation-iteration-count:1 !important;
        transition-duration:.01ms !important;
    }
}
@media (prefers-contrast:more){
    .service-card,.contact-form{border-width:2px}
}

/* Keyframes */
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes float{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(-50px,50px) rotate(5deg)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
