body{font-family:'Noto Sans',sans-serif;background:#010101;color:#F5F5F5;scroll-behavior:smooth;user-select:none}
#particles-canvas{z-index: -1 !important}
canvas{position:fixed;top:0;left:0;width:100%;height:100%;background:transparent;pointer-events: none;}
.navbar{display:grid;width:100%;position:fixed;top:10px;margin:0;justify-content:center;z-index:9999}
.container{display:grid;padding:15px 20px;margin:0;max-width:none;justify-self:center;background:rgba(255,255,255,.08);backdrop-filter:blur(10px);border-radius:10px;transition:background .3s ease-in-out;box-sizing:border-box}
.container:hover{background:rgba(255,255,255,.2)}
.navbar-nav{display:flex;flex-flow:row wrap;gap:10px;align-items:center;justify-content:left;padding:0}
.navbar-nav a{display:grid;justify-items:center;color:#fff;padding:10px;font-size:1rem;font-weight:600;text-decoration:none;white-space:nowrap;box-sizing:border-box;transition:transform .2s ease,opacity .3s ease}
.navbar-nav a:hover{opacity:.7;transform:scale(1.05)}
.cover-section{position:relative;background:url('https://i.pinimg.com/1200x/8a/9b/49/8a9b49112a5561a38d3d1a2efaae91a2.jpg') center/cover no-repeat;height:100vh;display:flex;justify-content:center;align-items:center;color:#fff;}
.fade-in{opacity:0;transform:translateY(20px);animation:fadeIn 1s ease-in-out forwards}
@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}
.cover-overlay{padding-inline:10px}
.cover-overlay h1{width:80vw;font-family:'Antonio',sans-serif;font-size:4rem;font-weight:300;text-transform:uppercase;letter-spacing:3px;color:#fff;margin-bottom:10px}
.section{display:grid;padding:120px 40px;text-align:center;border-bottom: 1px solid; border-image-source: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.2), transparent); border-image-slice: 1;box-sizing:border-box}
.section p{justify-self:center;max-width:900px}
.col{margin:0;padding:10px}
.col-md-4{max-width:300px!important;padding:10px!important}
.card{background:transparent;height:100%;display:block}
.cards-grid{display:grid;margin-top: 20px;grid-template-columns:repeat(auto-fit,minmax(20rem,300px));gap:1rem;justify-content:center}
.card-img-top,.card video{width:100%;height:250px;object-fit:cover;border-radius:5px;display:block}
.card .img-container,.img-container{overflow:hidden;border-radius:5px;position:relative;max-width:350px;width:100%;display:inline-block;cursor:pointer}
.img-container::after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,#01010195,transparent);pointer-events:none;border-radius:0 0 5px 5px}
.visit-icon{position:absolute;bottom:10px;right:10px;width:40px;height:40px;background:rgba(0,0,0,.6);color:#fff;border-radius:40px;padding:10px;font-size:15px;transition:background-color .3s ease;text-decoration:none}
.visit-icon:hover{background-color:rgba(0,0,0,.8)}
.like-button{position:absolute;bottom:10px;right:10px;display:flex;align-items:center;z-index:1}
.heart{border-radius:40px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;transition:background-color .3s ease,transform .2s ease;position:relative;color:#fff}
.heart.liked{animation:pop .5s ease}
@keyframes pop{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.heart:hover{transform:scale(1.1)}
.heart i{font-size:20px}
.like-count{font-size:16px;color:whitesmoke}
.video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:5px}
.video-wrapper video,.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.skills-container{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;padding-inline:100px;margin-top:20px}
.skill-box{background:rgba(255,255,255,.1);padding:10px 20px;border-radius:8px;font-size:15px;transition:transform .3s ease-in-out;box-sizing:border-box;cursor:pointer}
.skill-box:hover{transform:scale(1.05)}
.btn-contact{background:#fff;color:#000!important;padding:8px 15px;border-radius:5px;transition:.3s;box-sizing:border-box}
.btn-contact:hover{background:#000;color:#fff!important;transform:scale(1.1)}
.btn-bmc:hover {background-color: #ffbe00 !important;transform: translateY(-2px);transition: all 0.3s ease;}
.about-section{max-width:780px;margin:2.5rem auto 1.5rem}
.about-card{padding:1rem 2rem;background:rgba(255,255,255,.035);border-left:3px solid #1E90FF;border-radius:6px;color:#f5f5f5;margin:auto 2rem}
.about-section h1{font-size:1.5rem;font-weight:600;margin-bottom:.8rem;color:#f5f5f5}
.about-section p{font-size:.95rem;line-height:1.5;color:#ccc}
.experience-section{padding:3rem 1rem;max-width:1100px;margin:auto}
.experience-section h2{font-size:2rem;font-weight:600;text-align:center;color:#f5f5f5;margin-bottom:2rem}
.experience-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(20rem,300px));gap:1.5rem;justify-content:center}
.exp-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:10px;min-width:250px;padding:1.2rem 1rem;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 2px 6px rgba(0,0,0,.4);transition:transform .2s ease;cursor:pointer}
.exp-card:hover{transform:translateY(-4px)}
.exp-card:hover .exp-date{background:#1E90F520;padding:.2rem .5rem;border-radius:.3rem;animation:none}
.exp-header{display:flex;flex-direction:column;margin-bottom:.8rem;align-items:start}
.exp-date{font-size:.85rem;color:#1E90FF;font-weight:500;margin-bottom:.3rem;transition:all 1s ease;animation:pulsein 1s infinite}
@keyframes pulsein{0%,100%{filter:drop-shadow(1px 1px 5px #010101)}50%{filter:drop-shadow(1px 1px 5px #1E90F5)}}
.exp-title{font-size:1.05rem;font-weight:600;margin-bottom:.2rem}
.exp-company{font-size:.9rem;color:#ccc}
.exp-tags{font-size:.85rem;color:#1E90FF;background:rgba(30,144,255,.07);border-radius:4px;padding:.3rem .5rem;display:inline-block;margin-bottom:1rem}
.exp-button{align-self:flex-start;font-size:.8rem;font-weight:500;padding:.4rem .8rem;color:#1E90FF;border:1px solid #1E90FF;border-radius:5px;text-decoration:none;background:transparent;transition:all .25s ease}
.exp-button:hover{background:#1E90FF;color:#0f0f0f}
.experience-cards::-webkit-scrollbar{display:none}
.experience-cards{-ms-overflow-style:none;scrollbar-width:none}
#portfolio h2{font-size:3rem;margin-bottom:20px}
#graphic-projects .row{margin-top:30px}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(20rem,300px));gap:20px;justify-content:center;margin-top:20px}
.card-body{color:whitesmoke;padding:10px}
.card-text{font-size:14px}
.social-icons{display:flex;justify-content:center;gap:25px;margin-block:10px}
.social-icons a{font-size:35px;color:#fff;transition:all 1s ease;animation:pulse 1s infinite;margin-right:10px}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.social-icons a:hover{transform:scale(1.1);color:#1E90FF;opacity:.8;animation:none}
.visitor-counter{display:flex;align-items:center;font-size:16px;position:fixed;bottom:20px;left:20px;backdrop-filter:blur(10px);background:rgba(0,0,0,.6);color:#fff;padding:10px 20px;border-radius:10px;transition:all .3s ease;z-index:10000}
.visitor-counter i{margin-inline:5px;font-size:20px;animation:pulse 1s infinite}
.visitor-counter:hover{transform:scale(1.1);background:rgba(0,0,0,.8)}
.btn-paypal{display:inline-flex;justify-content:center;align-items:center;max-width:300px;background:#003087;color:#fff!important;font-weight:600;font-size:1rem;padding:12px 25px;border-radius:8px;border:none;cursor:pointer;user-select:none;text-decoration:none;transition:background .3s ease,transform .2s ease}
.btn-paypal:hover{background:#0065c8;transform:scale(1.05)}
.btn-paypal:active{transform:scale(.98)}
.btn-paypal .paypal-icon{margin-right:12px;width:20px;height:20px;fill:#fff}
.modern-footer{color:#fff;padding:3rem 1rem;font-family:'Segoe UI',sans-serif}
.footer-grid{display:grid;grid-template-columns:repeat(4,auto);gap:1rem;max-width:1200px;margin:auto;padding-inline:20px;padding-bottom:2rem;border-bottom: 1px solid; border-image-source: linear-gradient(to right, transparent, #333, transparent); border-image-slice: 1;justify-content:space-around}
.footer-col h3,.footer-col h4{margin-bottom:.5rem;color:#fff}
.footer-col p,.footer-col a{color:#ddd;text-decoration:none;line-height:1.6;font-size:.95rem}
.footer-col a:hover,.footer-col .social-icons a:hover{color:#0d6efd}
.footer-bottom{text-align:center;margin-top:2rem;
font-size:.9rem;color:#999}
.footer-col .social-icons{display:flex;justify-content:flex-start;gap:20px;margin:0;padding-top:.5rem}
.footer-col .social-icons a{font-size:1.4rem;color:#ddd;margin-right:0}
/* Toast Notification Styles */
.toast-container { z-index: 1050; }
.toast { background-color: #343a40; color: #fff; border: none; }
.toast-header { background-color: #495057; color: #fff; border-bottom: 1px solid; border-image-source: linear-gradient(to right, transparent, #6c757d, transparent); border-image-slice: 1; }
.toast-header strong { color: #fff; }
.toast-body { background-color: #343a40; color: #fff; }
/* Bot Bubble */
#bot-bubble {position: fixed;background: rgba(0, 0, 0, 0.8);color: #fff;padding: 8px 18px;border-radius: 18px;border: 1px solid #1E90FF;font-size: 14px;width: 230px;min-height: 45px;opacity: 0;visibility: hidden;transform: scale(0.9) translate(var(--translate-x, 0), var(--translate-y, 0));z-index: 1000;pointer-events: none;display: flex;flex-direction: column;justify-content: center;align-items: center;}
.bubble-text-wrapper {width: 100%;line-height: 1.2em;}
#bot-bubble .bubble-text {white-space: wrap;display: block;text-align: center;margin: 0 auto;}
/* Bulle pop animation */
@keyframes pop-up {
    0% {
        opacity: 0;
        transform: translate(var(--translate-x, 0), var(--translate-y, 0)) scale(0.8);
    }
    80% {
        opacity: 1;
        transform: translate(var(--translate-x, 0), var(--translate-y, 0)) scale(1.05);
    }
    100% {
        opacity: 1;
        transform: translate(var(--translate-x, 0), var(--translate-y, 0)) scale(1);
    }
}
/* Bulle pop-off animation */
@keyframes pop-off {
    0% {
        opacity: 1;
        transform: translate(var(--translate-x, 0), var(--translate-y, 0)) scale(1);
    }
    100% {
        opacity: 0;
        transform: translate(var(--translate-x, 0), var(--translate-y, 0)) scale(0.8);
    }
}
/* Position des bulles */
#bot-bubble.bubble-left {
    --translate-x: calc(-100% - 25%);
    --translate-y: -10%;
}
#bot-bubble.bubble-right {
    --translate-x: 25%;
    --translate-y: -10%;
}
/* Apparition de la bulle */
#bot-bubble.visible {animation: pop-up 0.4s ease-out forwards;visibility: visible;}

/* Disparition de la bulle */
#bot-bubble.disappear {
    animation: pop-off 0.2s ease-out forwards;
}

/* Flèche de la bulle */
#bot-bubble::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    border-width: 8px;
    border-style: solid;
    transition: border-color 0.3s ease;
}

#bot-bubble.bubble-left::after {
    left: 100%;
    border-color: transparent transparent transparent #1E90FF;
}

#bot-bubble.bubble-right::after {
    right: 100%;
    border-color: transparent #1E90FF transparent transparent;
}

/* Trois points animés */
.bubble-dots {
    text-align: center;
    height: 10px;
    margin: 4px;
}

.bubble-dots span {
    display: inline-block;
    width: 4px;
    height: 4px;
    margin: 0 1px;
    background: #fff;
    border-radius: 50%;
    opacity: 0;
    animation: dots 1s infinite;
}

.bubble-dots span:nth-child(1) { animation-delay: 0s; }
.bubble-dots span:nth-child(2) { animation-delay: 0.2s; }
.bubble-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dots {
    0%, 20% { opacity: 0; transform: translateY(0); }
    50% { opacity: 1; transform: translateY(-2px); }
    100% { opacity: 0; transform: translateY(0); }
}

@media screen and (min-width:2500px){body{justify-items:center}.main{width:1500px;margin:auto}}
@media screen and (max-width:1000px){.navbar-nav a{font-size:14px;padding:10px}}
@media screen and (max-width:900px){.navbar{padding:10px 15px}.navbar-nav a{font-size:12px;padding:6px 8px}.btn-contact{font-size:13px}.cover-overlay h1{font-size:2.2rem}.cover-overlay p{font-size:1rem}.section{padding:80px 20px}.skills-container{padding-inline:20px;gap:10px}.card-img-top{height:200px}.social-icons{gap:15px}.social-icons a{font-size:26px}.footer-col .social-icons{justify-content:left;gap:30px}}
@media screen and (max-width:700px){.navbar-nav a{font-size:11px;padding:5px 6px}.cover-overlay h1{font-size:1.8rem}.cover-overlay p{font-size:.95rem}.card-img-top{height:180px}}
@media screen and (min-width:300px) and (max-width:800px){.footer-grid{grid-template-columns:auto;text-align:center;justify-content:center}.footer-col .social-icons{justify-content:center}}
@media screen and (min-width:520px) and (max-width:650px){.navbar-nav a{font-size:10px;padding:5px 10px}.cover-overlay h1{font-size:1.5rem}.cover-overlay p{font-size:.9rem}.navbar-nav .nav-link{display:none}.navbar-nav .nav-link.show-on-duo{display:inline-block}}
@media screen and (min-width:300px) and (max-width:520px){.navbar-nav .nav-link{display:none}.navbar-nav .nav-link.show-on-mobile{display:inline-block}}

@media screen and (max-width: 768px) {
    #bot-bubble.bubble-left,
    #bot-bubble.bubble-right {
        --translate-x: -50%;
        --translate-y: -110%;
    }

    #bot-bubble.bubble-left::after,
    #bot-bubble.bubble-right::after {
        left: 50%;
        top: 100%; /* 2 * border-width */
        transform: translateX(-50%);
        border-width: 8px;
        border-style: solid;
        border-color: #1E90FF transparent transparent transparent;
    }
}
/* Modal styles */
.modal {
    display: none; /* Masqué par défaut */
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.9);
    justify-content: center;
    align-items: center;
}

.modal.is-active {
    display: flex; /* Affiché lorsque la classe is-active est présente */
}

.modal-content-wrapper {
    position: relative; /* Important pour positionner le bouton close */
    display: flex;
    justify-content: center;
    align-items: center;
    width: 80%;
    max-width: 600px; /* limite la taille pour les grands écrans */
    max-height: 80%;
    background-color: #111; /* couleur de fond pour la "carte" */
    border-radius: 8px;
    overflow: hidden;
}

.modal-content {
    display: block;
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
}

/* Bouton Close */
.close {
    position: absolute; /* pour le placer par-dessus l'image */
    top: 5px;
    right: 5px;
    color: #f1f1f1;
    font-size: 20px;
    font-weight: bold;
    transition: 0.3s;
    background: rgba(0, 0, 0, 0.5);
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    z-index: 1000;
}

.close:hover {
    background: rgba(255, 255, 255, 0.2);
}

.close:hover,
.close:focus {
  color: #bbb;
  text-decoration: none;
  cursor: pointer;
}

:root{
  --bg:#0f1115;
  --card:#0b1220;
  --muted:#9aa3b2;
  --accent:#0b6efd;
  --surface:#0b1220;
  --text:#e6eef6;
  --radius:12px;
}

/* Container */
.contact-section, .faq-section { padding: 48px 20px; max-width:1000px; margin:0 auto; color:var(--text); justify-items: center;}

/* Card layout */
.contact-card { display:flex; gap:30px; background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent); border-radius:var(--radius); padding:24px; align-items:flex-start;max-width: 780px;}

/* Left info */
.contact-left { flex:1; min-width:240px; }
.contact-title { margin:0 0 8px; font-size:1.6rem; color:var(--text); }
.contact-sub { margin:0 0 18px; color:var(--muted); line-height:1.4; }
.contact-info { list-style:none; padding:0; margin:0; color:var(--muted); }
.contact-info li { margin:8px 0; font-size:0.95rem; }

/* Form */
.contact-form { flex:1.1; display:flex; flex-direction:column; gap:12px;width: -webkit-fill-available;}
.field-row label { display:block; font-size:0.85rem; color:var(--muted); margin-bottom:6px; }
.field-row input, .field-row textarea {
  width:100%; background:transparent; border:1px solid rgba(255,255,255,0.06); color:var(--text); padding:10px 12px; border-radius:8px; outline:none;
  transition:box-shadow .12s, border-color .12s;
}
.field-row input:focus, .field-row textarea:focus { border-color:var(--accent); box-shadow:0 4px 16px rgba(11,110,253,0.08); }

.actions { display:flex; gap:12px; align-items:center; margin-top:6px;}
.btn-primary {
  background: linear-gradient(90deg, var(--accent), #0a5ee6);
  color: white;
  border: none;
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  transition: background 0.3s ease, transform 0.1s ease;
}

.btn-primary:hover {
  background: linear-gradient(90deg, #0a5ee6, var(--accent));
}

.btn-primary:active {
  transform: scale(0.98);
}
.contact-status { color:var(--muted); font-size:0.95rem; }

/* FAQ */
.faq-section{justify-items: center;}
.faq-section h2 { margin-bottom:16px; font-size:1.4rem; max-width: 720px;}
.faq-list { display:grid; gap:10px; max-width: 720px; margin:0 auto;}
.faq-item { background:transparent; border-radius:10px; overflow:hidden; }
.faq-q {
  width:100%; text-align:left; padding:12px 14px; background:rgba(255,255,255,0.02); border:1px solid rgba(255,255,255,0.04); color:var(--text);
  cursor:pointer; font-weight:600; border-radius:10px;
}
.faq-q[aria-expanded="true"] { background:linear-gradient(90deg, rgba(11,110,253,0.08), rgba(11,110,253,0.02)); }
.faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out, padding 0.3s ease-out;
    padding: 0 14px;
    border-left: 1px solid rgba(255, 255, 255, 0.03);
    color: var(--muted);
    background: rgba(0, 0, 0, 0.02);
}

.faq-q[aria-expanded="true"] + .faq-a {
    max-height: 500px; /* Ajustez cette valeur si le contenu est plus grand */
    padding: 12px 14px;
    transition: max-height 0.5s ease-in, padding 0.5s ease-in;
}

/* Responsive */
@media (max-width:700px){
  .contact-card { flex-direction:column; }
}

@media (max-width: 480px) {
  .contact-card {
    padding: 16px;
  }
  .contact-title {
    font-size: 1.4rem;
  }
  .contact-sub {
    font-size: 0.9rem;
  }
  .field-row input, .field-row textarea {
    padding: 8px 10px;
  }
  .btn-primary {
    padding: 8px 14px;
    font-size: 0.9rem;
  }
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {-webkit-box-shadow: 0 0 0 1000px transparent inset !important;box-shadow: 0 0 0 1000px transparent inset !important; -webkit-text-fill-color: white !important; transition: background-color 5000s ease-in-out 0s;}