:root {
  --white:   #ffffff;
  --off:     #f6f9fc;
  --bg:      #eef5fb;
  --bg2:     #ddeef8;
  --card:    #ffffff;
  --forest:  #0d3a5c;
  --green:   #1a7abf;
  --mid:     #3a9aca;
  --sage:    #72c4e0;
  --sage-lt: #b8e4f4;
  --mint:    #e2f4fb;
  --sky:     #2a7ab8;
  --ink:     #0e1e30;
  --ink2:    #1e3a52;
  --ink3:    #4a6880;
  --ink4:    #8aaac0;
  --border:  rgba(26,122,191,.12);
  --shadow:  0 2px 12px rgba(26,122,191,.07);
  --shadow2: 0 6px 28px rgba(26,122,191,.11);
  --r:       14px;
  --r2:      20px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--ink);font-family:'Plus Jakarta Sans',sans-serif;font-weight:300;overflow-x:hidden;cursor:none;}

/* CURSOR */
.cur{position:fixed;width:7px;height:7px;background:var(--green);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s;}
.cur-ring{position:fixed;width:28px;height:28px;border:1.5px solid var(--sage);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left .1s,top .1s;}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 3rem;height:62px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow);
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;}
.nav-logo-icon{
  width:34px;height:34px;background:var(--green);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:#fff;letter-spacing:-.02em;
}
.nav-logo-text{font-size:.95rem;font-weight:700;color:var(--forest);letter-spacing:-.01em;}
.nav-logo-text span{font-weight:300;color:var(--ink3);}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{font-size:.82rem;font-weight:500;color:var(--ink3);text-decoration:none;transition:color .2s;}
.nav-links a:hover{color:var(--green);}
.nav-cta{
  background:var(--green);color:#fff;
  font-size:.8rem;font-weight:600;
  padding:.5rem 1.3rem;border-radius:8px;
  text-decoration:none;
  transition:all .2s;
  box-shadow:0 2px 8px rgba(26,122,191,.25);
}
.nav-cta:hover{background:var(--forest);transform:translateY(-1px);box-shadow:0 4px 14px rgba(26,122,191,.3);}

/* HERO */
#hero{
  min-height:100vh;padding-top:62px;
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--white);
  position:relative;overflow:hidden;
}
.hero-bg-blob{
  position:absolute;
  top:-120px;right:-120px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(150,200,240,.35) 0%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
}
.hero-bg-blob2{
  position:absolute;
  bottom:-80px;left:40%;
  width:340px;height:340px;
  background:radial-gradient(circle,rgba(100,180,230,.18) 0%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
}
.hero-left{
  padding:5rem 3.5rem 4rem 4rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:2;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--mint);border:1px solid var(--sage-lt);
  color:var(--mid);font-size:.72rem;font-weight:600;
  padding:.35rem .9rem;border-radius:20px;
  margin-bottom:1.8rem;width:fit-content;
}
.hero-pill::before{content:'';width:6px;height:6px;background:var(--mid);border-radius:50%;}
h1{
  font-size:clamp(2.8rem,5vw,5rem);
  line-height:1.02;
  letter-spacing:-.03em;
  color:var(--ink);
  margin-bottom:.5rem;
}
h1 strong{font-weight:800;color:var(--forest);}
h1 .light{font-weight:200;color:var(--ink3);}
.hero-dash{width:2.5rem;height:3px;background:var(--sage);border-radius:2px;margin:1.6rem 0;}
.hero-intro{font-size:.97rem;color:var(--ink3);line-height:1.85;max-width:400px;font-weight:400;}
.hero-intro strong{color:var(--green);font-weight:600;}
.hero-ctas{display:flex;gap:.9rem;margin-top:2.2rem;align-items:center;flex-wrap:wrap;}
.btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.82rem 1.8rem;background:var(--green);color:#fff;
  font-size:.82rem;font-weight:600;border-radius:10px;text-decoration:none;
  box-shadow:0 3px 12px rgba(26,122,191,.28);transition:all .25s;
}
.btn-primary:hover{background:var(--forest);transform:translateY(-2px);box-shadow:0 6px 20px rgba(26,122,191,.32);}
.btn-secondary{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.82rem 1.8rem;background:transparent;
  border:1.5px solid var(--border);color:var(--ink2);
  font-size:.82rem;font-weight:500;border-radius:10px;text-decoration:none;
  transition:all .25s;
}
.btn-secondary:hover{border-color:var(--sage);color:var(--green);}
.hero-stats{
  display:flex;gap:0;margin-top:3.5rem;
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;width:fit-content;
}
.h-stat{padding:1rem 1.8rem;display:flex;flex-direction:column;align-items:center;}
.h-stat+.h-stat{border-left:1px solid var(--border);}
.h-stat-n{font-size:1.8rem;font-weight:800;color:var(--forest);line-height:1;letter-spacing:-.03em;}
.h-stat-l{font-size:.65rem;font-weight:500;color:var(--ink4);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem;}

