/*
Theme Name: Jerry Portfolio
Version: 1.5.0
*/
@import url('https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400&family=Montserrat:wght@300;400;500;600;700;800&display=swap');

/* ══════════════════════════════════════
   VARIABLES
══════════════════════════════════════ */
:root {
    --primary:     #0a192f;
    --secondary:   #172a45;
    --accent:      #d4af37;
    --accent-dark: #b8941e;
    --text:        #e6f1ff;
    --text-dark:   #0a192f;
    --bg-light:    #f8f9fa;
}

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

body {
    font-family: 'Crimson Text', serif;
    color: var(--text-dark);
    background: #fff;
    overflow-x: hidden;
    line-height: 1.7;
}
html { scroll-behavior: smooth; }
img { -webkit-user-drag:none; user-drag:none; }
video, audio { -webkit-user-drag:none; user-drag:none; }
p,h1,h2,h3,h4,h5,h6,span,a,li {
    -webkit-user-select:text; -moz-user-select:text; user-select:text;
}

/* ══════════════════════════════════════
   LAYOUT
══════════════════════════════════════ */
.section-container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 2rem;
}

/* Espacement UNIFORME pour toutes les sections */
section:not(.hero) {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
}

/* ══════════════════════════════════════
   TITRE DE SECTION  — harmonisé partout
══════════════════════════════════════ */
.section-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 2rem;
    font-weight: 800;
    color: var(--text-dark);
    display: inline-block;
    position: relative;
    margin-bottom: 2rem;
}
.section-title::after {
    content: '';
    position: absolute;
    bottom: -8px; left: 0;
    width: 50%; height: 4px;
    background: var(--accent);
    border-radius: 2px;
}

/* ══════════════════════════════════════
   NAVIGATION
══════════════════════════════════════ */
nav {
    position: fixed; top:0; width:100%;
    background: rgba(10,25,47,0.98);
    backdrop-filter: blur(10px);
    padding: 1.1rem 5%;
    z-index: 1000;
    border-bottom: 1px solid rgba(212,175,55,0.2);
    transition: all .3s;
}
nav.scrolled { padding:.75rem 5%; box-shadow:0 2px 30px rgba(0,0,0,.3); }
.nav-container {
    max-width:1400px; margin:0 auto;
    display:flex; justify-content:space-between; align-items:center;
}
.logo {
    font-family:'Montserrat',sans-serif;
    font-size:1.7rem; font-weight:800;
    color:var(--accent); text-transform:uppercase;
}
.nav-links { display:flex; gap:1.8rem; list-style:none; }
.nav-links a {
    color:var(--text); text-decoration:none;
    font-family:'Montserrat',sans-serif;
    font-weight:500; font-size:.85rem;
    letter-spacing:.4px; position:relative; transition:all .3s;
}
.nav-links a::after {
    content:''; position:absolute; bottom:-4px; left:0;
    width:0; height:2px; background:var(--accent); transition:width .3s;
}
.nav-links a:hover::after { width:100%; }
.mobile-menu-btn {
    display:none; background:none; border:none;
    color:var(--text); font-size:1.4rem; cursor:pointer;
}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero {
    min-height: 100vh;
    background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
    display: flex; align-items:center; justify-content:center;
    padding: 4rem 5% 3rem;
    position: relative; overflow:hidden;
}
.hero::before {
    content:''; position:absolute; inset:0;
    background:
        radial-gradient(circle at 20% 50%, rgba(212,175,55,.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(212,175,55,.1) 0%, transparent 50%);
    animation: pulse 15s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.5} }

.hero-content {
    max-width: 1200px; width:100%;
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items:center;
    position:relative; z-index:1;
}

/* ── NOM : Jerry Déodat même taille que GANDAHO, sur une seule ligne ── */
.hero-title {
    display: block;
    white-space: nowrap;            /* une seule ligne */
    margin-bottom: .6rem;
    line-height: 1.1;
    animation: fadeInUp .8s ease;
}
.hero-firstname {
    font-family: 'Montserrat', sans-serif;
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -0.5px;
}
.hero-lastname {
    font-family: 'Montserrat', sans-serif;
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--accent);
    letter-spacing: -0.5px;
    margin-left: .4rem;
}

