@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700;900&display=swap');

:root{
    --bg:#0a0a0a;
    --card:#111;
    --text:#fff;
    --muted:rgba(255,255,255,0.6);
    --cyan:#00f0ff;
    --pink:#ff2d95;
    --purple:#b300ff;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Space Grotesk', Arial, sans-serif;
}

body{
    background:var(--bg);
    color:var(--text);
    min-height:100vh;
    overflow-x:hidden;
}

/* Décorations de fond */

body::before,
body::after{
    content:'';
    position:fixed;
    border-radius:50%;
    filter:blur(120px);
    opacity:0.15;
    pointer-events:none;
    z-index:0;
}

body::before{
    width:600px;
    height:600px;
    background:var(--pink);
    top:-200px;
    right:-200px;
    animation:float 20s ease-in-out infinite;
}

body::after{
    width:500px;
    height:500px;
    background:var(--cyan);
    bottom:-150px;
    left:-150px;
    animation:float 25s ease-in-out infinite reverse;
}

@keyframes float{
    0%,100%{transform:translate(0,0)}
    33%{transform:translate(30px,-30px)}
    66%{transform:translate(-20px,20px)}
}

/* Menu */

nav{
    display:flex;
    justify-content:center;
    gap:30px;
    padding:40px;
    position:relative;
    z-index:1;
}

.btn{
    text-decoration:none;
    color:var(--text);
    border:1px solid rgba(255,255,255,0.15);
    border-radius:50px;
    padding:12px 50px;
    font-size:18px;
    font-weight:500;
    letter-spacing:1px;
    transition:all 0.3s ease;
    position:relative;
    overflow:hidden;
    z-index:1;
}

.btn::before{
    content:'';
    position:absolute;
    top:0;
    left:-100%;
    width:100%;
    height:100%;
    background:linear-gradient(90deg, var(--cyan), var(--pink));
    transition:left 0.4s ease;
    z-index:-1;
}

.btn:hover::before{
    left:0;
}

.btn:hover{
    color:var(--bg);
    border-color:transparent;
    transform:translateY(-2px);
    box-shadow:0 0 30px rgba(0,240,255,0.3);
}

/* Hero */

.hero{
    display:flex;
    justify-content:space-between;
    align-items:center;
    min-height:calc(100vh - 140px);
    padding:0 80px;
    position:relative;
    z-index:1;
    animation:fadeIn 1.2s ease;
    gap:60px;
}

.hero-left{
    flex:1;
    min-width:0;
}

.text h1{
    font-size:160px;
    line-height:0.85;
    font-weight:900;
    letter-spacing:-6px;
    background:linear-gradient(135deg, var(--cyan), var(--pink), var(--purple));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}

.text h1 span{
    display:inline-block;
    animation:slideUp 0.8s ease forwards;
    opacity:0;
}

.text h1 span:nth-child(1){animation-delay:0.1s}
.text h1 span:nth-child(2){animation-delay:0.3s}

.hero-sub{
    margin-top:20px;
    font-size:15px;
    color:var(--muted);
    font-weight:500;
    word-break:break-word;
    animation:fadeIn 1s ease 0.5s both;
}

.hero-desc{
    margin-top:16px;
    font-size:15px;
    line-height:1.5;
    color:var(--muted);
    word-break:break-word;
    animation:fadeIn 1s ease 0.7s both;
}

.hero-links{
    margin-top:35px;
    display:flex;
    gap:15px;
    animation:fadeIn 1s ease 0.9s both;
}

.btn-small{
    text-decoration:none;
    color:var(--text);
    border:1px solid rgba(255,255,255,0.15);
    border-radius:50px;
    padding:12px 30px;
    font-size:14px;
    font-weight:500;
    letter-spacing:0.5px;
    transition:all 0.3s ease;
    position:relative;
    overflow:hidden;
    z-index:1;
}

.btn-small::before{
    content:'';
    position:absolute;
    top:0;
    left:-100%;
    width:100%;
    height:100%;
    background:linear-gradient(90deg, var(--cyan), var(--pink));
    transition:left 0.4s ease;
    z-index:-1;
}

.btn-small:hover::before{
    left:0;
}

.btn-small:hover{
    color:var(--bg);
    border-color:transparent;
    transform:translateY(-2px);
    box-shadow:0 0 20px rgba(0,240,255,0.25);
}

.photo{
    position:relative;
    flex-shrink:0;
}

.photo .glow{
    position:absolute;
    inset:-5px;
    border-radius:24px;
    background:linear-gradient(135deg, var(--cyan), var(--pink));
    opacity:0.5;
    filter:blur(10px);
    transition:opacity 0.4s, filter 0.4s;
    z-index:-1;
}

.photo:hover .glow{
    opacity:1;
    filter:blur(15px);
}

.photo img{
    width:480px;
    border-radius:20px;
    display:block;
    position:relative;
    transition:transform 0.5s ease;
    border:1px solid rgba(255,255,255,0.1);
}