/* Hero right */
.hero-right{
  display:flex;flex-direction:column;
  position:relative;z-index:2;
  overflow:hidden;
  border-left:1px solid var(--border);
}
.photo-wrap{
  position:relative;
  width:100%;
  height:100%;
  min-height:100%;
}
.photo-frame{
  width:100%;height:100%;
  overflow:hidden;
}
.photo-landscape{width:100%;display:block;}
.photo-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;
}
.photo-icon-wrap{
  width:58px;height:58px;border-radius:50%;
  background:rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(255,255,255,.4);
}
.photo-hint{font-size:.65rem;color:rgba(255,255,255,.55);font-weight:500;letter-spacing:.06em;}
.photo-badge{
  position:absolute;
  top:1.2rem;right:-1rem;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:10px;
  padding:.7rem 1rem;
  box-shadow:var(--shadow2);
  text-align:center;
  min-width:90px;
}
.badge-n{font-size:1.5rem;font-weight:800;color:var(--forest);line-height:1;letter-spacing:-.03em;}
.badge-l{font-size:.6rem;font-weight:500;color:var(--ink4);text-transform:uppercase;letter-spacing:.1em;margin-top:.15rem;}

/* SECTION COMMONS */
.sw{max-width:1200px;margin:0 auto;}
section{padding:7rem 3.5rem;}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--mint);color:var(--mid);
  font-size:.68rem;font-weight:700;
  padding:.3rem .8rem;border-radius:20px;
  letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:1rem;border:1px solid var(--sage-lt);
}
h2{font-size:clamp(1.9rem,3vw,2.9rem);font-weight:800;line-height:1.1;letter-spacing:-.025em;color:var(--ink);margin-bottom:2.5rem;}
h2 em{font-style:normal;color:var(--green);}
h2 .light{font-weight:300;}

/* ABOUT */
#about{background:var(--white);}
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:6rem;align-items:start;}
.about-text p{font-size:.97rem;line-height:1.85;color:var(--ink3);margin-bottom:1.2rem;font-weight:400;}
.about-text p strong{color:var(--forest);font-weight:600;}
.val-cards{display:flex;flex-direction:column;gap:.75rem;}
.val-card{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r);padding:1.2rem 1.4rem;
  display:flex;gap:1rem;align-items:flex-start;
  transition:all .25s;
}
.val-card:hover{background:var(--white);box-shadow:var(--shadow2);transform:translateY(-1px);}
.val-icon{
  width:36px;height:36px;border-radius:9px;
  background:var(--mint);border:1px solid var(--sage-lt);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:.95rem;
}
.val-title{font-size:.88rem;font-weight:700;color:var(--ink);margin-bottom:.2rem;}
.val-desc{font-size:.78rem;color:var(--ink3);line-height:1.6;}

/* EXPERTISE */
#expertise{background:var(--off);}
.stack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.5rem;}
.stack-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r);padding:1.8rem;
  transition:all .25s;
}
.stack-card:hover{box-shadow:var(--shadow2);transform:translateY(-2px);border-color:var(--sage-lt);}
.stack-icon{font-size:1.3rem;margin-bottom:.8rem;display:block;}
.stack-card h3{font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:.4rem;}
.stack-card p{font-size:.78rem;color:var(--ink3);line-height:1.65;margin-bottom:.9rem;}
.tags{display:flex;flex-wrap:wrap;gap:.35rem;}
.tag{
  font-size:.63rem;font-weight:500;
  color:var(--mid);
  background:var(--mint);
  border:1px solid var(--sage-lt);
  padding:.18rem .55rem;border-radius:6px;
}