/* ── Sous-titre ── */
.hero-role {
    font-family: 'Crimson Text', serif;
    font-size: 1.15rem;
    font-style: italic;
    color: rgba(230,241,255,.82);
    line-height: 1.5;
    margin-bottom: 2rem;
    animation: fadeInUp .8s ease .15s backwards;
}

.hero-buttons {
    display:flex; gap:1.2rem; flex-wrap:wrap;
    animation: fadeInUp .8s ease .3s backwards;
}
.btn {
    padding:.85rem 2rem; border:none; border-radius:50px;
    font-family:'Montserrat',sans-serif; font-weight:600; font-size:.9rem;
    cursor:pointer; transition:all .3s; text-decoration:none; display:inline-block;
}
.btn-primary  { background:var(--accent); color:var(--primary); box-shadow:0 8px 25px rgba(212,175,55,.3); }
.btn-primary:hover  { transform:translateY(-3px); box-shadow:0 12px 35px rgba(212,175,55,.4); }
.btn-secondary{ background:transparent; color:var(--text); border:2px solid var(--accent); }
.btn-secondary:hover{ background:var(--accent); color:var(--primary); }

@keyframes fadeInUp   { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeInRight{ from{opacity:0;transform:translateX(22px)} to{opacity:1;transform:translateX(0)} }

/* ── Photo ── */
.hero-image { display:flex; justify-content:center; align-items:center; animation:fadeInRight .8s ease; }
.hero-image-wrapper {
    width: 420px;
    height: 520px;
    border-radius:20px; overflow:hidden;
    border:3px solid var(--accent);
    box-shadow:0 0 0 6px rgba(212,175,55,.2), 0 20px 60px rgba(0,0,0,.4);
    background:var(--secondary);
}
.hero-image-wrapper img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: 50% 18%;
}

/* ══════════════════════════════════════
   À PROPOS
══════════════════════════════════════ */
.about { background:var(--bg-light); }

.about-text p {
    font-size:1.08rem; line-height:1.85;
    margin-bottom:1.1rem; color:#333;
    text-align:justify; max-width:860px;
}

/* Stats — taille réduite, plus compact */
.stats {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:1.25rem; margin-top:2rem; max-width:680px;
}
.stat-item {
    text-align:center; padding:1.2rem 1rem;
    background:#fff; border-radius:12px;
    box-shadow:0 4px 16px rgba(0,0,0,.08);
    transition:transform .3s;
}
.stat-item:hover { transform:translateY(-4px); }
.stat-number {
    font-family:'Montserrat',sans-serif;
    font-size:2rem;             /* réduit */
    font-weight:800; color:var(--accent); display:block;
}
.stat-label {
    font-family:'Montserrat',sans-serif;
    font-size:.82rem; color:#666; margin-top:.3rem;
}

