:root{
  --bg:#F8FAFC; --white:#FFFFFF; --surface:#F1F5F9;
  --ink:#0F172A; --ink2:#334155; --muted:#64748B; --light:#94A3B8;
  --bd:#E2E8F0; --bd2:#CBD5E1;
  --primary:#3B82F6; --primary-dark:#2563EB; --primary-light:#60A5FA;
  --accent:#F97316; --accent-dark:#EA580C; 
  --navy:#1E293B; --teal:#0891B2; --green:#10B981; --purple:#8B5CF6;
  --fd:'Inter',system-ui,sans-serif;
  --fb:'Inter',system-ui,sans-serif;
  --fm:'JetBrains Mono','Fira Code',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--fb);font-size:15px;line-height:1.7;overflow-x:hidden}
::selection{background:rgba(59,130,246,.15)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}
img{display:block;max-width:100%}

/* ════════════════════════════
   NAV
════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bd);height:70px;
  padding:0 5%;display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 1px 3px rgba(0,0,0,.05);
}
.n-logo{font-family:var(--fb);font-size:1.3rem;font-weight:700;color:var(--ink);text-decoration:none;white-space:nowrap;letter-spacing:-.02em}
.n-logo em{color:var(--primary);font-style:normal;font-weight:800}
.n-links{display:flex;gap:2.5rem;list-style:none;align-items:center}
.n-links a{font-size:.9rem;font-weight:500;letter-spacing:-.01em;color:var(--muted);text-decoration:none;transition:all .2s;position:relative}
.n-links a:hover,.n-links a.on{color:var(--ink)}
.n-links a::after{content:'';position:absolute;bottom:-8px;left:0;right:0;height:2px;background:var(--primary);transform:scaleX(0);transition:transform .3s ease}
.n-links a:hover::after,.n-links a.on::after{transform:scaleX(1)}
.n-cta{background:var(--primary)!important;color:var(--white)!important;padding:.6rem 1.4rem!important;border-radius:4px!important;transition:all .2s!important;font-weight:600!important}
.n-cta:hover{background:var(--primary-dark)!important;transform:translateY(-2px)!important;box-shadow:0 4px 12px rgba(59,130,246,.3)!important}
.n-cta::after{display:none!important}

/* Hamburger */
.n-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.n-burger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:4px;transition:all .3s}
.n-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.n-burger.open span:nth-child(2){opacity:0}
.n-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.n-drawer{
  display:none;position:fixed;top:60px;left:0;right:0;bottom:0;z-index:299;
  background:rgba(249,247,243,.98);backdrop-filter:blur(14px);
  flex-direction:column;align-items:center;justify-content:center;gap:2rem;
}
.n-drawer.open{display:flex}
.n-drawer a{font-family:var(--fd);font-size:2rem;font-weight:600;color:var(--ink);text-decoration:none;transition:color .2s}
.n-drawer a:hover{color:var(--gold)}
.n-drawer .n-cta{font-family:var(--fb);font-size:.88rem;padding:.6rem 2rem;font-weight:500}