/* PARCOURS */
#parcours{background:var(--white);}
.tl{position:relative;max-width:800px;}
.tl::before{
  content:'';position:absolute;left:15px;top:6px;bottom:0;
  width:2px;background:linear-gradient(to bottom,var(--sage),var(--sage-lt) 90%,transparent);
  border-radius:2px;
}
.tl-item{
  padding:0 0 2.5rem 3rem;
  position:relative;
}
.tl-dot{
  position:absolute;left:6px;top:4px;
  width:20px;height:20px;border-radius:50%;
  background:var(--white);border:2.5px solid var(--green);
  display:flex;align-items:center;justify-content:center;
}
.tl-dot::after{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);}
.tl-card{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r);padding:1.3rem 1.5rem;
  transition:all .25s;
}
.tl-card:hover{background:var(--white);box-shadow:var(--shadow);}
.tl-period{font-size:.67rem;font-weight:600;color:var(--sage);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.35rem;}
.tl-title{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:.2rem;}
.tl-co{font-size:.75rem;font-weight:500;color:var(--sky);margin-bottom:.6rem;}
.tl-desc{font-size:.82rem;color:var(--ink3);line-height:1.75;}

/* PROJETS */
#projets{background:var(--off);}
.projets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:2.5rem;}
.proj-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r2);overflow:hidden;
  transition:all .3s;
}
.proj-card:hover{box-shadow:var(--shadow2);transform:translateY(-3px);}
.proj-card a{text-decoration:none;color:inherit;display:block;}
.proj-img{position:relative;line-height:0;overflow:hidden;border-radius:var(--r2) var(--r2) 0 0;}
.proj-img svg{width:100%;height:auto;display:block;transition:transform .5s;}
.proj-card:hover .proj-img svg{transform:scale(1.03);}
.proj-img img{transition:transform .5s ease;}
.proj-card:hover .proj-img img{transform:scale(1.03);}
.proj-img-overlay{
  position:absolute;inset:0;
  background:rgba(30,64,16,0);
  display:flex;align-items:center;justify-content:center;
  transition:background .3s;border-radius:var(--r2) var(--r2) 0 0;
}
.proj-card:hover .proj-img-overlay{background:rgba(30,64,16,.45);}
.proj-img-cta{
  font-size:.72rem;font-weight:600;color:#fff;
  background:rgba(255,255,255,.18);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.4);
  padding:.5rem 1.1rem;border-radius:8px;
  opacity:0;transition:opacity .3s;letter-spacing:.05em;
}
.proj-card:hover .proj-img-cta{opacity:1;}
.proj-body{padding:1.5rem 1.6rem 1.8rem;}
.proj-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mid);background:var(--mint);border:1px solid var(--sage-lt);
  padding:.2rem .7rem;border-radius:20px;margin-bottom:.8rem;
}
.proj-card h3{font-size:1.3rem;font-weight:800;color:var(--ink);margin-bottom:.6rem;letter-spacing:-.02em;}
.proj-card p{font-size:.85rem;color:var(--ink3);line-height:1.8;margin-bottom:1rem;}
.proj-cta-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.75rem;font-weight:600;color:var(--green);
  transition:gap .25s;
}
.proj-card:hover .proj-cta-link{gap:.8rem;}
.proj-soon{background:var(--off) !important;}
.proj-soon h3{color:var(--ink3);}

/* CONTACT */
#contact{background:var(--white);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;}
.contact-info p{font-size:.95rem;color:var(--ink3);line-height:1.85;margin-bottom:1.5rem;}
.c-details{display:flex;flex-direction:column;gap:.8rem;margin-top:1.5rem;}
.c-row{
  display:flex;align-items:center;gap:.9rem;
  background:var(--off);border:1px solid var(--border);
  border-radius:10px;padding:.8rem 1rem;
}
.c-icon{
  width:32px;height:32px;border-radius:8px;
  background:var(--mint);border:1px solid var(--sage-lt);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;
}
.c-lbl{font-size:.62rem;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.08em;}
.c-val{font-size:.85rem;color:var(--ink);font-weight:500;}
.c-val a{color:var(--ink);text-decoration:none;transition:color .2s;}
.c-val a:hover{color:var(--green);}