/* ══════════════════════════════════════
   DIPLÔMES  — même design que Compétences/Réalisations
══════════════════════════════════════ */
.diplomas { background:#fff; }

.diplomas-grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:1.5rem;
}
.diploma-card {
    background:var(--bg-light);
    border-radius:16px;
    padding:1.75rem 1.5rem;
    border-top:4px solid var(--accent);
    box-shadow:0 4px 18px rgba(0,0,0,.07);
    transition:all .3s;
}
.diploma-card:hover { transform:translateY(-6px); box-shadow:0 10px 30px rgba(0,0,0,.12); }
.diploma-card-header {
    display:flex; align-items:center; gap:.8rem; margin-bottom:1rem;
}
.diploma-card-header i { font-size:1.6rem; color:var(--accent); }
.diploma-date {
    font-family:'Montserrat',sans-serif;
    font-size:.78rem; font-weight:700;
    color:var(--accent); letter-spacing:.3px;
}
.diploma-card h3 {
    font-family:'Montserrat',sans-serif;
    font-size:1rem; font-weight:700;
    color:var(--text-dark); margin-bottom:.4rem; line-height:1.35;
}
.diploma-card p { font-size:.92rem; color:#666; }

/* ══════════════════════════════════════
   COMPÉTENCES — 2 blocs, pas de hauteur fixe
══════════════════════════════════════ */
.skills { background:var(--bg-light); }

.skills-grid {
    display:grid; grid-template-columns:1fr 1fr;
    gap:2rem; align-items:start; /* IMPORTANT : start = hauteur naturelle */
}
.skill-card {
    background:#fff;
    border-radius:16px;
    padding:2rem;
    border-top:4px solid var(--accent);
    box-shadow:0 4px 18px rgba(0,0,0,.07);
    transition:all .3s;
    /* PAS de height fixe → s'adapte au contenu */
}
.skill-card:hover { transform:translateY(-5px); box-shadow:0 10px 30px rgba(0,0,0,.12); }
.skill-card-icon { margin-bottom:.9rem; }
.skill-card-icon i { font-size:2rem; color:var(--accent); }
.skill-card h3 {
    font-family:'Montserrat',sans-serif;
    font-size:1.1rem; font-weight:700;
    color:var(--text-dark); margin-bottom:1.1rem;
}
.skill-card ul { list-style:none; }
.skill-card ul li {
    padding:.45rem 0; font-size:.97rem; color:#444;
    border-bottom:1px solid #f0f0f0;
    display:flex; align-items:flex-start; gap:.5rem;
}
.skill-card ul li::before {
    content:'▸'; color:var(--accent);
    font-size:.8rem; flex-shrink:0; margin-top:.15rem;
}
.skill-card ul li:last-child { border-bottom:none; }

/* ══════════════════════════════════════
   RÉALISATIONS
══════════════════════════════════════ */
.portfolio { background:#fff; }

.portfolio-tabs {
    display:flex; justify-content:center;
    gap:1.25rem; margin:1.75rem 0; flex-wrap:wrap;
}
.tab-btn {
    padding:.8rem 1.6rem; background:#fff;
    border:2px solid var(--accent); border-radius:50px;
    font-family:'Montserrat',sans-serif; font-weight:600; font-size:.88rem;
    color:var(--text-dark); cursor:pointer; transition:all .3s;
}
.tab-btn.active,.tab-btn:hover { background:var(--accent); color:#fff; }

.portfolio-content { margin-top:1.75rem; }
.tab-pane { display:none; }
.tab-pane.active { display:block; }

.media-carousel { overflow:hidden; padding:.5rem 0; }
.media-track { display:flex; transition:transform .3s; gap:1.5rem; }
.media-item { min-width:calc(25% - 1.2rem); flex-shrink:0; }

.media-card {
    background:#fff; border-radius:14px; overflow:hidden;
    box-shadow:0 6px 22px rgba(0,0,0,.09); transition:all .3s;
}
.media-card:hover { transform:translateY(-6px); box-shadow:0 12px 35px rgba(0,0,0,.14); }

/* vidéo */
.video-wrapper { position:relative; padding-bottom:56.25%; height:0; overflow:hidden; background:#000; }
.video-wrapper video {
    position:absolute; top:0; left:0; width:100%; height:100%;
    object-fit:contain; background:#000;
}
.media-placeholder-full {
    min-height:180px; display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    background:linear-gradient(135deg,var(--primary),var(--secondary));
    padding:2rem; text-align:center;
}
.media-placeholder-full i  { font-size:2.5rem; color:var(--accent); margin-bottom:.6rem; }
.media-placeholder-full span{ color:rgba(230,241,255,.75); font-size:.9rem; }
.media-placeholder {
    min-height:180px; display:flex; align-items:center; justify-content:center;
    background:linear-gradient(135deg,var(--primary),var(--secondary));
}
.media-placeholder i { font-size:2.5rem; color:var(--accent); }

/* audio */
.audio-wrapper {
    padding:1.5rem;
    background:linear-gradient(135deg,var(--primary),var(--secondary));
}
.audio-top { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1rem; }
.audio-top > i { font-size:2rem; color:var(--accent); flex-shrink:0; margin-top:.2rem; }
.audio-top h3 { font-family:'Montserrat',sans-serif; font-size:1rem; color:var(--text); margin-bottom:.2rem; }
.audio-top p  { font-size:.85rem; color:rgba(230,241,255,.7); }
.audio-wrapper audio { width:100%; }

/* pdf */
.pdf-wrapper {
    padding:2rem 1.5rem;
    background:linear-gradient(135deg,var(--primary),var(--secondary));
    display:flex; flex-direction:column; align-items:center; text-align:center;
}
.pdf-wrapper i  { font-size:3rem; color:var(--accent); margin-bottom:.75rem; }
.pdf-wrapper h3 { font-family:'Montserrat',sans-serif; font-size:1rem; color:var(--text); margin-bottom:.4rem; }
.pdf-wrapper p  { font-size:.85rem; color:rgba(230,241,255,.7); margin-bottom:1rem; }
.pdf-link {
    padding:.65rem 1.3rem; background:var(--accent); color:var(--primary);
    text-decoration:none; border-radius:50px;
    font-family:'Montserrat',sans-serif; font-weight:600; font-size:.88rem;
    transition:all .3s;
}
.pdf-link:hover { transform:translateY(-2px); box-shadow:0 6px 18px rgba(212,175,55,.3); }

.media-info { padding:1.1rem 1.25rem; }
.media-info h3 { font-family:'Montserrat',sans-serif; font-size:1rem; margin-bottom:.3rem; color:var(--text-dark); }
.media-info p  { color:#666; font-size:.88rem; }

.carousel-controls { display:flex; justify-content:center; gap:.9rem; margin-top:1.25rem; }
.carousel-btn {
    background:var(--accent); color:#fff; border:none;
    width:42px; height:42px; border-radius:50%; font-size:1rem;
    cursor:pointer; transition:all .3s;
    display:flex; align-items:center; justify-content:center;
}
.carousel-btn:hover { background:var(--accent-dark); transform:scale(1.1); }
.carousel-btn:disabled { opacity:.4; cursor:not-allowed; }

/* ══════════════════════════════════════
   PARCOURS
══════════════════════════════════════ */
.timeline { background:var(--bg-light); }

.timeline-items { position:relative; margin-top:1.75rem; }
.timeline-items::before {
    content:''; position:absolute; left:50%; transform:translateX(-50%);
    width:3px; height:100%; background:var(--accent);
}
.timeline-item {
    display:grid; grid-template-columns:1fr 1fr;
    gap:4rem; margin-bottom:2rem; position:relative;
}
.timeline-item::before {
    content:''; position:absolute; left:50%; top:26px;
    transform:translateX(-50%);
    width:16px; height:16px; background:var(--accent);
    border-radius:50%; border:3px solid #fff;
    box-shadow:0 0 0 3px var(--accent); z-index:1;
}
.timeline-content {
    background:#fff; padding:1.5rem 1.75rem;
    border-radius:14px; box-shadow:0 6px 22px rgba(0,0,0,.08);
}
.timeline-item:nth-child(even) .timeline-content { grid-column:2; }
.timeline-item:nth-child(odd)  .timeline-content { grid-column:1; }
.timeline-date  { font-family:'Montserrat',sans-serif; font-weight:700; color:var(--accent); font-size:.88rem; margin-bottom:.35rem; }
.timeline-content h3 { font-family:'Montserrat',sans-serif; font-size:1.2rem; color:var(--text-dark); margin-bottom:.3rem; }
.timeline-content h4 { font-size:.95rem; color:#666; margin-bottom:.6rem; }
.timeline-content p  { color:#666; line-height:1.6; font-size:.92rem; }

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
#contact {
    background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);
}
.contact-title { color:var(--text) !important; }
.contact-title::after { background:var(--accent); }
.section-subtitle { text-align:center; font-size:1.05rem; color:rgba(230,241,255,.8); margin-top:-.75rem; margin-bottom:2rem; }

.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; }
.contact-info { display:flex; flex-direction:column; gap:1.25rem; }
.contact-item {
    display:flex; align-items:flex-start; gap:1.1rem; padding:1.1rem;
    background:rgba(255,255,255,.05); border-radius:12px;
    border:1px solid rgba(212,175,55,.2); transition:all .3s;
}
.contact-item:hover { transform:translateX(6px); border-color:var(--accent); }
.contact-item i { font-size:1.5rem; color:var(--accent); margin-top:.15rem; }
.contact-item h3 { font-family:'Montserrat',sans-serif; color:var(--text); margin-bottom:.3rem; font-size:.95rem; }
.contact-item a,.contact-item p { color:rgba(230,241,255,.78); text-decoration:none; font-size:.92rem; transition:color .3s; }
.contact-item a:hover { color:var(--accent); }

.contact-form-wrap {
    background:rgba(255,255,255,.05); backdrop-filter:blur(10px);
    padding:1.75rem; border-radius:14px; border:1px solid rgba(212,175,55,.2);
}
.contact-form-wrap form { display:flex; flex-direction:column; gap:1.1rem; }
.contact-form-wrap input,
.contact-form-wrap textarea {
    width:100%; padding:.85rem;
    background:rgba(255,255,255,.1); border:1px solid rgba(212,175,55,.3);
    border-radius:10px; color:var(--text);
    font-family:'Crimson Text',serif; font-size:1rem; transition:all .3s;
}
.contact-form-wrap input:focus,
.contact-form-wrap textarea:focus { outline:none; border-color:var(--accent); background:rgba(255,255,255,.15); }
.contact-form-wrap textarea { resize:vertical; }
.contact-form-wrap input::placeholder,
.contact-form-wrap textarea::placeholder { color:rgba(230,241,255,.4); }
.contact-form-wrap button {
    padding:.85rem 2rem; background:var(--accent); color:var(--primary);
    border:none; border-radius:50px;
    font-family:'Montserrat',sans-serif; font-weight:600; font-size:.9rem;
    cursor:pointer; transition:all .3s;
    box-shadow:0 8px 22px rgba(212,175,55,.3); align-self:flex-start;
}
.contact-form-wrap button:hover { transform:translateY(-3px); box-shadow:0 12px 30px rgba(212,175,55,.4); }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer {
    background:var(--primary); padding:2.25rem 5%;
    text-align:center; border-top:1px solid rgba(212,175,55,.2);
}
.footer-content { max-width:1200px; margin:0 auto; }
.social-links { display:flex; justify-content:center; gap:1.1rem; margin-bottom:1.25rem; }
.social-links a {
    width:42px; height:42px; background:rgba(212,175,55,.1);
    border:2px solid var(--accent); border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:var(--accent); font-size:1.05rem; transition:all .3s;
}
.social-links a:hover { background:var(--accent); color:var(--primary); transform:translateY(-3px); }
footer p { color:rgba(230,241,255,.6); font-size:.88rem; }

/* ══════════════════════════════════════
   FLOATING BUTTONS
══════════════════════════════════════ */
.floating-buttons {
    position:fixed; bottom:1.5rem; right:1.5rem;
    display:flex; flex-direction:column; gap:.75rem; z-index:999;
}
.float-btn {
    width:52px; height:52px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size:1.3rem; text-decoration:none;
    box-shadow:0 4px 16px rgba(0,0,0,.3); transition:all .3s;
}
.float-btn:hover { transform:translateY(-4px) scale(1.1); }
.whatsapp { background:#25d366; }
.linkedin  { background:#0077b5; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width:1100px) {
    .hero-firstname, .hero-lastname { font-size:2rem; }
    .media-item { min-width:calc(33.333% - 1rem); }
    .diplomas-grid { grid-template-columns:1fr 1fr; }
}

@media (max-width:968px) {
    .nav-links {
        position:fixed; top:0; right:-100%; height:100vh; width:270px;
        background:var(--primary); flex-direction:column; padding:5rem 2rem;
        transition:right .3s; box-shadow:-5px 0 20px rgba(0,0,0,.3);
    }
    .nav-links.active { right:0; }
    .mobile-menu-btn { display:block; }
    .hero-content { grid-template-columns:1fr; text-align:center; }
    .hero-title { white-space:normal; }
    .hero-firstname, .hero-lastname { font-size:1.9rem; }
    .hero-buttons { justify-content:center; }
    .hero-image-wrapper { width:300px; height:380px; }
    .skills-grid { grid-template-columns:1fr; }
    .diplomas-grid { grid-template-columns:1fr; }
    .contact-grid { grid-template-columns:1fr; }
    .stats { grid-template-columns:repeat(3,1fr); }
    .timeline-items::before { left:24px; }
    .timeline-item { grid-template-columns:1fr; padding-left:52px; gap:0; margin-bottom:1.5rem; }
    .timeline-item::before { left:24px; }
    .timeline-item:nth-child(even) .timeline-content,
    .timeline-item:nth-child(odd) .timeline-content { grid-column:1; }
    .media-item { min-width:calc(50% - .75rem); }
}

@media (max-width:600px) {
    .hero-firstname, .hero-lastname { font-size:1.55rem; }
    .hero-role { font-size:1rem; }
    .section-title { font-size:1.75rem; }
    .media-item { min-width:100%; }
    .stats { grid-template-columns:1fr; max-width:280px; }
    .diplomas-grid { grid-template-columns:1fr; }
    section:not(.hero) { padding-top:2.75rem; padding-bottom:2.75rem; }
}