/* ── HOME.CSS — Styles spécifiques à index.html ── */

/* ── HERO ── */
.hero {
    min-height: 100vh; min-height: 100dvh;
    display: flex; align-items: center;
    padding: 120px 40px 80px;
    padding-top: calc(120px + var(--safe-top));
    max-width: 1200px; margin: 0 auto;
    position: relative; z-index: 1;
}

.hero-content { max-width: 680px; }

.hero-tag { margin-bottom: 32px; }

.hero h1 {
    font-family: 'DM Serif Display', serif;
    font-size: clamp(3rem, 8.5vw, 6.8rem);
    line-height: 1.0; color: var(--dark);
    letter-spacing: -0.02em; margin-bottom: 24px;
}
.hero h1 em { font-style: italic; color: var(--accent); }

.hero-desc {
    font-size: clamp(1rem, 1.8vw, 1.15rem);
    color: var(--text-light); font-weight: 300;
    line-height: 1.75; max-width: 500px; margin-bottom: 44px;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }

.hero-scroll {
    position: absolute; bottom: 48px; left: 40px;
    display: flex; align-items: center; gap: 12px;
    color: var(--warm-gray); font-size: 0.75rem;
    font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase;
}
.scroll-line { width: 36px; height: 1px; background: var(--warm-gray); animation: sline 2s ease-in-out infinite; }
@keyframes sline { 0%,100%{width:36px;} 50%{width:56px;} }

/* ── À PROPOS ── */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }

.about-text p {
    font-size: 1.05rem; color: var(--text-light);
    font-weight: 300; line-height: 1.85; margin-bottom: 14px;
}
.about-text p strong { color: var(--text); font-weight: 500; }

.about-facts { display: flex; flex-direction: column; gap: 14px; }

.fact-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 18px; padding: 20px 24px;
    backdrop-filter: blur(10px); transition: all 0.25s;
}
.fact-card:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(28,26,24,0.07); }
.fact-label { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--warm-gray); margin-bottom: 5px; }
.fact-value { font-family: 'DM Serif Display', serif; font-size: 1.15rem; color: var(--dark); }

/* ── TIMELINE ── */
.timeline { position: relative; padding-left: 30px; }
.timeline::before { content: ''; position: absolute; left: 0; top: 10px; bottom: 10px; width: 1px; background: linear-gradient(to bottom, var(--accent), var(--accent-2), transparent); }

.timeline-item { position: relative; margin-bottom: 44px; }
.timeline-item::before { content: ''; position: absolute; left: -35px; top: 10px; width: 10px; height: 10px; border-radius: 50%; background: var(--cream); border: 2px solid var(--accent); }

.timeline-date { font-size: 0.78rem; font-weight: 600; color: var(--accent); letter-spacing: 0.06em; margin-bottom: 5px; }
.timeline-title { font-family: 'DM Serif Display', serif; font-size: 1.25rem; color: var(--dark); margin-bottom: 3px; }
.timeline-org { font-size: 0.88rem; color: var(--text-light); font-weight: 500; margin-bottom: 8px; }
.timeline-desc { font-size: 0.92rem; color: var(--text-light); font-weight: 300; line-height: 1.7; }

/* ── CARTES EXPÉRIENCES ── */
.exp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,300px),1fr)); gap: 18px; }

.exp-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 22px; padding: 30px 26px;
    backdrop-filter: blur(10px); transition: all 0.25s;
}
.exp-card:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(28,26,24,0.08); }

.exp-type {
    display: inline-block; font-size: 0.72rem; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--accent-2); background: rgba(143,168,158,0.12);
    padding: 4px 10px; border-radius: 100px; margin-bottom: 12px;
}
.exp-card h3 { font-family: 'DM Serif Display', serif; font-size: 1.2rem; color: var(--dark); margin-bottom: 4px; }
.exp-card .org { font-size: 0.85rem; color: var(--text-light); font-weight: 500; margin-bottom: 12px; }
.exp-card p { font-size: 0.9rem; color: var(--text-light); font-weight: 300; line-height: 1.65; }
.exp-card ul { padding-left: 16px; font-size: 0.9rem; color: var(--text-light); font-weight: 300; line-height: 1.65; }
.exp-card li { margin-bottom: 4px; }

/* ── COMPÉTENCES ── */
.skills-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; }
.skill-group-title { font-family: 'DM Serif Display', serif; font-size: 1.4rem; color: var(--dark); margin-bottom: 22px; }

.skill-list { display: flex; flex-direction: column; gap: 13px; }
.skill-row { display: flex; align-items: center; gap: 14px; }
.skill-name { font-size: 0.88rem; font-weight: 500; color: var(--text); min-width: 130px; }
.skill-track { flex: 1; height: 4px; background: var(--stone); border-radius: 10px; overflow: hidden; }
.skill-fill { height: 100%; border-radius: 10px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width 1.3s cubic-bezier(0.4,0,0.2,1); }

