/* styles/dev-page.css */
/* Par défaut (desktop) : drawer/overlay cachés */
#mobile-drawer,
#drawer-overlay{
  display: none;
}

/* Mobile seulement : on les affiche */
@media (max-width: 768px){
  #drawer-overlay{ display:block; }   /* l'overlay existe mais reste invisible tant que pas .is-open */
  #mobile-drawer{ display:flex; }     /* flex car ton panneau est en flex-column */
}

/* Variables */
:root{
  --dev-primary: #1a1a2e;
  --dev-secondary: #16213e;
  --dev-accent: #4cc9f0;
  --dev-text: #e6e6e6;
  --dev-card-bg: rgba(22, 33, 62, 0.8);
  --dev-border: rgba(76, 201, 240, 0.3);
}

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

body{
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background: linear-gradient(135deg, var(--dev-primary) 0%, var(--dev-secondary) 100%);
  color: var(--dev-text);
  min-height: 100vh;
}

.container{ max-width:1200px; margin:0 auto; padding:0 20px; }

/* Navbar */
.navbar{
  position: fixed; top:0; left:0; right:0;
  background: rgba(22, 33, 62, 0.95);
  backdrop-filter: blur(10px);
  z-index: 1000; padding: 1rem 0; border-bottom: 1px solid var(--dev-border);
}
.nav-container{
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo{ display:flex; align-items:center; gap:.5rem; color:var(--dev-accent); text-decoration:none; font-weight:600; }
.nav-menu{ display:flex; gap:2rem; align-items:center; }
.nav-link{ color:var(--dev-text); text-decoration:none; font-weight:500; transition:color .25s ease; }
.nav-link:hover{ color:var(--dev-accent); }

.nav-toggle{
  display:none; background:transparent; border:0; cursor:pointer;
  width:42px; height:42px; border-radius:10px;
}
.nav-toggle .bar{ display:block; width:24px; height:2px; background:var(--dev-text); margin:5px auto; }

/* Hero */
.dev-hero{
  position: relative;
  display:grid;
  grid-template-columns: 1fr minmax(420px,520px);
  align-items:center;
  gap:40px;
  padding: 120px 0 60px;
}
.dev-hero{padding:calc(70px + 48px) var(--gutter) 50px; padding-top: 130px;}
.hero-content{margin-inline:auto;text-align:left;max-width:720px}
.hero-intro{ margin-bottom:2rem; }
.hero-greeting{ display:block; font-size:1.2rem; color:var(--dev-accent); margin-bottom:.5rem; font-weight:500; }
.hero-title{
  font-size:4rem; font-weight:800; margin-bottom:1rem; line-height:1.2;
  background: linear-gradient(135deg, var(--dev-text) 0%, var(--dev-accent) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-tagline{ font-size:1.8rem; font-weight:600; margin-bottom:2rem; }
.typewriter{ color:var(--dev-accent); }
.typewriter-cursor{ animation: blink 1s infinite; color:var(--dev-accent); }
@keyframes blink{ 0%,50%{opacity:1} 51%,100%{opacity:0} }

.hero-description{ font-size:1.3rem; line-height:1.6; margin-bottom:2.5rem; opacity:.9; max-width:640px; }
.hero-description strong{ color:var(--dev-accent); font-weight:600; }
.hero-description strong a{ color:var(--dev-accent); text-decoration:underline; }

.hero-highlights{ display:flex; gap:2rem; flex-wrap:wrap; margin-bottom:3rem; }
.highlight-item{
  display:flex; align-items:center; gap:.8rem;
  background: rgba(76, 201, 240, 0.1);
  padding:1rem 1.5rem; border-radius:15px; border:1px solid var(--dev-border);
}
.highlight-item i{ font-size:1.2rem; color:var(--dev-accent); }
.highlight-item span{ font-weight:600; }

.hero-actions{ display:flex; gap:1.5rem; flex-wrap:wrap; }

.cta-btn{
  padding:1.1rem 2.2rem; border-radius:50px; text-decoration:none; font-weight:600; font-size:1.05rem;
  display:flex; align-items:center; gap:.8rem; transition: all .25s ease; border:2px solid transparent;
}
.cta-btn.primary{ background:var(--dev-accent); color:var(--dev-primary); }
.cta-btn.primary:hover{ transform:translateY(-3px); box-shadow:0 10px 30px rgba(76,201,240,.4); }
.cta-btn.secondary{ background:transparent; color:var(--dev-accent); border-color:var(--dev-accent); }
.cta-btn.secondary:hover{ background:var(--dev-accent); color:var(--dev-primary); transform:translateY(-3px); }

/* Hero visuel */
.hero-visual{ position:relative; width:100%; height:460px;}
.code-animation{
  position:absolute; inset: 50% auto auto 50%; transform: translate(-50%,-50%);
  width:320px; height:220px; background: rgba(22,33,62,.8); border:1px solid var(--dev-border);
  border-radius:15px; padding:1.5rem;
}
.code-line{ height:15px; background:linear-gradient(90deg, var(--dev-accent) 0%, transparent 100%); margin-bottom:.8rem; border-radius:3px; opacity:.7; animation: codeTyping 2s ease-in-out infinite; }
.code-line:nth-child(2){ width:80%; animation-delay:.5s; }
.code-line:nth-child(3){ width:60%; animation-delay:1s; }
.code-line:nth-child(4){ width:70%; animation-delay:1.5s; }
@keyframes codeTyping{ 0%,100%{opacity:.3} 50%{opacity:.8} }

/* Éléments flottants à droite */
.floating-elements{
  position:absolute; top:0; right:500px; width:100%; height:100%; pointer-events:none;
}
.floating-element{
  position:absolute; width:60px; height:60px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; color:var(--dev-accent);
  background:var(--dev-card-bg); border:2px solid var(--dev-border);
  animation: floatElement 6s ease-in-out infinite;
  pointer-events:auto;
}
.floating-element::after{
  content: attr(data-tech);
  position:absolute; bottom:-30px; left:50%; transform:translateX(-50%);
  font-size:.8rem; color:var(--dev-text); opacity:0; transition:opacity .25s ease;
}
.floating-element:hover::after{ opacity:1; }

/* Placement précis dans la zone de droite */
.floating-element:nth-child(1)  { top: 6%;  left: 15%; animation-delay: 0s; }
.floating-element:nth-child(2)  { top: 22%; left: 60%; animation-delay: .4s; }
.floating-element:nth-child(3)  { top: 40%; left: 35%; animation-delay: .8s; }
.floating-element:nth-child(4)  { top: 10%; left: 70%; animation-delay: 1.2s; }
.floating-element:nth-child(5)  { top: 55%; left: 70%; animation-delay: 1.6s; }
.floating-element:nth-child(6)  { top: 30%; left: 10%; animation-delay: 2s; }
.floating-element:nth-child(7)  { top: 72%; left: 25%; animation-delay: 2.4s; }
.floating-element:nth-child(8)  { top: 75%; left: 58%; animation-delay: 2.8s; }
.floating-element:nth-child(9)  { top: 18%; left: 40%; animation-delay: 3.2s; }
.floating-element:nth-child(10) { top: 62%; left: 48%; animation-delay: 3.6s; }
.floating-element:nth-child(11) { top: 85%; left: 35%; animation-delay: 4s; }

@keyframes floatElement{
  0%,100%{ transform: translateY(0) rotate(0); }
  50%{ transform: translateY(-20px) rotate(10deg); }
}

/* Sections Projets */
.projects-section{ padding:100px 0; }
.section-title{ font-size:3rem; text-align:center; margin-bottom:4rem; font-weight:800; }
.accent{ color:var(--dev-accent); }

.projects-grid{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap:2rem; margin-top:3rem;
}
.project-card{
  background:var(--dev-card-bg); border:1px solid var(--dev-border); border-radius:20px; overflow:hidden;
  transition: transform .3s ease, box-shadow .3s ease; backdrop-filter: blur(10px);
}
.project-card:hover{ transform:translateY(-10px); box-shadow:0 20px 40px rgba(0,0,0,.3); }

.project-image{
  height:250px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center;
}
.project-logo-img,
.echoes-logo-img,
.home-inspire-logo-img,
.saldaetrip-logo-img{
  max-width:80%; max-height:80%; width:auto; height:auto; object-fit:contain; z-index:1;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,.4)); transition: all .3s ease; border-radius:10px;
}
.project-overlay{
  position:absolute; inset:0; background:rgba(0,0,0,.85);
  display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .3s ease; z-index:2;
}
.project-tech{ display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; padding:1rem; }
.project-tech span{ background:var(--dev-accent); color:var(--dev-primary); padding:.6rem 1.2rem; border-radius:20px; font-size:.9rem; font-weight:600; }

.project-card:hover .project-overlay{ opacity:1; }
.project-card:hover .project-logo-img,
.project-card:hover .echoes-logo-img,
.project-card:hover .home-inspire-logo-img,
.project-card:hover .saldaetrip-logo-img{
  transform: scale(.9); filter: brightness(.7) drop-shadow(0 6px 12px rgba(0,0,0,.6));
}

.project-content{ padding:2rem; }
.project-title{ font-size:1.5rem; margin-bottom:1rem; color:var(--dev-accent); }
.project-description{ opacity:.9; margin-bottom:1.5rem; line-height:1.6; }
.project-actions{ display:flex; gap:1rem; flex-wrap:wrap; }

.project-btn{
  padding:.8rem 1.5rem; border:2px solid var(--dev-accent); border-radius:25px;
  background:transparent; color:var(--dev-accent); text-decoration:none; font-weight:600;
  display:inline-flex; align-items:center; gap:.5rem; cursor:pointer; transition: all .25s ease; font-family:inherit;
}
.project-btn:hover{ background:var(--dev-accent); color:var(--dev-primary); transform: translateY(-2px); }
.project-btn.secondary{ border-color:var(--dev-text); color:var(--dev-text); }
.project-btn.secondary:hover{ background:var(--dev-text); color:var(--dev-primary); }

/* Skills */
.skills-section{ padding:100px 0; background: rgba(22,33,62,.5); }
.skills-grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap:3rem; margin-top:3rem; }
.skill-category{ background:var(--dev-card-bg); border:1px solid var(--dev-border); border-radius:20px; padding:2rem; }
.skill-category h3{ color:var(--dev-accent); margin-bottom:1.5rem; font-size:1.5rem; }
.skills-list{ display:flex; flex-direction:column; gap:1.5rem; }
.skill-item{ display:flex; flex-direction:column; gap:.5rem; }
.skill-name{ font-weight:600; }
.skill-bar{ width:100%; height:8px; background: rgba(76,201,240,.2); border-radius:10px; overflow:hidden; }
.skill-progress{
  height:100%; background: linear-gradient(90deg, var(--dev-accent) 0%, #4cc9f0 100%);
  border-radius:10px; transform: scaleX(0); transform-origin:left; animation: fillBar 2s ease-in-out forwards;
}
@keyframes fillBar{ to{ transform: scaleX(1); } }

.skill-progress[data-level="90"]{ width:90%; }
.skill-progress[data-level="85"]{ width:85%; }
.skill-progress[data-level="95"]{ width:95%; }
.skill-progress[data-level="88"]{ width:88%; }
.skill-progress[data-level="82"]{ width:82%; }
.skill-progress[data-level="75"]{ width:75%; }
.skill-progress[data-level="80"]{ width:80%; }

/* Footer premium */
.dev-footer{
  position:relative; margin-top:80px;
  background: linear-gradient(180deg, rgba(22,33,62,.4) 0%, rgba(22,33,62,.8) 100%);
  border-top:1px solid var(--dev-border); overflow:hidden;
}
.dev-footer::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, transparent, var(--dev-accent), transparent);
  filter: drop-shadow(0 0 10px var(--dev-accent)); opacity:.7;
}
.footer-grid{
  display:grid; grid-template-columns: 1.2fr .8fr 1fr; gap:40px; padding:60px 20px;
}
.footer-logo{
  display:flex; align-items:center; gap:.6rem; color:var(--dev-text); text-decoration:none; font-weight:800; font-size:1.3rem; letter-spacing:.4px;
}
.footer-logo .dot{ width:12px; height:12px; border-radius:50%; background:var(--dev-accent); box-shadow:0 0 16px rgba(76,201,240,.8); }
.footer-tag{ margin-top:12px; max-width:420px; opacity:.85; line-height:1.6; }