.photo:hover img{
    transform:scale(1.02);
}

/* Section featured home */

.home-featured{
    max-width:1000px;
    margin:0 auto;
    padding:60px 30px 100px;
    position:relative;
    z-index:1;
    animation:fadeIn 1s ease 1.1s both;
}

.home-featured h2{
    font-size:13px;
    letter-spacing:4px;
    text-transform:uppercase;
    color:var(--muted);
    font-weight:500;
    margin-bottom:30px;
}

.mini-grid{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    gap:20px;
}

.mini-card{
    background:var(--card);
    border:1px solid rgba(255,255,255,0.06);
    border-radius:14px;
    overflow:hidden;
    transition:all 0.3s ease;
}

.mini-card:hover{
    transform:translateY(-5px);
    border-color:rgba(0,240,255,0.3);
    box-shadow:0 0 30px rgba(0,240,255,0.08);
}

.mini-img{
    height:160px;
    overflow:hidden;
}

.mini-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform 0.5s ease;
}

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

.mini-placeholder{
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,0.03);
    font-size:30px;
    color:var(--muted);
}

.mini-info{
    padding:15px 18px;
}

.mini-info .cat{
    font-size:10px;
    letter-spacing:2px;
    text-transform:uppercase;
    color:var(--cyan);
    font-weight:500;
}

.mini-info h3{
    font-size:16px;
    margin-top:4px;
    font-weight:600;
}

/* Pages internes */

.page{
    max-width:1000px;
    margin:0 auto;
    padding:60px 30px 40px;
    position:relative;
    z-index:1;
    animation:fadeIn 0.8s ease;
}

.page h1{
    font-size:64px;
    font-weight:900;
    margin-bottom:20px;
    letter-spacing:-2px;
    background:linear-gradient(135deg, var(--cyan), var(--pink));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    display:inline-block;
}

.page > p{
    font-size:18px;
    line-height:1.7;
    color:var(--muted);
    margin-bottom:16px;
    max-width:700px;
}

.bio-text{
    font-size:16px;
    line-height:1.5;
    color:var(--muted);
    max-width:100%;
    word-break:break-word;
    background:var(--card);
    border:1px solid rgba(255,255,255,0.06);
    border-radius:16px;
    padding:30px;
    margin-bottom:40px;
    font-family:monospace;
}

/* About - sections */

.about-sections{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:30px;
    margin-top:50px;
}

.about-card{
    background:var(--card);
    border:1px solid rgba(255,255,255,0.06);
    border-radius:16px;
    padding:30px;
    transition:all 0.3s ease;
}

.about-card:hover{
    border-color:rgba(0,240,255,0.3);
    transform:translateY(-4px);
    box-shadow:0 0 40px rgba(0,240,255,0.08);
}

.about-card h3{
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:3px;
    color:var(--cyan);
    margin-bottom:15px;
    font-weight:500;
}

.about-card p{
    font-size:16px;
    color:var(--muted);
    line-height:1.6;
}

.about-card .tags{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-top:12px;
}

.about-card .tag{
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:50px;
    padding:6px 16px;
    font-size:13px;
    color:var(--muted);
    transition:0.3s;
}

.about-card .tag:hover{
    border-color:var(--pink);
    color:var(--pink);
}

/* Projets */

.projets{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:30px;
    margin-top:40px;
}

.projet{
    background:var(--card);
    border:1px solid rgba(255,255,255,0.06);
    border-radius:16px;
    overflow:hidden;
    transition:all 0.4s ease;
    position:relative;
}

.projet::after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:16px;
    opacity:0;
    transition:0.4s;
    pointer-events:none;
}

.projet:hover{
    transform:translateY(-8px);
    box-shadow:0 0 50px rgba(255,45,149,0.15);
}

.projet:hover::after{
    opacity:1;
}

.projet img,
.projet-img-placeholder{
    width:100%;
    height:260px;
    object-fit:cover;
    display:block;
    transition:transform 0.6s ease;
}

.projet-img-placeholder{
    display:flex;
    align-items:center;
    justify-content:center;
}

.projet-img-placeholder span{
    font-size:40px;
    font-weight:900;
    color:rgba(255,255,255,0.3);
}

.projet:hover img{
    transform:scale(1.05);
}

.projet-info{
    padding:20px 24px 24px;
    position:relative;
    z-index:1;
}

.projet-info .cat{
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:2px;
    color:var(--cyan);
    margin-bottom:6px;
    font-weight:500;
}

.projet-info h2{
    font-size:20px;
    margin-bottom:6px;
    font-weight:700;
}

.projet-info p{
    font-size:14px;
    color:var(--muted);
    margin:0;
}

/* Contact */

.contact-info{
    margin-top:60px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:30px;
}