.skill-row--devweb { position: relative; user-select: none; --devweb-hold: 0; overflow: visible; }
.skill-row--devweb .skill-track { position: relative; transform-origin: center; will-change: transform, box-shadow; }
.skill-row--devweb.is-click-growing .skill-track {
    transform: scaleY(var(--devweb-click-grow, 1.2));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 36%, transparent), 0 0 36px color-mix(in srgb, var(--accent-2) 58%, transparent);
    transition: transform 0.28s ease, box-shadow 0.28s ease;
}
.skill-row--devweb.is-click-growing .skill-fill {
    animation: devwebPulse 820ms ease-in-out infinite;
}
.skill-row--devweb.is-pressing .skill-track {
    transform: scaleY(calc(1 + (var(--devweb-hold) * 1.8)));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 34%, transparent), 0 0 calc(12px + (var(--devweb-hold) * 34px)) color-mix(in srgb, var(--accent-2) 52%, transparent);
}
.skill-row--devweb.is-pressing .skill-fill {
    animation: devwebCharge 1s linear infinite;
}
.skill-row--devweb.is-hyped .skill-track {
    transform: scaleY(2.5);
    transform-origin: center;
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 44%, transparent), 0 0 46px color-mix(in srgb, var(--accent-2) 66%, transparent);
    transition: transform 0.32s ease, box-shadow 0.32s ease;
}
.skill-row--devweb.is-hyped .skill-fill {
    animation: devwebPulse 900ms ease-in-out infinite;
}
.skill-row--devweb.is-hyped .skill-track::before,
.skill-row--devweb.is-hyped .skill-track::after {
    content: '';
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    top: -9px;
    background: radial-gradient(circle, #ffffff 0%, var(--accent) 60%, transparent 100%);
    pointer-events: none;
    animation: devwebSpark 0.9s ease-out infinite;
}
.skill-row--devweb.is-hyped .skill-track::before { left: 14%; }
.skill-row--devweb.is-hyped .skill-track::after { left: 76%; animation-delay: 0.3s; }

.devweb-burst-layer {
    position: absolute;
    inset: -34px -10px;
    pointer-events: none;
    overflow: visible;
    z-index: 5;
}

.devweb-particle {
    position: absolute;
    left: var(--x);
    top: var(--y);
    opacity: 0;
    animation: devwebBurst var(--dur) cubic-bezier(0.15, 0.7, 0.2, 1) var(--delay) forwards;
}

.devweb-particle--spark {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: radial-gradient(circle, #ffffff 0%, var(--accent) 56%, color-mix(in srgb, var(--accent-2) 70%, transparent) 100%);
    box-shadow: 0 0 14px color-mix(in srgb, var(--accent-2) 58%, transparent);
}

.devweb-particle--confetti {
    width: 6px;
    height: 12px;
    border-radius: 2px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 85%, white), color-mix(in srgb, var(--accent-2) 88%, white));
    box-shadow: 0 0 10px color-mix(in srgb, var(--accent-2) 45%, transparent);
}

@keyframes devwebCharge {
    0% { filter: saturate(1); }
    50% { filter: saturate(1.25); }
    100% { filter: saturate(1); }
}

@keyframes devwebPulse {
    0%, 100% { transform: scaleX(1); filter: brightness(1); }
    50% { transform: scaleX(1.03); filter: brightness(1.12); }
}

@keyframes devwebSpark {
    0% { transform: translateY(0) scale(0.8); opacity: 0; }
    35% { opacity: 1; }
    100% { transform: translateY(-14px) scale(1.08); opacity: 0; }
}

@keyframes devwebBurst {
    0% {
        transform: translate(0, 0) rotate(0deg) scale(0.65);
        opacity: 0;
    }
    12% {
        opacity: 1;
    }
    100% {
        transform: translate(var(--dx), var(--dy)) rotate(var(--rot)) scale(1.06);
        opacity: 0;
    }
}

.devweb-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: 16px;
}

.devweb-modal[hidden] {
    display: none;
}

.devweb-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 14, 18, 0.38);
    backdrop-filter: blur(4px);
}

.devweb-modal__panel {
    position: relative;
    width: min(360px, calc(100vw - 32px));
    border-radius: 20px;
    border: 1px solid var(--border);
    background: var(--nav-bg);
    box-shadow: 0 20px 56px rgba(22, 19, 25, 0.28);
    padding: 16px;
    transform: translateY(10px) scale(0.98);
    opacity: 0;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.devweb-modal.is-open .devweb-modal__panel {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.devweb-modal__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.devweb-modal__badge {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent-2);
    background: color-mix(in srgb, var(--accent-2) 17%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent-2) 40%, transparent);
    border-radius: 999px;
    padding: 4px 10px;
}