/* ════════════════════════════
   HERO
════════════════════════════ */
#hero{
  min-height:100svh;padding-top:60px;
  display:grid;grid-template-columns:58% 42%;
}
.h-left{
  display:flex;flex-direction:column;justify-content:center;
  padding:5rem 4rem 5rem 5%;position:relative;
}
.h-left::after{
  content:'';position:absolute;right:0;top:10%;bottom:10%;
  width:1px;background:linear-gradient(180deg,transparent,var(--bd2) 35%,var(--bd2) 65%,transparent);
}
.h-eyebrow{display:flex;align-items:center;gap:.7rem;margin-bottom:1.8rem;animation:sli .7s ease both}
.h-eline{width:32px;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:4px}
.h-etxt{font-family:var(--fm);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);font-weight:600}
.h-name{
  font-family:var(--fb);font-size:clamp(2.8rem,4.5vw,5rem);font-weight:300;
  line-height:1.1;color:var(--ink);animation:sli .7s .1s ease both;letter-spacing:-.03em;
}
.h-name strong{display:block;font-weight:800;background:linear-gradient(135deg,var(--ink) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.h-name em{color:var(--primary);font-style:normal;font-weight:900}
.h-divrow{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;animation:sli .7s .2s ease both}
.h-drule{flex:1;height:1px;background:var(--bd2)}
.h-dtxt{font-family:var(--fm);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.tech-animate{
  display:inline-block;
  background:linear-gradient(90deg,var(--muted) 0%,var(--primary) 25%,var(--accent) 50%,var(--primary) 75%,var(--muted) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:techGradient 4s ease-in-out infinite, techFloat 3s ease-in-out infinite;
}
@keyframes techGradient{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
@keyframes techFloat{
  0%,100%{transform:translateX(0) translateY(0)}
  25%{transform:translateX(4px) translateY(-2px)}
  50%{transform:translateX(0) translateY(0)}
  75%{transform:translateX(-4px) translateY(2px)}
}
.h-desc{font-size:.97rem;color:var(--ink2);max-width:420px;line-height:1.8;margin-bottom:2.2rem;font-weight:300;animation:sli .7s .3s ease both}
.h-btns{display:flex;gap:.85rem;flex-wrap:wrap;animation:sli .7s .4s ease both}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.8rem;font-family:var(--fb);font-size:.9rem;font-weight:600;letter-spacing:-.01em;text-decoration:none;cursor:pointer;border:none;border-radius:4px;transition:all .25s;position:relative;overflow:hidden}
.btn-p{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--white);box-shadow:0 4px 14px rgba(59,130,246,.25)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(59,130,246,.35)}
.btn-g{background:var(--white);color:var(--ink);border:2px solid var(--bd);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.btn-g:hover{border-color:var(--primary);color:var(--primary);box-shadow:0 4px 12px rgba(59,130,246,.15)}

.h-right{
  background:var(--surface);display:flex;flex-direction:column;
  justify-content:center;align-items:center;padding:5rem 4% 5rem;
  animation:fdi .9s .4s ease both;
}
.pcard{
  background:var(--white);border:1px solid var(--bd);border-radius:4px;
  padding:2rem;width:100%;max-width:400px;
  box-shadow:0 8px 32px rgba(15,23,42,.08);position:relative;
}
.pcard::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);border-radius:4px 4px 0 0;
}
.pc-tag{font-family:var(--fm);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.pc-name{font-family:var(--fd);font-size:1.35rem;font-weight:600;color:var(--ink);margin-top:.25rem;line-height:1.2}
.pc-rows{margin-top:1.5rem}
.pcr{display:flex;justify-content:space-between;align-items:center;padding:.65rem 0;border-bottom:1px solid var(--bd)}
.pcr:last-child{border-bottom:none}
.pcr-k{font-size:.82rem;color:var(--muted)}
.pcr-v{font-family:var(--fd);font-size:1.25rem;font-weight:600;color:var(--ink)}
.pcr-v small{font-family:var(--fb);font-size:.7rem;color:var(--gold);margin-left:2px}
.pcr-countries{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;font-size:.75rem!important}
.pcr-countries small{font-size:.7rem;color:var(--ink2);margin:0}
.avail{display:flex;align-items:center;gap:.55rem;margin-top:1.3rem;font-size:.8rem;color:var(--green);font-weight:500}
.adot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:pulse 2.5s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(46,107,80,.4)}50%{box-shadow:0 0 0 5px rgba(46,107,80,0)}}
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-top:2.5rem;animation:bob 2s 1.2s infinite}
.scroll-cue span{font-family:var(--fm);font-size:.6rem;letter-spacing:.13em;text-transform:uppercase;color:var(--light)}
.scroll-cue::after{content:'';width:1px;height:26px;background:var(--light);display:block}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
@keyframes sli{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
@keyframes fdi{from{opacity:0}to{opacity:1}}

/* ════════════════════════════
   SECTION BASE
════════════════════════════ */
.sec{padding:6rem 5%}
.sec-alt{background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%)}
.sec-dark{background:linear-gradient(135deg,var(--navy) 0%,var(--ink) 100%);color:var(--white)}

.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:4rem;padding-bottom:1.6rem;border-bottom:1px solid var(--bd2);
}
.sec-dark .sec-head{border-bottom-color:rgba(255,255,255,.1)}
.sn{font-family:var(--fd);font-size:3.8rem;font-weight:300;color:var(--bd2);line-height:1;margin-bottom:-.35rem}
.sec-dark .sn{color:rgba(255,255,255,.06)}
.st{font-family:var(--fd);font-size:clamp(1.9rem,3vw,2.7rem);font-weight:600;letter-spacing:-.02em;color:var(--ink);line-height:1.1}
.sec-dark .st{color:var(--white)}
.st em{color:var(--gold);font-style:italic}
.stag{font-family:var(--fm);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:right;line-height:1.8}
.sec-dark .stag{color:rgba(255,255,255,.3)}