form{display:flex;flex-direction:column;gap:1rem;}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.f-group{display:flex;flex-direction:column;gap:.4rem;}
label{font-size:.68rem;font-weight:700;color:var(--ink2);letter-spacing:.05em;text-transform:uppercase;}
input,textarea{
  background:var(--off);border:1.5px solid var(--border);
  color:var(--ink);padding:.8rem 1rem;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:.88rem;font-weight:400;outline:none;
  transition:border-color .2s,background .2s,box-shadow .2s;
  resize:none;border-radius:10px;
}
input:focus,textarea:focus{
  border-color:var(--sage);background:var(--white);
  box-shadow:0 0 0 3px rgba(138,186,106,.15);
}
textarea{min-height:130px;}
.btn-form{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.9rem 2rem;background:var(--green);color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:.82rem;font-weight:700;border-radius:10px;
  border:none;cursor:pointer;width:fit-content;
  box-shadow:0 3px 12px rgba(26,122,191,.28);
  transition:all .25s;
}
.btn-form:hover{background:var(--forest);transform:translateY(-2px);}

/* FOOTER */
footer{
  background:var(--forest);color:rgba(255,255,255,.75);
  padding:2.5rem 3.5rem;
  display:flex;align-items:center;justify-content:space-between;
}
.f-logo{font-size:.95rem;font-weight:800;color:#fff;letter-spacing:-.01em;}
.f-logo span{font-weight:300;opacity:.6;}
.f-copy{font-size:.68rem;color:rgba(255,255,255,.45);letter-spacing:.04em;}
.f-links{display:flex;gap:1.8rem;}
.f-links a{font-size:.72rem;color:rgba(255,255,255,.55);text-decoration:none;font-weight:500;transition:color .2s;}
.f-links a:hover{color:#fff;}

/* MODAL */
.ml-overlay{display:none;position:fixed;inset:0;background:rgba(20,30,16,.55);z-index:500;backdrop-filter:blur(4px);}
.ml-panel{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--white);max-width:660px;width:92%;max-height:85vh;overflow-y:auto;
  padding:3rem;border-radius:var(--r2);box-shadow:0 20px 60px rgba(20,30,16,.2);
}
.ml-close{position:absolute;top:1rem;right:1rem;background:var(--off);border:1px solid var(--border);font-size:1rem;width:32px;height:32px;border-radius:8px;cursor:pointer;color:var(--ink3);display:flex;align-items:center;justify-content:center;}
.ml-h3{font-size:.72rem;font-weight:700;color:var(--mid);letter-spacing:.12em;text-transform:uppercase;margin:1.5rem 0 .6rem;}
.ml-p{font-size:.87rem;color:var(--ink2);line-height:1.85;}

/* REVEAL */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .65s ease,transform .65s ease;}
.reveal.on{opacity:1;transform:translateY(0);}

/* STAGGER */
.reveal:nth-child(2){transition-delay:.08s;}
.reveal:nth-child(3){transition-delay:.16s;}
.reveal:nth-child(4){transition-delay:.24s;}

/* RESPONSIVE */
@media(max-width:960px){
  nav{padding:0 1.5rem;}
  .nav-links,.nav-cta{display:none;}
  section{padding:4.5rem 1.5rem;}
  #hero{grid-template-columns:1fr;padding-top:62px;min-height:auto;}
  .hero-left{padding:3rem 1.5rem;}
  .hero-right{display:none;}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:3rem;}
  .stack-grid{grid-template-columns:1fr 1fr;}
  .projets-grid{grid-template-columns:1fr;}
  .f-row{grid-template-columns:1fr;}
  footer{flex-direction:column;gap:1rem;text-align:center;padding:2rem 1.5rem;}
  .f-links{display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.5rem;justify-items:center;}
  .f-logo{margin-bottom:.2rem;}
  body{cursor:auto;}
  .cur,.cur-ring{display:none;}
}
@media(max-width:600px){
  .stack-grid{grid-template-columns:1fr;}
  h1{font-size:2.5rem;}
}