.contact-card{
    background:var(--card);
    border:1px solid rgba(255,255,255,0.06);
    border-radius:16px;
    padding:40px;
    text-align:center;
    transition:all 0.3s ease;
}

.contact-card:hover{
    border-color:rgba(0,240,255,0.2);
    transform:translateY(-4px);
    box-shadow:0 0 40px rgba(0,240,255,0.06);
}

.contact-label{
    font-size:11px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--muted);
    font-weight:500;
    margin-bottom:20px;
}

.contact-card .email-large{
    font-size:28px;
    font-weight:700;
    background:linear-gradient(135deg, var(--cyan), var(--pink));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:30px;
    word-break:break-all;
}

.contact-card a.btn-contact{
    color:var(--text);
    text-decoration:none;
    border:1px solid rgba(255,255,255,0.15);
    border-radius:50px;
    padding:14px 50px;
    display:inline-block;
    font-size:15px;
    font-weight:500;
    letter-spacing:1px;
    transition:all 0.3s ease;
    position:relative;
    overflow:hidden;
    z-index:1;
}

.contact-card a.btn-contact::before{
    content:'';
    position:absolute;
    top:0;
    left:-100%;
    width:100%;
    height:100%;
    background:linear-gradient(90deg, var(--cyan), var(--pink));
    transition:left 0.4s ease;
    z-index:-1;
}

.contact-card a.btn-contact:hover::before{
    left:0;
}

.contact-card a.btn-contact:hover{
    color:var(--bg);
    border-color:transparent;
    transform:translateY(-2px);
    box-shadow:0 0 30px rgba(0,240,255,0.25);
}

.contact-links{
    display:flex;
    justify-content:center;
    gap:20px;
    margin-bottom:15px;
    flex-wrap:wrap;
}

.contact-links a{
    color:var(--text);
    text-decoration:none;
    font-size:18px;
    font-weight:500;
    transition:0.3s;
    position:relative;
}

.contact-links a::after{
    content:'';
    position:absolute;
    bottom:-2px;
    left:0;
    width:0;
    height:1px;
    background:var(--cyan);
    transition:width 0.3s;
}

.contact-links a:hover::after{
    width:100%;
}

.contact-links a:hover{
    color:var(--cyan);
}

.contact-note{
    font-size:13px;
    color:rgba(255,255,255,0.2);
}

/* Footer */

footer{
    text-align:center;
    padding:60px 20px 40px;
    position:relative;
    z-index:1;
}

footer p{
    font-size:13px;
    color:rgba(255,255,255,0.15);
    letter-spacing:1px;
}

/* Animations globales */

@keyframes fadeIn{
    from{opacity:0}
    to{opacity:1}
}

@keyframes slideUp{
    from{
        opacity:0;
        transform:translateY(40px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

/* Ligne decorative */

.divider{
    height:1px;
    background:linear-gradient(90deg, transparent, var(--cyan), var(--pink), transparent);
    margin:40px 0;
    opacity:0.3;
}

/* Responsive */

@media(max-width:900px){
    .hero{
        flex-direction:column;
        text-align:center;
        gap:50px;
        padding:0 30px;
        min-height:auto;
    }
    .text h1{
        font-size:90px;
        letter-spacing:-3px;
    }
    .photo img{
        width:350px;
    }
    .projets,
    .about-sections{
        grid-template-columns:1fr;
    }
    nav{
        gap:15px;
        padding:30px 15px;
        flex-wrap:wrap;
    }
    .btn{
        padding:10px 28px;
        font-size:15px;
    }
    .page h1{
        font-size:42px;
    }
    .contact-info{
        grid-template-columns:1fr;
    }
    .contact-card .email-large{
        font-size:22px;
    }
    .mini-grid{
        grid-template-columns:1fr 1fr;
    }
    .hero-links{
        flex-direction:column;
        align-items:flex-start;
    }
}

@media(max-width:500px){
    .text h1{
        font-size:52px;
        letter-spacing:-2px;
    }
    .hero{
        padding:0 20px;
        gap:30px;
    }
    .hero-sub{
        font-size:13px;
        letter-spacing:2px;
    }
    .hero-desc{
        font-size:16px;
    }
    .photo img{
        width:250px;
    }
    .btn{
        padding:8px 18px;
        font-size:13px;
    }
    nav{
        gap:10px;
        padding:20px 10px;
    }
    .page{
        padding:30px 15px;
    }
    .page h1{
        font-size:32px;
    }
    .mini-grid{
        grid-template-columns:1fr;
    }
    .home-featured{
        padding:40px 20px 60px;
    }
    .contact-card{
        padding:25px;
    }
    .contact-card .email-large{
        font-size:18px;
    }
    .contact-links{
        gap:12px;
    }
    .contact-links a{
        font-size:15px;
    }
    .projets{
        gap:20px;
    }
    .btn-small{
        padding:10px 22px;
        font-size:13px;
    }
}