/* ════════════════════════════
   STATISTIQUES
════════════════════════════ */
.stats-sec{
  padding:4rem 5%;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:3rem;
  max-width:1100px;
  margin:0 auto;
}
.stat-item{
  text-align:center;
  padding:2rem 1.5rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:4px;
  transition:all .3s;
}
.stat-item:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.25);
  transform:translateY(-4px);
}
.stat-num{
  font-family:var(--fd);
  font-size:3.5rem;
  font-weight:700;
  color:var(--white);
  line-height:1;
  margin-bottom:.5rem;
}
.stat-lbl{
  font-family:var(--fb);
  font-size:.9rem;
  font-weight:500;
  color:rgba(255,255,255,.85);
  letter-spacing:.02em;
}
.stat-sub{
  font-family:var(--fm);
  font-size:.7rem;
  color:rgba(255,255,255,.5);
  margin-top:.4rem;
  letter-spacing:.05em;
}

/* ════════════════════════════
   SKILLS
════════════════════════════ */
.sk-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:start}
.sk-quote{
  font-family:var(--fd);font-size:1.2rem;font-weight:300;font-style:italic;
  color:var(--ink2);line-height:1.75;padding-right:3rem;
  border-right:1px solid var(--bd);margin-bottom:2.2rem;
}
.sk-quote strong{font-style:normal;font-weight:600;color:var(--ink)}
.mono-lbl{font-family:var(--fm);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem}
.pills{display:flex;flex-wrap:wrap;gap:.4rem}
.pill{
  padding:.25rem .8rem;background:var(--white);border:1px solid var(--bd2);
  border-radius:4px;font-size:.75rem;font-family:var(--fm);color:var(--ink2);
  transition:all .18s;cursor:default;
}
.pill:hover{border-color:var(--gold);color:var(--gold)}
.sk-bar{margin-bottom:1.75rem}
.sk-bh{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.45rem}
.sk-lbl{font-size:.87rem;font-weight:500;color:var(--ink)}
.sk-pct{font-family:var(--fd);font-size:1rem;font-weight:600;color:var(--gold)}
.sk-tr{height:2px;background:var(--bd);overflow:hidden}
.sk-fi{height:100%;background:linear-gradient(90deg,var(--navy),var(--teal));transform:scaleX(0);transform-origin:left;transition:transform 1.2s cubic-bezier(.16,1,.3,1)}
.sk-fi.go{transform:scaleX(1)}