.devweb-modal__close {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--card-bg);
    color: var(--text);
    cursor: pointer;
    font-size: 1rem;
}

.devweb-modal__panel h3 {
    font-family: 'DM Serif Display', serif;
    font-size: 1.3rem;
    color: var(--dark);
    margin-bottom: 8px;
}

.devweb-modal__panel p {
    color: var(--text-light);
    font-size: 0.92rem;
    margin-bottom: 14px;
}

.devweb-modal__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    text-decoration: none;
    border-radius: 12px;
    padding: 10px 12px;
    border: 1px solid color-mix(in srgb, var(--accent) 44%, transparent);
    background: color-mix(in srgb, var(--accent) 16%, transparent);
    color: var(--text);
    font-weight: 600;
}

.devweb-modal__link:hover {
    background: color-mix(in srgb, var(--accent) 22%, transparent);
}

.soft-skills { display: flex; flex-wrap: wrap; gap: 9px; cursor: default; }
.soft-tag {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 100px; padding: 7px 15px;
    font-size: 0.85rem; color: var(--text); font-weight: 500;
    cursor: default; user-select: none;
    backdrop-filter: blur(10px); transition: all 0.2s;
}
.soft-tag:hover { background: var(--stone); transform: translateY(-1px); }

/* ── DIPLÔMES ── */
.diplomes-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,240px),1fr)); gap: 14px; }

.diplome-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 20px; padding: 26px 22px;
    backdrop-filter: blur(10px); transition: all 0.25s;
}
a.diplome-card { display: block; color: inherit; text-decoration: none; }
.diplome-card:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(28,26,24,0.08); }
a.diplome-card:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.diplome-icon { width: 38px; height: 38px; border-radius: 12px; background: var(--cream-2); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; font-size: 1rem; color: var(--accent); }
.diplome-card h4 { font-family: 'DM Serif Display', serif; font-size: 1.05rem; color: var(--dark); margin-bottom: 5px; }
.diplome-card p { font-size: 0.85rem; color: var(--text-light); font-weight: 300; }
.mention { display: inline-block; margin-top: 8px; font-size: 0.75rem; font-weight: 600; color: var(--accent-2); background: rgba(143,168,158,0.12); padding: 3px 9px; border-radius: 100px; }

/* ── CONTACT ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.contact-intro { font-size: 1.05rem; color: var(--text-light); font-weight: 300; line-height: 1.8; margin-bottom: 28px; }

.contact-links { display: flex; flex-direction: column; gap: 12px; }
.contact-link {
    display: flex; align-items: center; gap: 14px;
    text-decoration: none; color: var(--text);
    padding: 14px 18px; border-radius: 16px;
    border: 1px solid var(--border); background: var(--card-bg);
    backdrop-filter: blur(10px); transition: all 0.2s; touch-action: manipulation;
}
.contact-link:hover { transform: translateX(4px); background: var(--stone); }
.contact-link-icon { width: 38px; height: 38px; border-radius: 12px; background: var(--cream-2); display: flex; align-items: center; justify-content: center; color: var(--accent); font-size: 0.95rem; flex-shrink: 0; }
.contact-link-text strong { display: block; font-weight: 500; font-size: 0.78rem; color: var(--text-light); margin-bottom: 1px; text-transform: uppercase; letter-spacing: 0.05em; }
.contact-link-text span { font-size: 0.92rem; color: var(--text); }

.engagement-card {
    background: linear-gradient(140deg, var(--dark) 0%, var(--dark-2) 100%);
    border-radius: 24px; padding: 40px 34px; color: var(--text-on-dark);
}
.ec-label { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; }
.engagement-card h3 { font-family: 'DM Serif Display', serif; font-size: 1.75rem; margin-bottom: 12px; line-height: 1.2; }
.engagement-card p { font-size: 0.92rem; color: rgba(250,248,245,0.6); font-weight: 300; line-height: 1.75; }

/* ── MODE SOMBRE ── */
body[data-theme='dark'] .hero h1,
body[data-theme='dark'] .fact-value,
body[data-theme='dark'] .timeline-title,
body[data-theme='dark'] .exp-card h3,
body[data-theme='dark'] .skill-group-title,
body[data-theme='dark'] .skill-name,
body[data-theme='dark'] .soft-tag,
body[data-theme='dark'] .diplome-card h4,
body[data-theme='dark'] .contact-link,
body[data-theme='dark'] .contact-link-text span { color: var(--text); }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
    .about-grid, .contact-grid, .skills-layout { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 768px) {
    .hero { padding: 100px 20px 70px; padding-top: calc(100px + var(--safe-top)); }
    .hero-scroll { left: 20px; }
}

@media (max-width: 480px) {
    .hero-actions { flex-direction: column; align-items: stretch; }
    .skill-name { min-width: 100px; font-size: 0.82rem; }
}