.footer-links h3, .footer-contact h3{ color:var(--dev-accent); margin-bottom:12px; font-size:1.1rem; }
.footer-links ul{ list-style:none; display:grid; gap:10px; }
.footer-links a, .footer-links button{
  color:var(--dev-text); text-decoration:none; opacity:.9; transition: all .25s ease; border:0; background:transparent; text-align:left; cursor:pointer;
  border-bottom:1px dashed transparent;
}
.footer-links a:hover, .footer-links button:hover{ color:var(--dev-accent); border-bottom-color:var(--dev-accent); }

.footer-social{ display:flex; gap:14px; margin-top:12px; }
.footer-social a{
  width:40px; height:40px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  color:var(--dev-accent); border:1px solid var(--dev-border); background: rgba(22,33,62,.35);
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.footer-social a:hover{ transform: translateY(-2px); background: rgba(76,201,240,.12); box-shadow:0 8px 24px rgba(76,201,240,.25); }

.footer-bottom{ border-top:1px solid var(--dev-border); background: rgba(0,0,0,.15); }
.footer-bottom-inner{
  display:flex; align-items:center; justify-content:space-between; gap:20px; padding:16px 0; font-size:.95rem; opacity:.9;
}
.to-top{
  border:1px solid var(--dev-border); background: rgba(22,33,62,.4); color:var(--dev-text);
  width:42px; height:42px; border-radius:12px; cursor:pointer; transition: all .2s ease;
}
.to-top:hover{ color:var(--dev-primary); background:var(--dev-accent); transform: translateY(-2px); }

/* Modale projets */
.project-modal{
  position:fixed; inset:0; display:none; justify-content:center; align-items:center;
  background: rgba(0,0,0,.9); backdrop-filter: blur(10px); z-index:10000;
  opacity:0; transition: opacity .3s ease; padding:20px;
}
.project-modal.active{ display:flex; opacity:1; }
.modal-content{
  background:var(--dev-card-bg); border:1px solid var(--dev-border); border-radius:20px;
  max-width:900px; width:100%; max-height:90vh; overflow-y:auto; position:relative; animation: modalSlideIn .3s ease;
}
@keyframes modalSlideIn{ from{opacity:0; transform: translateY(-50px) scale(.9);} to{opacity:1; transform: translateY(0) scale(1);} }
.modal-close{
  position:absolute; top:20px; right:20px; width:40px; height:40px; border-radius:50%;
  background: rgba(76,201,240,.2); border:1px solid var(--dev-border); color:var(--dev-text);
  display:flex; align-items:center; justify-content:center; cursor:pointer; transition: all .25s ease; z-index:5;
}
.modal-close:hover{ background:var(--dev-accent); color:var(--dev-primary); transform: rotate(90deg); }
.modal-header{ padding:40px 40px 20px; border-bottom:1px solid var(--dev-border); }
.modal-title{ color:var(--dev-accent); font-size:2.5rem; margin-bottom:15px; }
.modal-tech{ display:flex; gap:10px; flex-wrap:wrap; }
.modal-tech span{ background: rgba(76,201,240,.2); color:var(--dev-accent); padding:5px 15px; border-radius:20px; border:1px solid var(--dev-border); font-size:.9rem; }

.modal-slider{ position:relative; height:400px; overflow:hidden; margin:20px 0; }
.slider-container{ display:flex; height:100%; transition: transform .3s ease; }
.slider-slide{ min-width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.slider-slide img{ max-width:100%; max-height:100%; object-fit:contain; border-radius:10px; }
.slider-arrow{
  position:absolute; top:50%; transform: translateY(-50%); width:50px; height:50px; border-radius:50%;
  border:0; background: rgba(0,0,0,.7); color:#fff; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition: background .25s ease; z-index:10;
}
.slider-arrow:hover{ background: var(--dev-accent); }
.slider-prev{ left:20px; }
.slider-next{ right:20px; }
.slider-dots{ position:absolute; bottom:20px; left:50%; transform: translateX(-50%); display:flex; gap:10px; }
.slider-dot{ width:12px; height:12px; border-radius:50%; background: rgba(255,255,255,.3); border:0; cursor:pointer; transition: transform .2s ease, background .2s ease; }
.slider-dot.active{ background:var(--dev-accent); transform: scale(1.2); }

.modal-body{ padding:20px 40px 40px; }
.modal-description{ font-size:1.1rem; line-height:1.6; margin-bottom:25px; }
.modal-features{ margin-bottom:25px; }
.modal-features h3{ color:var(--dev-accent); margin-bottom:15px; font-size:1.3rem; }
.modal-features ul{ list-style:none; padding:0; }
.modal-features li{ padding:8px 0 8px 25px; position:relative; }
.modal-features li:before{ content:"▹"; position:absolute; left:0; color:var(--dev-accent); }

.modal-links{ display:flex; gap:15px; flex-wrap:wrap; }
.modal-link{
  padding:12px 25px; border:2px solid var(--dev-accent); border-radius:25px; color:var(--dev-accent);
  text-decoration:none; font-weight:600; display:flex; align-items:center; gap:8px; transition: all .25s ease;
}
.modal-link:hover{ background:var(--dev-accent); color:var(--dev-primary); transform: translateY(-2px); }
.modal-link.live-demo{ background:var(--dev-accent); color:var(--dev-primary); }
.modal-link.live-demo:hover{ background:transparent; color:var(--dev-accent); }

/* Panneau de contact */
.contact-panel{
  position:fixed; inset:0; z-index:11000; display:grid; place-items:center;
  background: rgba(0,0,0,.5); backdrop-filter: blur(6px); opacity:0; pointer-events:none; transition: opacity .28s ease;
}
.contact-panel.active{ opacity:1; pointer-events:auto; }
.contact-card{
  position:relative; width:min(920px, 92vw); background: var(--dev-card-bg); border:1px solid var(--dev-border);
  border-radius:20px; padding:32px 24px; box-shadow:0 24px 60px rgba(0,0,0,.35); transform: translateY(24px) scale(.98); transition: transform .28s ease;
}
.contact-panel.active .contact-card{ transform: translateY(0) scale(1); }
.contact-header h2{ color:var(--dev-accent); font-size:2rem; margin-bottom:6px; }
.contact-header p{ opacity:.9; margin-bottom:22px; }

.form-grid{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:18px; }
.form-field{ display:flex; flex-direction:column; gap:8px; }
.form-field--full{ grid-column:1 / -1; }
.form-field label{ font-weight:600; }
.form-field input, .form-field select, .form-field textarea{
  border:1px solid var(--dev-border); background: rgba(22,33,62,.5); color:var(--dev-text);
  border-radius:12px; padding:12px 14px; outline:none; font:inherit; transition: border-color .2s ease, box-shadow .2s ease;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  border-color:var(--dev-accent); box-shadow:0 0 0 3px rgba(76,201,240,.18);
}
.field-msg{ font-size:.85rem; color:#ffb3b3; min-height:1em; }

.form-actions{ display:flex; align-items:center; gap:14px; margin-top:10px; }
.form-status{ opacity:.9; }
.contact-close{
  position:absolute; top:14px; right:14px; width:42px; height:42px; border-radius:12px;
  border:1px solid var(--dev-border); background: rgba(76,201,240,.15); color:var(--dev-text);
  cursor:pointer; transition: all .2s ease;
}
.contact-close:hover{ background:var(--dev-accent); color:var(--dev-primary); transform: rotate(90deg); }
.hp-field{ position:absolute; left:-9999px; opacity:0; }


@media (max-width:2000px){
  .floating-elements{ right:0;}
}

/* Responsive */
@media (max-width: 1200px){
  .dev-hero{ grid-template-columns: 1fr 440px; gap:30px; }
  .hero-visual{ height:420px; }
  .floating-element{ width:50px; height:50px; font-size:1.4rem; }
  .hero-content{ padding: 0 30px; }
  .floating-elements{ right:0;}
}
@media (max-width: 992px){
  .dev-hero{ grid-template-columns: 1fr; }
  .hero-visual{ height:auto; margin-top:24px; }
  .floating-elements{
    position:relative; width:100%; height:160px; margin:0 auto;
    display:grid; grid-template-columns: repeat(5, 1fr); grid-auto-rows:1fr; gap:12px;right:0px;
  }
  .floating-element{
    position:static; width:45px; height:45px; font-size:1.2rem; animation: floatElementMobile 3s ease-in-out infinite;
  }
  .floating-element::after{ display:none; }
  @keyframes floatElementMobile{ 0%,100%{transform: translateY(0);} 50%{transform: translateY(-8px);} }
  .form-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 768px){
  .nav-toggle{ display:block; }
  .nav-menu{ display:none; }
  .hero-content{ padding: 0 10px; text-align:center; }
  .hero-title{ font-size:3rem; }
  .hero-tagline{ font-size:1.4rem; }
  .hero-description{ font-size:1.1rem; margin-left:auto; margin-right:auto; }
  .hero-highlights{ flex-direction:column; gap:1rem; }
  .hero-actions{ flex-direction:column; }
  .cta-btn{ justify-content:center; }
  .projects-grid{ grid-template-columns:1fr; }
  .skills-grid{ grid-template-columns:1fr; }
  .project-actions{ flex-direction:column; }
  .modal-content{ margin:10px; max-height:95vh; }
  .modal-header{ padding:60px 20px 15px; }
  .modal-title{ font-size:2rem; }
  .modal-slider{ height:300px; }
  .modal-body{ padding:15px 20px 30px; }
  .slider-arrow{ width:40px; height:40px; }
  .modal-links{ flex-direction:column; }
  .modal-link{ justify-content:center; }
  .footer-grid{ grid-template-columns: 1fr; gap:28px; padding: 40px 20px; }
  .footer-bottom-inner{ flex-direction:column; }
}
@media (max-width: 600px){
  .hero-title{ font-size:2.6rem; }
  .floating-elements{ grid-template-columns: repeat(4, 1fr); height:150px; gap:10px; right:0;}
  .floating-element{ width:40px; height:40px; font-size:1.1rem; }
  .contact-card{ padding:22px 16px; }
  .form-grid{ grid-template-columns:1fr; }
}
@media (max-width: 480px){
  .floating-elements{ grid-template-columns: repeat(3, 1fr); height:170px; right:0;}
  .floating-element{ width:36px; height:36px; font-size:1rem; right:0;}
}
@media (max-width: 360px){
  .floating-elements{ display:none; }
}

/* Bouton "Me contacter" du footer : fond bleu foncé */
.dev-footer .modal-link{
  background: #16213e;             /* bleu foncé */
  color: var(--dev-accent);        /* texte/icone cyan */   
  border: 2px solid var(--dev-accent);
  border-radius: 999px;            /* pastille bien arrondie */
  padding: 12px 25px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: background .25s ease, transform .2s ease, box-shadow .25s ease;
}

.dev-footer .modal-link:hover{
  background: #13224a;             /* un ton plus clair au survol */
  color: var(--dev-accent);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(76,201,240,.18);
}

.dev-footer .modal-link:active{
  transform: translateY(0);
  box-shadow: none;
}

/* ===== NAV MOBILE — menu vertical déroulant ===== */
@media (max-width: 768px){
  .nav-toggle{ display:block; }

  /* le conteneur nav sert d’ancrage */
  .nav-container{ position: relative; }

  /* menu replié par défaut */
  #main-menu{
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
    background: rgba(20, 16, 22, .92);                 /* fond sombre neutre */
    backdrop-filter: blur(10px);
    border-top: 1px solid var(--card-border, var(--border, rgba(255,255,255,.15)));
    border-bottom: 1px solid var(--card-border, var(--border, rgba(255,255,255,.15)));
    padding: 10px var(--gutter, 20px);

    /* animation d’ouverture */
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transform: translateY(-8px);
    transition: max-height .35s ease, opacity .25s ease, transform .25s ease;
    z-index: 999; /* au-dessus du contenu */
  }

  /* état ouvert */
  #main-menu.is-open{
    max-height: 60vh;   /* assez pour lister tes liens */
    opacity: 1;
    transform: translateY(0);
  }

  /* liens empilés */
  #main-menu .nav-link,
  #main-menu a,
  #main-menu button{
    display: block;
    padding: 14px 0;
    text-decoration: none;
    color: var(--crea-text, var(--text, #fff));
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  #main-menu .nav-link:last-child{ border-bottom: 0; }

  /* optionnel : hover */
  #main-menu .nav-link:hover{
    color: var(--crea-accent, var(--glow, #9e7bff));
  }
}

/* ===== OFF-CANVAS MOBILE (droite, 80%) ===== */
@media (max-width: 768px){
  /* on garde le bouton hamburger existant */
  .nav-toggle{ display:block; }
  /* masque le menu horizontal d'origine */
  #main-menu{ display:none !important; }

  /* Overlay 20% cliquable */
  .drawer-overlay{
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(2px);
    opacity: 0; pointer-events: none;
    transition: opacity .25s ease;
    z-index: 998;
  }
  .drawer-overlay.is-open{ opacity:1; pointer-events:auto; }

  /* Panneau */
  .mobile-drawer{
    position: fixed; top:0; right:0; height:100vh;
    width: 80vw; max-width: 420px; min-width: 300px;
    background: var(--dev-card-bg, rgba(22,33,62,.92));
    /* pour about (thème violet), les var() retomberont sur ces valeurs */
    backdrop-filter: blur(12px);
    border-left: 1px solid var(--dev-border, rgba(76,201,240,.28));
    box-shadow: -18px 0 60px rgba(0,0,0,.35);
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.22,1,.36,1);
    z-index: 1001; /* au-dessus de la navbar si besoin */
    display:flex; flex-direction:column;
    padding: 18px 20px 22px;
  }
  .mobile-drawer.is-open{ transform: translateX(0); }

  .drawer-header{
    display:flex; align-items:center; justify-content:space-between;
    padding: 6px 2px 12px;
    border-bottom: 1px solid var(--dev-border, rgba(76,201,240,.22));
  }
  .drawer-header h2{
    font-size: 1.1rem; font-weight: 800;
    color: var(--dev-text, #e6e6e6); letter-spacing:.2px;
  }
  .drawer-close{
    width:40px; height:40px; border-radius:10px;
    border:1px solid var(--dev-border, rgba(76,201,240,.3));
    background: rgba(0,0,0,.2);
    color: var(--dev-text, #e6e6e6); cursor:pointer;
  }
  .drawer-close:hover{ background: var(--dev-accent, #4cc9f0); color: var(--dev-primary, #1a1a2e); }

  .drawer-nav{
    display:flex; flex-direction:column; gap: 2px;
    padding: 10px 0;
  }
  .drawer-nav .nav-link{
    display:block; padding: 14px 2px;
    color: var(--dev-text, #e6e6e6); text-decoration:none;
    border-bottom: 1px solid rgba(255,255,255,.06);
    font-weight: 600;
  }
  .drawer-nav .nav-link:last-child{ border-bottom:0; }
  .drawer-nav .nav-link:hover{
    color: var(--dev-accent, #4cc9f0);
  }

  .drawer-footer{
    margin-top: auto; padding-top: 14px;
    border-top: 1px solid var(--dev-border, rgba(76,201,240,.22));
    display:flex; flex-direction:column; gap:12px;
  }
  .drawer-cta{
    display:inline-flex; align-items:center; gap:.6rem;
    padding: 12px 16px; border-radius: 12px;
    color: var(--dev-primary, #1a1a2e); background: var(--dev-accent, #4cc9f0);
    text-decoration:none; font-weight: 700; justify-content:center;
  }
  .drawer-cta:hover{ transform: translateY(-2px); box-shadow:0 10px 24px rgba(76,201,240,.28); }

  .drawer-socials{ display:flex; gap:10px; }
  .drawer-socials a{
    width:42px; height:42px; border-radius:12px;
    display:flex; align-items:center; justify-content:center;
    border:1px solid var(--dev-border, rgba(76,201,240,.3));
    color: var(--dev-accent, #4cc9f0);
    background: rgba(22,33,62,.35);
    text-decoration:none;
  }
}

/* Empêche le scroll du body quand le drawer est ouvert */
.body-no-scroll{ overflow: hidden; }

/* ==== SWITCH DEV/CRÉA ==== */
.mode-toggle{
  position: relative;
  display: inline-grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 0;
  width: 160px;
  height: 40px;
  padding: 4px;
  border-radius: 999px;
  text-decoration: none;
  user-select: none;
  cursor: pointer;
  /* fond et bord s’adaptent au thème */
  background: rgba(255,255,255,.06);
  border: 1px solid var(--dev-border, var(--card-border, rgba(255,255,255,.18)));
  backdrop-filter: blur(8px);
  isolation: isolate; /* pour le thumb */
}
.mode-toggle .toggle-half{
  position: relative;
  z-index: 2;
  display:flex; align-items:center; justify-content:center;
  font-weight: 800;
  font-size: .95rem;
  letter-spacing: .2px;
  border-radius: 999px;
  color: var(--dev-text, var(--crea-text, #eee));
  transition: color .25s ease, opacity .25s ease;
}
.mode-toggle .half-dev::before,
.mode-toggle .half-crea::before{
  content: "";
  position: absolute; inset: 0;
  border-radius: 999px;
  opacity: 0;                       /* allumé éteint */
  transition: opacity .25s ease;
  z-index: -1;
}

/* pastille mobile */
.mode-toggle .toggle-thumb{
  position: absolute;
  z-index: 1;
  top: 4px; bottom: 4px;
  width: calc(50% - 4px);
  border-radius: 999px;
  background: var(--dev-accent, var(--crea-accent, #ff8a65));
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
  transition: transform .28s cubic-bezier(.22,1,.36,1), background .25s ease;
}

/* États — page DEV allumée à gauche */
.mode-toggle.is-dev .toggle-thumb{
  transform: translateX(0);
  background: var(--dev-accent, #4cc9f0);
}
.mode-toggle.is-dev .half-dev{ color: var(--dev-primary, #1a1a2e); }
.mode-toggle.is-dev .half-dev::before{
  background: var(--dev-accent, #4cc9f0);
  opacity: 1;
}
.mode-toggle.is-dev .half-crea{ opacity: .9; }

/* États — page CRÉA allumée à droite */
.mode-toggle.is-crea .toggle-thumb{
  transform: translateX(100%);
  background: var(--crea-accent, #ff8a65);
}
.mode-toggle.is-crea .half-crea{ color: var(--crea-primary, #2b1a16); }
.mode-toggle.is-crea .half-crea::before{
  background: var(--crea-accent, #ff8a65);
  opacity: 1;
}
.mode-toggle.is-crea .half-dev{ opacity: .9; }

/* Hover léger (desktop) */
@media (hover:hover){
  .mode-toggle .toggle-half:hover{ opacity: 1; }
}

/* Placement dans la navbar */
.nav-container .mode-toggle{ margin-left: 12px; }

/* Cacher le switch en dessous de 768px */
/* Cacher le switch en dessous de 768px */
@media (max-width: 768px){
  .mode-toggle.is-crea.nav{
    display: none !important;
  }
}

/* Autoriser le scroll + smooth natif */
html, body { overflow-y: auto; }
html { scroll-behavior: smooth; }

/* Évite que la navbar fixe masque l’ancre */
:root { --nav-h: 72px; } /* ajuste si ta navbar est plus haute */
#projects, #skills, #contact-panel { scroll-margin-top: var(--nav-h); }