/* ════════════════════════════
   PROJECTS
════════════════════════════ */
.proj-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
}
.pc{
  background:var(--white);border:1px solid var(--bd);border-radius:4px;
  display:flex;flex-direction:column;overflow:hidden;
  transition:all .35s cubic-bezier(.4,0,.2,1);
  box-shadow:0 2px 8px rgba(44,42,38,.06);
}
.pc:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 40px rgba(44,42,38,.12);
  border-color:var(--gold);
}
.pc-img{
  height:240px;position:relative;overflow:hidden;flex-shrink:0;
  background:var(--surface);
}
.pc-badge{
  position:absolute;top:14px;right:14px;
  padding:.45rem 1rem;
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  color:white;font-family:var(--fb);font-size:.72rem;font-weight:700;
  letter-spacing:.02em;
  border-radius:4px;
  box-shadow:0 4px 16px rgba(249,115,22,.35);
  z-index:10;
  animation:pulse 2.5s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1);box-shadow:0 4px 16px rgba(249,115,22,.35)}
  50%{transform:scale(1.06);box-shadow:0 6px 20px rgba(249,115,22,.5)}
}
.pc-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.pc:hover .pc-img img{transform:scale(1.05)}
.pc-img svg{width:100%;height:100%}
.pc-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(158,107,53,.92),rgba(35,53,87,.92));
  display:flex;align-items:center;justify-content:center;gap:1rem;
  opacity:0;transition:opacity .35s;
}
.pc:hover .pc-img-overlay{opacity:1}
.ov-btn{
  padding:.6rem 1.4rem;
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(10px);
  border:1.5px solid rgba(255,255,255,.8);
  color:var(--white);
  font-family:var(--fb);font-size:.75rem;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;
  text-decoration:none;border-radius:4px;
  transition:all .25s;
}
.ov-btn:hover{
  background:rgba(255,255,255,.95);
  color:var(--navy);
  transform:translateY(-2px);
}
.pc-body{padding:1.8rem;flex:1;display:flex;flex-direction:column}
.pc-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1rem}
.pt{
  padding:.35rem .75rem;
  font-family:var(--fb);font-size:.7rem;font-weight:600;
  letter-spacing:.02em;border-radius:4px;
  transition:all .2s;
}
.pt-l{background:#FEF3C7;color:#92400E;border:1px solid #FDE68A}
.pt-v{background:#D1FAE5;color:#065F46;border:1px solid #A7F3D0}
.pt-w{background:#DBEAFE;color:#1E40AF;border:1px solid #BFDBFE}
.pt-p{background:#E9D5FF;color:#6B21A8;border:1px solid #D8B4FE}
.pt-j{background:#FEF9C3;color:#854D0E;border:1px solid #FEF08A}
.pt-a{background:#F1F5F9;color:#475569;border:1px solid #E2E8F0}
.pt-m{background:#DBEAFE;color:#1E40AF;border:1px solid #BFDBFE}
.pt-n{background:#D1FAE5;color:#065F46;border:1px solid #A7F3D0}
.pt:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.08)}
.pc-name{
  font-family:var(--fd);font-size:1.4rem;font-weight:600;
  color:var(--ink);margin-bottom:.6rem;line-height:1.2;
  letter-spacing:-.01em;
}
.pc-desc{
  font-size:.88rem;color:var(--ink2);line-height:1.75;
  flex:1;margin-bottom:1.4rem;
}
.pc-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:1rem;border-top:1px solid var(--bd);
}
.pc-link{
  font-family:var(--fb);font-size:.75rem;font-weight:600;
  letter-spacing:.02em;color:var(--primary);
  text-decoration:none;
  transition:all .2s;display:inline-flex;align-items:center;gap:.4rem;
}
.pc-link:hover{color:var(--navy);transform:translateX(3px)}
.pc-arr{
  color:var(--bd2);transition:all .3s;font-size:1.1rem;
  display:inline-block;
}
.pc:hover .pc-arr{color:var(--primary);transform:translate(4px,-4px)}

/* ════════════════════════════
   EXPERIENCE
════════════════════════════ */
.exp-wrap{display:grid;grid-template-columns:190px 1fr;gap:0}
.exp-side{padding-right:2.5rem;border-right:1px solid var(--bd2);padding-top:.2rem}
.exp-side .mono-lbl{margin-bottom:1.3rem}
.esn{display:flex;flex-direction:column}
.esn-i{
  font-size:.82rem;color:var(--muted);padding:.5rem 0 .5rem .75rem;
  border-left:2px solid transparent;cursor:pointer;transition:all .2s;
}
.esn-i.on{color:var(--ink);font-weight:500;border-left-color:var(--gold)}
.exp-main{padding-left:3rem}
.exp-it{
  padding-bottom:2.5rem;margin-bottom:2.5rem;border-bottom:1px solid var(--bd);
  opacity:0;transform:translateY(14px);transition:opacity .65s ease,transform .65s ease;
  scroll-margin-top:100px;
}
.exp-it.vis{opacity:1;transform:translateY(0)}
.exp-it:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.exp-date{font-family:var(--fm);font-size:.66rem;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;margin-bottom:.35rem}
.exp-role{font-family:var(--fd);font-size:1.4rem;font-weight:600;color:var(--ink);letter-spacing:-.01em;margin-bottom:.25rem}
.exp-co{font-size:.82rem;color:var(--muted);margin-bottom:1rem;display:flex;align-items:center;gap:.6rem}
.exp-co::after{content:'';flex:1;height:1px;background:var(--bd);max-width:100px}
.exp-pts{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.exp-pts li{font-size:.85rem;color:var(--ink2);padding-left:1.05rem;position:relative;line-height:1.65}
.exp-pts li::before{content:'';position:absolute;left:0;top:.6em;width:4px;height:4px;background:var(--gold);border-radius:50%}

/* ════════════════════════════
   CONTACT
════════════════════════════ */
.ct-wrap{display:grid;grid-template-columns:1fr 1.15fr;gap:4.5rem;align-items:start}
.ct-ql{font-family:var(--fd);font-size:1.25rem;font-weight:300;font-style:italic;color:rgba(255,255,255,.5);line-height:1.65;margin-bottom:2.2rem}
.ct-items{display:flex;flex-direction:column}
.ct-it{
  display:flex;align-items:center;gap:.9rem;text-decoration:none;
  color:rgba(255,255,255,.62);font-size:.87rem;transition:color .2s;
  padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.07);
}
.ct-it:last-child{border-bottom:none}
.ct-it:hover{color:#D4A574}
.ct-ico{
  width:37px;height:37px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.85rem;
  flex-shrink:0;transition:all .2s;
}
.ct-it:hover .ct-ico{background:rgba(158,107,53,.2);border-color:var(--gold2)}
.ct-lbl{font-family:var(--fm);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.28)}
.ct-val{font-size:.84rem;margin-top:1px}
.cf{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:2rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:.85rem}
.fg{margin-bottom:.85rem}
.fg label{display:block;font-family:var(--fm);font-size:.6rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.33);margin-bottom:.4rem}
.fg input,.fg textarea{
  width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:4px;padding:.62rem .85rem;color:var(--white);font-family:var(--fb);
  font-size:.87rem;outline:none;transition:border-color .2s;
}
.fg input:focus,.fg textarea:focus{border-color:var(--gold2)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.18)}
.fg textarea{resize:vertical;min-height:105px}
.btn-s{width:100%;justify-content:center;padding:.82rem;background:var(--gold)!important;color:var(--white)!important;font-size:.78rem!important;letter-spacing:.1em!important;border-radius:4px;margin-top:.2rem}
.btn-s:hover{background:var(--gold2)!important;transform:none!important;box-shadow:none!important}

/* ════════════════════════════
   FOOTER
════════════════════════════ */
footer{
  background:var(--ink);padding:2rem 5%;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--fb);font-size:.85rem;letter-spacing:-.01em;
  color:rgba(255,255,255,.5);
}
footer b{color:var(--primary-light);font-weight:600}

/* ════════════════════════════
   REVEAL / TOAST
════════════════════════════ */
.rv{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.rv.vis{opacity:1;transform:translateY(0)}
.toast{
  position:fixed;bottom:1.5rem;right:1.5rem;background:var(--white);
  border:1px solid var(--bd2);border-left:3px solid var(--green);
  padding:.85rem 1.3rem;border-radius:3px;font-size:.82rem;color:var(--ink);
  box-shadow:0 6px 24px rgba(44,42,38,.1);z-index:999;
  transform:translateY(60px);opacity:0;transition:all .38s cubic-bezier(.16,1,.3,1);
}
.toast.show{transform:translateY(0);opacity:1}

/* ════════════════════════════
   RESPONSIVE — tablet 768-1100
════════════════════════════ */
@media(max-width:1100px){
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .pc:nth-child(3n){border-right:1px solid var(--bd)}
}
@media(max-width:900px){
  nav{padding:0 4%}
  .n-links{display:none}
  .n-burger{display:flex}

  #hero{grid-template-columns:1fr;min-height:auto;padding-top:60px}
  .h-left{padding:3.5rem 5% 2.5rem;align-items:center;text-align:center}
  .h-left::after{display:none}
  .h-eyebrow{justify-content:center}
  .h-divrow{flex-direction:column;gap:.5rem}
  .h-drule{display:none}
  .h-desc{text-align:left;max-width:100%}
  .h-btns{justify-content:center}
  .h-right{padding:2rem 5% 3rem}

  .sec{padding:4.5rem 5%}
  .sec-head{flex-direction:column;align-items:flex-start;gap:.6rem}
  .sn{font-size:2.8rem}

  .sk-wrap{grid-template-columns:1fr;gap:2.5rem}
  .sk-quote{border-right:none;padding-right:0;border-bottom:1px solid var(--bd);padding-bottom:1.8rem}

  .proj-grid{grid-template-columns:1fr}

  .exp-wrap{grid-template-columns:1fr}
  .exp-side{border-right:none;border-bottom:1px solid var(--bd2);padding-right:0;padding-bottom:1.2rem;margin-bottom:1.8rem}
  .esn{flex-direction:row;flex-wrap:wrap;gap:.4rem}
  .esn-i{border-left:none;padding:.3rem .8rem;border-radius:20px;background:var(--surface);border:1px solid var(--bd)}
  .esn-i.on{background:var(--ink);color:var(--white);border-color:var(--ink)}
  .exp-main{padding-left:0}

  .ct-wrap{grid-template-columns:1fr;gap:2.5rem}
  .fr{grid-template-columns:1fr}
  .sec#contact{padding:4.5rem 5%}

  footer{flex-direction:column;gap:.4rem;text-align:center}
}
@media(max-width:500px){
  .h-left{padding:2.8rem 4% 2rem}
  .sec{padding:3.5rem 4%}
  .sec#contact{padding:3.5rem 4%}
  .btn{padding:.65rem 1.3rem;font-size:.74rem}
  .pcard{padding:1.5rem}
  .cf{padding:1.5rem}
  footer{padding:1.3rem 4%}
}
